mirror of
https://gitlab.xiph.org/xiph/ezstream.git
synced 2025-01-03 14:56:35 -05:00
b61b78e161
Adds support for WebM/Matroska Replaces Vorbis and Theora with Ogg
211 lines
5.5 KiB
C
211 lines
5.5 KiB
C
#include <check.h>
|
|
#include <limits.h>
|
|
#include <netdb.h>
|
|
|
|
#include "cfg_private.h"
|
|
#include "log.h"
|
|
|
|
#include "check_cfg.h"
|
|
|
|
static void _el_cb(cfg_encoder_t, void *);
|
|
|
|
Suite * cfg_suite(void);
|
|
void setup_checked(void);
|
|
void teardown_checked(void);
|
|
|
|
cfg_encoder_list_t encoders;
|
|
|
|
static void
|
|
_el_cb(cfg_encoder_t enc, void *arg)
|
|
{
|
|
int *count = (int *)arg;
|
|
|
|
ck_assert_ptr_ne(cfg_encoder_get_name(enc), NULL);
|
|
(*count)++;
|
|
}
|
|
|
|
START_TEST(test_encoder_list_get)
|
|
{
|
|
cfg_encoder_t enc, enc2;
|
|
int count = 0;
|
|
|
|
ck_assert_ptr_eq(cfg_encoder_list_get(encoders, NULL), NULL);
|
|
ck_assert_ptr_eq(cfg_encoder_list_get(encoders, ""), NULL);
|
|
|
|
enc = cfg_encoder_list_get(encoders, "TeSt");
|
|
enc2 = cfg_encoder_list_get(encoders, "test");
|
|
ck_assert_ptr_eq(enc, enc2);
|
|
|
|
(void)cfg_encoder_list_get(encoders, "test2");
|
|
ck_assert_uint_eq(cfg_encoder_list_nentries(encoders), 2);
|
|
cfg_encoder_list_foreach(encoders, _el_cb, &count);
|
|
ck_assert_int_eq(count, 2);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_encoder_set_name)
|
|
{
|
|
TEST_XSTRDUP_T(cfg_encoder_t, cfg_encoder_list_get, encoders,
|
|
cfg_encoder_set_name, cfg_encoder_get_name);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_encoder_set_program)
|
|
{
|
|
TEST_XSTRDUP_T(cfg_encoder_t, cfg_encoder_list_get, encoders,
|
|
cfg_encoder_set_program, cfg_encoder_get_program);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_encoder_set_format_str)
|
|
{
|
|
cfg_encoder_t enc = cfg_encoder_list_get(encoders, "test_encoder_set_format_str");
|
|
const char *errstr;
|
|
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_set_format_str(enc, encoders, NULL,
|
|
NULL), 0);
|
|
ck_assert_int_ne(cfg_encoder_set_format_str(enc, encoders, NULL,
|
|
&errstr), 0);
|
|
ck_assert_str_eq(errstr, "empty");
|
|
ck_assert_int_ne(cfg_encoder_set_format_str(enc, encoders, "", NULL),
|
|
0);
|
|
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_set_format_str(enc, encoders, "test",
|
|
&errstr), 0);
|
|
ck_assert_str_eq(errstr, "unsupported stream format");
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_format_str(enc, encoders,
|
|
CFG_SFMT_OGG, NULL), 0);
|
|
ck_assert_int_eq(cfg_encoder_set_format_str(enc, encoders,
|
|
CFG_SFMT_MP3, NULL), 0);
|
|
ck_assert_int_eq(cfg_encoder_set_format_str(enc, encoders,
|
|
CFG_SFMT_MP3, NULL), 0);
|
|
ck_assert_int_eq(cfg_encoder_set_format_str(enc, encoders,
|
|
CFG_SFMT_MATROSKA, NULL), 0);
|
|
ck_assert_uint_eq(cfg_encoder_get_format(enc), CFG_STREAM_MATROSKA);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_encoder_validate)
|
|
{
|
|
cfg_encoder_t enc = cfg_encoder_list_get(encoders, "test_encoder_validate");
|
|
cfg_encoder_t enc2 = cfg_encoder_list_get(encoders, "test_encoder_validate_2");;
|
|
const char *errstr;
|
|
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_set_name(enc2, encoders,
|
|
"test_encoder_validate", &errstr), 0);
|
|
ck_assert_str_eq(errstr, "already exists");
|
|
|
|
ck_assert_int_ne(cfg_encoder_validate(enc, NULL), 0);
|
|
ck_assert_int_ne(cfg_encoder_validate(enc, &errstr), 0);
|
|
ck_assert_str_eq(errstr, "format not set");
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_format(enc, CFG_STREAM_OGG), 0);
|
|
|
|
ck_assert_int_ne(cfg_encoder_validate(enc, &errstr), 0);
|
|
ck_assert_str_eq(errstr, "program not set");
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, encoders, "test", NULL),
|
|
0);
|
|
ck_assert_int_eq(cfg_encoder_validate(enc, NULL), 0);
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, encoders,
|
|
PLACEHOLDER_TRACK, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_validate(enc, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"prohibited placeholder " PLACEHOLDER_TRACK);
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, encoders,
|
|
PLACEHOLDER_STRING, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_validate(enc, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"prohibited placeholder " PLACEHOLDER_STRING);
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, encoders,
|
|
PLACEHOLDER_METADATA PLACEHOLDER_METADATA, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_validate(enc, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"duplicate placeholder " PLACEHOLDER_METADATA);
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, encoders,
|
|
PLACEHOLDER_ARTIST PLACEHOLDER_ARTIST, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_validate(enc, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"duplicate placeholder " PLACEHOLDER_ARTIST);
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, encoders,
|
|
PLACEHOLDER_TITLE PLACEHOLDER_TITLE, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_validate(enc, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"duplicate placeholder " PLACEHOLDER_TITLE);
|
|
}
|
|
END_TEST
|
|
|
|
Suite *
|
|
cfg_suite(void)
|
|
{
|
|
Suite *s;
|
|
TCase *tc_encoder;
|
|
|
|
s = suite_create("Config");
|
|
|
|
tc_encoder = tcase_create("Encoder");
|
|
tcase_add_checked_fixture(tc_encoder, setup_checked,
|
|
teardown_checked);
|
|
tcase_add_test(tc_encoder, test_encoder_list_get);
|
|
tcase_add_test(tc_encoder, test_encoder_set_name);
|
|
tcase_add_test(tc_encoder, test_encoder_set_program);
|
|
tcase_add_test(tc_encoder, test_encoder_set_format_str);
|
|
tcase_add_test(tc_encoder, test_encoder_validate);
|
|
suite_add_tcase(s, tc_encoder);
|
|
|
|
return (s);
|
|
}
|
|
|
|
void
|
|
setup_checked(void)
|
|
{
|
|
if (0 < cfg_init() ||
|
|
0 < cfg_set_program_name("check_cfg_encoder", NULL) ||
|
|
0 < log_init(cfg_get_program_name()))
|
|
ck_abort_msg("setup_checked failed");
|
|
|
|
encoders = cfg_encoder_list_create();
|
|
}
|
|
|
|
void
|
|
teardown_checked(void)
|
|
{
|
|
cfg_encoder_list_destroy(&encoders);
|
|
|
|
log_exit();
|
|
cfg_exit();
|
|
}
|
|
|
|
int
|
|
main(void)
|
|
{
|
|
int num_failed;
|
|
Suite *s;
|
|
SRunner *sr;
|
|
|
|
s = cfg_suite();
|
|
sr = srunner_create(s);
|
|
|
|
srunner_run_all(sr, CK_NORMAL);
|
|
num_failed = srunner_ntests_failed(sr);
|
|
srunner_free(sr);
|
|
|
|
if (num_failed)
|
|
return (1);
|
|
return (0);
|
|
}
|