mirror of
https://gitlab.xiph.org/xiph/ezstream.git
synced 2025-01-03 14:56:35 -05:00
925 lines
25 KiB
C
925 lines
25 KiB
C
#include <check.h>
|
|
#include <limits.h>
|
|
#include <netdb.h>
|
|
|
|
#include "cfg_private.h"
|
|
#include "log.h"
|
|
|
|
#define TEST_EMPTYSTR(s, g) do { \
|
|
const char *errstr; \
|
|
\
|
|
errstr = NULL; \
|
|
ck_assert_int_eq(s(NULL, &errstr), -1); \
|
|
ck_assert_str_eq(errstr, "empty"); \
|
|
\
|
|
errstr = NULL; \
|
|
ck_assert_int_eq(s("", &errstr), -1); \
|
|
ck_assert_str_eq(errstr, "empty"); \
|
|
\
|
|
} while (0)
|
|
|
|
#define TEST_XSTRDUP(s, g) do { \
|
|
TEST_EMPTYSTR(s, g); \
|
|
\
|
|
ck_assert_int_eq(s("check_cfg", NULL), 0); \
|
|
ck_assert_str_eq(g(), "check_cfg"); \
|
|
} while (0)
|
|
|
|
#define TEST_STRLCPY(s, g, l) do { \
|
|
char buf[l + 1]; \
|
|
const char *errstr2; \
|
|
\
|
|
TEST_XSTRDUP(s, g); \
|
|
\
|
|
errstr2 = NULL; \
|
|
memset(buf, 'A', sizeof(buf) - 1); \
|
|
buf[sizeof(buf) - 1] = '\0'; \
|
|
ck_assert_int_eq(s(buf, &errstr2), -1); \
|
|
ck_assert_ptr_ne(errstr2, NULL); \
|
|
} while (0)
|
|
|
|
#define TEST_BOOLEAN(s, g) do { \
|
|
const char *errstr2; \
|
|
\
|
|
TEST_EMPTYSTR(s, g); \
|
|
\
|
|
errstr2 = NULL; \
|
|
ck_assert_int_eq(s("BOGUS", &errstr2), -1); \
|
|
ck_assert_str_eq(errstr2, "invalid"); \
|
|
\
|
|
ck_assert_int_eq(s("tRuE", NULL), 0); \
|
|
ck_assert_int_eq(g(), 1); \
|
|
ck_assert_int_eq(s("YeS", NULL), 0); \
|
|
ck_assert_int_eq(g(), 1); \
|
|
ck_assert_int_eq(s("1", NULL), 0); \
|
|
ck_assert_int_eq(g(), 1); \
|
|
\
|
|
ck_assert_int_eq(s("FaLsE", NULL), 0); \
|
|
ck_assert_int_eq(g(), 0); \
|
|
ck_assert_int_eq(s("nO", NULL), 0); \
|
|
ck_assert_int_eq(g(), 0); \
|
|
ck_assert_int_eq(s("0", NULL), 0); \
|
|
ck_assert_int_eq(g(), 0); \
|
|
} while (0)
|
|
|
|
#define TEST_UINTNUM(s, g) do { \
|
|
const char *errstr2; \
|
|
\
|
|
TEST_EMPTYSTR(s, g); \
|
|
\
|
|
errstr2 = NULL; \
|
|
ck_assert_int_eq(s("-1", &errstr2), -1); \
|
|
ck_assert_ptr_ne(errstr2, NULL); \
|
|
\
|
|
errstr2 = NULL; \
|
|
ck_assert_int_eq(s("4294967296", &errstr2), -1); \
|
|
ck_assert_ptr_ne(errstr2, NULL); \
|
|
\
|
|
ck_assert_int_eq(s("20", NULL), 0); \
|
|
ck_assert_uint_eq(g(), 20); \
|
|
} while (0)
|
|
|
|
#define TEST_INTNUM(s, g) do { \
|
|
const char *errstr2; \
|
|
\
|
|
TEST_EMPTYSTR(s, g); \
|
|
\
|
|
errstr2 = NULL; \
|
|
ck_assert_int_eq(s("-2147483649", &errstr2), -1); \
|
|
ck_assert_ptr_ne(errstr2, NULL); \
|
|
\
|
|
errstr2 = NULL; \
|
|
ck_assert_int_eq(s("2147483648", &errstr2), -1); \
|
|
ck_assert_ptr_ne(errstr2, NULL); \
|
|
\
|
|
ck_assert_int_eq(s("20", NULL), 0); \
|
|
ck_assert_int_eq(g(), 20); \
|
|
} while (0)
|
|
|
|
Suite * cfg_suite(void);
|
|
void setup_checked(void);
|
|
void teardown_checked(void);
|
|
|
|
START_TEST(test_stash)
|
|
{
|
|
ck_assert_ptr_eq(cfg_get_stream_name(), NULL);
|
|
ck_assert_int_eq(cfg_set_stream_name("test_stash", NULL), 0);
|
|
ck_assert_str_eq(cfg_get_stream_name(), "test_stash");
|
|
cfg_save();
|
|
ck_assert_int_eq(cfg_set_stream_name("test_stash2", NULL), 0);
|
|
ck_assert_str_eq(cfg_get_stream_name(), "test_stash2");
|
|
cfg_restore();
|
|
ck_assert_str_eq(cfg_get_stream_name(), "test_stash");
|
|
cfg_restore();
|
|
ck_assert_str_eq(cfg_get_stream_name(), "test_stash");
|
|
cfg_save();
|
|
cfg_clear();
|
|
cfg_restore();
|
|
ck_assert_str_eq(cfg_get_stream_name(), "test_stash");
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_check)
|
|
{
|
|
const char *errstr = NULL;
|
|
|
|
ck_assert_int_eq(cfg_check(NULL), -1);
|
|
ck_assert_int_eq(cfg_check(&errstr), -1);
|
|
ck_assert_str_eq(errstr, "server hostname missing");
|
|
ck_assert_int_eq(cfg_set_server_hostname("localhost", NULL), 0);
|
|
|
|
ck_assert_int_eq(cfg_check(NULL), -1);
|
|
ck_assert_int_eq(cfg_check(&errstr), -1);
|
|
ck_assert_str_eq(errstr, "server password missing");
|
|
ck_assert_int_eq(cfg_set_server_password("secret", NULL), 0);
|
|
|
|
ck_assert_int_eq(cfg_check(NULL), -1);
|
|
ck_assert_int_eq(cfg_check(&errstr), -1);
|
|
ck_assert_str_eq(errstr, "media filename missing");
|
|
ck_assert_int_eq(cfg_set_media_filename(SRCDIR "/playlist.txt", NULL),
|
|
0);
|
|
|
|
ck_assert_int_eq(cfg_check(NULL), -1);
|
|
ck_assert_int_eq(cfg_check(&errstr), -1);
|
|
ck_assert_str_eq(errstr, "stream format missing or unsupported");
|
|
ck_assert_int_eq(cfg_set_stream_format(CFG_SFMT_VORBIS, NULL), 0);
|
|
|
|
ck_assert_int_eq(cfg_check(NULL), 0);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_str2fmt)
|
|
{
|
|
enum cfg_stream_format fmt;
|
|
|
|
ck_assert_int_eq(cfg_stream_str2fmt(CFG_SFMT_VORBIS, &fmt), 0);
|
|
ck_assert_int_eq(fmt, CFG_STREAM_VORBIS);
|
|
ck_assert_int_eq(cfg_stream_str2fmt(CFG_SFMT_MP3, &fmt), 0);
|
|
ck_assert_int_eq(fmt, CFG_STREAM_MP3);
|
|
ck_assert_int_eq(cfg_stream_str2fmt(CFG_SFMT_THEORA, &fmt), 0);
|
|
ck_assert_int_eq(fmt, CFG_STREAM_THEORA);
|
|
ck_assert_int_eq(cfg_stream_str2fmt("<something else>", &fmt), -1);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_fmt2str)
|
|
{
|
|
ck_assert_str_eq(cfg_stream_fmt2str(CFG_STREAM_VORBIS),
|
|
CFG_SFMT_VORBIS);
|
|
ck_assert_str_eq(cfg_stream_fmt2str(CFG_STREAM_MP3),
|
|
CFG_SFMT_MP3);
|
|
ck_assert_str_eq(cfg_stream_fmt2str(CFG_STREAM_THEORA),
|
|
CFG_SFMT_THEORA);
|
|
ck_assert_ptr_eq(cfg_stream_fmt2str(CFG_STREAM_INVALID), NULL);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_file_check)
|
|
{
|
|
ck_assert_int_eq(cfg_file_check(""), -1);
|
|
ck_assert_int_eq(cfg_file_check(SRCDIR "/check_cfg.c"), 0);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_program_name)
|
|
{
|
|
TEST_STRLCPY(cfg_set_program_name, cfg_get_program_name, PATH_MAX);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_program_config_type)
|
|
{
|
|
const char *errstr = NULL;
|
|
|
|
ck_assert_int_eq(cfg_set_program_config_type(-2, &errstr), -1);
|
|
ck_assert_str_eq(errstr, "invalid");
|
|
ck_assert_int_eq(cfg_set_program_config_type(CFG_TYPE_XMLFILE, NULL),
|
|
0);
|
|
ck_assert_int_eq(cfg_get_program_config_type(), CFG_TYPE_XMLFILE);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_program_config_file)
|
|
{
|
|
ck_assert_ptr_eq(cfg_get_program_config_file(), NULL);
|
|
TEST_STRLCPY(cfg_set_program_config_file, cfg_get_program_config_file,
|
|
PATH_MAX);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_program_quiet_stderr)
|
|
{
|
|
ck_assert_int_eq(cfg_set_program_quiet_stderr(-1, NULL), 0);
|
|
ck_assert_int_ne(cfg_get_program_quiet_stderr(), 0);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_program_rtstatus_output)
|
|
{
|
|
ck_assert_int_eq(cfg_set_program_rtstatus_output(-1, NULL), 0);
|
|
ck_assert_int_ne(cfg_get_program_rtstatus_output(), 0);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_program_verbosity)
|
|
{
|
|
ck_assert_int_eq(cfg_set_program_verbosity(2000, NULL), 0);
|
|
ck_assert_int_eq(cfg_get_program_verbosity(), 2000);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_protocol)
|
|
{
|
|
const char *errstr2;
|
|
|
|
TEST_EMPTYSTR(cfg_set_server_protocol, cfg_get_server_protocol);
|
|
|
|
errstr2 = NULL;
|
|
ck_assert_int_eq(cfg_set_server_protocol("invalid", &errstr2), -1);
|
|
ck_assert_str_eq(errstr2, "unsupported");
|
|
|
|
ck_assert_int_eq(cfg_set_server_protocol("hTtP", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_server_protocol(), CFG_PROTO_HTTP);
|
|
ck_assert_str_eq(cfg_get_server_protocol_str(), "http");
|
|
ck_assert_int_eq(cfg_set_server_protocol("HtTpS", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_server_protocol(), CFG_PROTO_HTTPS);
|
|
ck_assert_str_eq(cfg_get_server_protocol_str(), "https");
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_hostname)
|
|
{
|
|
TEST_STRLCPY(cfg_set_server_hostname, cfg_get_server_hostname,
|
|
NI_MAXHOST);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_port)
|
|
{
|
|
const char *errstr2;
|
|
|
|
ck_assert_uint_eq(cfg_get_server_port(), DEFAULT_PORT);
|
|
|
|
TEST_EMPTYSTR(cfg_set_server_port, cfg_get_server_port);
|
|
|
|
errstr2 = NULL;
|
|
ck_assert_int_eq(cfg_set_server_port("0", &errstr2), -1);
|
|
ck_assert_ptr_ne(errstr2, NULL);
|
|
|
|
errstr2 = NULL;
|
|
ck_assert_int_eq(cfg_set_server_port("65536", &errstr2), -1);
|
|
ck_assert_ptr_ne(errstr2, NULL);
|
|
|
|
ck_assert_int_eq(cfg_set_server_port("8008", NULL), 0);
|
|
ck_assert_uint_eq(cfg_get_server_port(), 8008);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_user)
|
|
{
|
|
ck_assert_str_eq(cfg_get_server_user(), DEFAULT_USER);
|
|
TEST_STRLCPY(cfg_set_server_user, cfg_get_server_user, UCREDS_SIZE);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_password)
|
|
{
|
|
TEST_STRLCPY(cfg_set_server_password, cfg_get_server_password,
|
|
UCREDS_SIZE);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_ca_dir)
|
|
{
|
|
TEST_STRLCPY(cfg_set_server_ca_dir, cfg_get_server_ca_dir, PATH_MAX);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_tls)
|
|
{
|
|
const char *errstr = NULL;
|
|
|
|
ck_assert_int_eq(cfg_set_server_tls("", &errstr), -1);
|
|
ck_assert_str_eq(errstr, "empty");
|
|
ck_assert_int_eq(cfg_set_server_tls("test", &errstr), -1);
|
|
ck_assert_str_eq(errstr, "invalid");
|
|
ck_assert_int_eq(cfg_get_server_tls(), CFG_TLS_MAY);
|
|
ck_assert_int_eq(cfg_set_server_tls("None", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_server_tls(), CFG_TLS_NONE);
|
|
ck_assert_int_eq(cfg_set_server_tls("Required", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_server_tls(), CFG_TLS_REQUIRED);
|
|
ck_assert_int_eq(cfg_set_server_tls("May", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_server_tls(), CFG_TLS_MAY);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_tls_cipher_suite)
|
|
{
|
|
TEST_STRLCPY(cfg_set_server_tls_cipher_suite,
|
|
cfg_get_server_tls_cipher_suite, CSUITE_SIZE);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_ca_file)
|
|
{
|
|
TEST_STRLCPY(cfg_set_server_ca_file, cfg_get_server_ca_file, PATH_MAX);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_client_cert)
|
|
{
|
|
TEST_STRLCPY(cfg_set_server_client_cert, cfg_get_server_client_cert,
|
|
PATH_MAX);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_server_reconnect_attempts)
|
|
{
|
|
TEST_UINTNUM(cfg_set_server_reconnect_attempts,
|
|
cfg_get_server_reconnect_attempts);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_mountpoint)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_mountpoint, cfg_get_stream_mountpoint);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_name)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_name, cfg_get_stream_name);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_url)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_url, cfg_get_stream_url);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_genre)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_genre, cfg_get_stream_genre);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_description)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_description, cfg_get_stream_description);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_quality)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_quality, cfg_get_stream_quality);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_bitrate)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_bitrate, cfg_get_stream_bitrate);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_samplerate)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_samplerate, cfg_get_stream_samplerate);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_channels)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_channels, cfg_get_stream_channels);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_server_public)
|
|
{
|
|
TEST_BOOLEAN(cfg_set_stream_server_public,
|
|
cfg_get_stream_server_public);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_format)
|
|
{
|
|
const char *errstr2;
|
|
|
|
TEST_EMPTYSTR(cfg_set_stream_format, cfg_get_stream_format);
|
|
|
|
ck_assert_int_eq(cfg_set_stream_format("<something else>", &errstr2),
|
|
-1);
|
|
ck_assert_str_eq(errstr2, "unsupported stream format");
|
|
|
|
ck_assert_int_eq(cfg_set_stream_format(CFG_SFMT_VORBIS, NULL), 0);
|
|
ck_assert_int_eq(cfg_get_stream_format(), CFG_STREAM_VORBIS);
|
|
ck_assert_str_eq(cfg_get_stream_format_str(),
|
|
cfg_stream_fmt2str(CFG_STREAM_VORBIS));
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_stream_encoder)
|
|
{
|
|
TEST_XSTRDUP(cfg_set_stream_encoder, cfg_get_stream_encoder);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_media_type)
|
|
{
|
|
const char *errstr2;
|
|
|
|
TEST_EMPTYSTR(cfg_set_media_type, cfg_get_media_type);
|
|
|
|
ck_assert_int_eq(cfg_set_media_type("<something else>", &errstr2), -1);
|
|
ck_assert_str_eq(errstr2, "unsupported");
|
|
|
|
ck_assert_int_eq(cfg_set_media_type("aUtOdEtEcT", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_media_type(), CFG_MEDIA_AUTODETECT);
|
|
ck_assert_int_eq(cfg_set_media_type("FiLe", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_media_type(), CFG_MEDIA_FILE);
|
|
ck_assert_int_eq(cfg_set_media_type("pLaYlIsT", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_media_type(), CFG_MEDIA_PLAYLIST);
|
|
ck_assert_int_eq(cfg_set_media_type("PrOgRaM", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_media_type(), CFG_MEDIA_PROGRAM);
|
|
ck_assert_int_eq(cfg_set_media_type("sTdIn", NULL), 0);
|
|
ck_assert_int_eq(cfg_get_media_type(), CFG_MEDIA_STDIN);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_media_filename)
|
|
{
|
|
TEST_STRLCPY(cfg_set_media_filename, cfg_get_media_filename, PATH_MAX);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_media_shuffle)
|
|
{
|
|
TEST_BOOLEAN(cfg_set_media_shuffle, cfg_get_media_shuffle);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_media_stream_once)
|
|
{
|
|
TEST_BOOLEAN(cfg_set_media_stream_once, cfg_get_media_stream_once);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_metadata_program)
|
|
{
|
|
ck_assert_ptr_eq(cfg_get_metadata_program(), NULL);
|
|
TEST_STRLCPY(cfg_set_metadata_program, cfg_get_metadata_program,
|
|
PATH_MAX);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_metadata_format_str)
|
|
{
|
|
const char *errstr2;
|
|
|
|
TEST_XSTRDUP(cfg_set_metadata_format_str,
|
|
cfg_get_metadata_format_str);
|
|
|
|
ck_assert_int_eq(cfg_set_metadata_format_str("test", NULL), 0);
|
|
|
|
errstr2 = NULL;
|
|
ck_assert_int_eq(cfg_set_metadata_format_str(PLACEHOLDER_METADATA,
|
|
&errstr2), -1);
|
|
ck_assert_str_eq(errstr2,
|
|
"prohibited placeholder " PLACEHOLDER_METADATA);
|
|
|
|
errstr2 = NULL;
|
|
ck_assert_int_eq(cfg_set_metadata_format_str(
|
|
PLACEHOLDER_TRACK PLACEHOLDER_TRACK, &errstr2), -1);
|
|
ck_assert_str_eq(errstr2, "duplicate placeholder " PLACEHOLDER_TRACK);
|
|
|
|
errstr2 = NULL;
|
|
ck_assert_int_eq(cfg_set_metadata_format_str(
|
|
PLACEHOLDER_STRING PLACEHOLDER_STRING, &errstr2), -1);
|
|
ck_assert_str_eq(errstr2, "duplicate placeholder " PLACEHOLDER_STRING);
|
|
|
|
errstr2 = NULL;
|
|
ck_assert_int_eq(cfg_set_metadata_format_str(
|
|
PLACEHOLDER_ARTIST PLACEHOLDER_ARTIST, &errstr2), -1);
|
|
ck_assert_str_eq(errstr2, "duplicate placeholder " PLACEHOLDER_ARTIST);
|
|
|
|
errstr2 = NULL;
|
|
ck_assert_int_eq(cfg_set_metadata_format_str(
|
|
PLACEHOLDER_TITLE PLACEHOLDER_TITLE, &errstr2), -1);
|
|
ck_assert_str_eq(errstr2, "duplicate placeholder " PLACEHOLDER_TITLE);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_metadata_refresh_interval)
|
|
{
|
|
ck_assert_int_eq(cfg_get_metadata_refresh_interval(), -1);
|
|
|
|
TEST_INTNUM(cfg_set_metadata_refresh_interval,
|
|
cfg_get_metadata_refresh_interval);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_metadata_normalize_strings)
|
|
{
|
|
TEST_BOOLEAN(cfg_set_metadata_normalize_strings,
|
|
cfg_get_metadata_normalize_strings);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_metadata_no_updates)
|
|
{
|
|
TEST_BOOLEAN(cfg_set_metadata_no_updates,
|
|
cfg_get_metadata_no_updates);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_decoder_get)
|
|
{
|
|
cfg_decoder_t dec, dec2;
|
|
|
|
ck_assert_ptr_eq(cfg_decoder_get(NULL), NULL);
|
|
ck_assert_ptr_eq(cfg_decoder_get(""), NULL);
|
|
|
|
dec = cfg_decoder_get("TeSt");
|
|
dec2 = cfg_decoder_get("test");
|
|
ck_assert_ptr_eq(dec, dec2);
|
|
}
|
|
END_TEST
|
|
|
|
#define TEST_DEC_XSTRDUP(s, g) do { \
|
|
cfg_decoder_t dec = cfg_decoder_get(#s); \
|
|
const char *errstr; \
|
|
\
|
|
errstr = NULL; \
|
|
ck_assert_int_ne(s(dec, NULL, &errstr), 0); \
|
|
ck_assert_str_eq(errstr, "empty"); \
|
|
ck_assert_int_ne(s(dec, "", NULL), 0); \
|
|
\
|
|
ck_assert_int_eq(s(dec, "test", NULL), 0); \
|
|
ck_assert_str_eq(g(dec), "test"); \
|
|
\
|
|
ck_assert_int_eq(s(dec, #s, NULL), 0); \
|
|
ck_assert_str_eq(g(dec), #s); \
|
|
} while (0)
|
|
|
|
START_TEST(test_decoder_set_name)
|
|
{
|
|
TEST_DEC_XSTRDUP(cfg_decoder_set_name, cfg_decoder_get_name);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_decoder_set_program)
|
|
{
|
|
TEST_DEC_XSTRDUP(cfg_decoder_set_program, cfg_decoder_get_program);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_decoder_add_match)
|
|
{
|
|
cfg_decoder_t dec = cfg_decoder_get("test_decoder_add_match");
|
|
cfg_decoder_t dec2 = cfg_decoder_get("test_decoder_add_match_2");
|
|
const char *errstr;
|
|
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_decoder_add_match(dec, NULL, &errstr), 0);
|
|
ck_assert_str_eq(errstr, "empty");
|
|
ck_assert_int_ne(cfg_decoder_add_match(dec, "", NULL), 0);
|
|
|
|
ck_assert_int_eq(cfg_decoder_add_match(dec, ".test", NULL), 0);
|
|
ck_assert_int_eq(cfg_decoder_add_match(dec, ".test2", NULL), 0);
|
|
ck_assert_ptr_eq(cfg_decoder_find(".test"), dec);
|
|
ck_assert_ptr_eq(cfg_decoder_find(".test2"), dec);
|
|
|
|
ck_assert_int_eq(cfg_decoder_add_match(dec2, ".test2", NULL), 0);
|
|
ck_assert_ptr_eq(cfg_decoder_find(".test"), dec);
|
|
ck_assert_ptr_eq(cfg_decoder_find(".test2"), dec2);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_decoder_validate)
|
|
{
|
|
cfg_decoder_t dec = cfg_decoder_get("test_decoder_validate");
|
|
const char *errstr;
|
|
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_decoder_validate(dec, &errstr), 0);
|
|
ck_assert_str_eq(errstr, "program not set");
|
|
|
|
ck_assert_int_eq(cfg_decoder_set_program(dec, "test", NULL), 0);
|
|
ck_assert_int_ne(cfg_decoder_validate(dec, &errstr), 0);
|
|
ck_assert_str_eq(errstr, "no file extensions registered");
|
|
|
|
ck_assert_int_eq(cfg_decoder_add_match(dec, ".test", NULL), 0);
|
|
|
|
ck_assert_int_eq(cfg_decoder_set_program(dec, PLACEHOLDER_STRING,
|
|
NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_decoder_validate(dec, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"prohibited placeholder " PLACEHOLDER_STRING);
|
|
|
|
ck_assert_int_eq(cfg_decoder_set_program(dec,
|
|
PLACEHOLDER_TRACK PLACEHOLDER_TRACK, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_decoder_validate(dec, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"duplicate placeholder " PLACEHOLDER_TRACK);
|
|
|
|
ck_assert_int_eq(cfg_decoder_set_program(dec,
|
|
PLACEHOLDER_METADATA PLACEHOLDER_METADATA, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_decoder_validate(dec, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"duplicate placeholder " PLACEHOLDER_METADATA);
|
|
|
|
ck_assert_int_eq(cfg_decoder_set_program(dec,
|
|
PLACEHOLDER_ARTIST PLACEHOLDER_ARTIST, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_decoder_validate(dec, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"duplicate placeholder " PLACEHOLDER_ARTIST);
|
|
|
|
ck_assert_int_eq(cfg_decoder_set_program(dec,
|
|
PLACEHOLDER_TITLE PLACEHOLDER_TITLE, NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_decoder_validate(dec, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"duplicate placeholder " PLACEHOLDER_TITLE);
|
|
|
|
ck_assert_int_eq(cfg_decoder_set_program(dec, "test", NULL), 0);
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_decoder_validate(dec, &errstr), 0);
|
|
ck_assert_str_eq(errstr,
|
|
"missing placeholder " PLACEHOLDER_TRACK);
|
|
|
|
ck_assert_int_eq(cfg_decoder_set_program(dec, PLACEHOLDER_TRACK, NULL),
|
|
0);
|
|
ck_assert_int_eq(cfg_decoder_validate(dec, &errstr), 0);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_encoder_get)
|
|
{
|
|
cfg_encoder_t enc, enc2;
|
|
|
|
ck_assert_ptr_eq(cfg_encoder_get(NULL), NULL);
|
|
ck_assert_ptr_eq(cfg_encoder_get(""), NULL);
|
|
|
|
enc = cfg_encoder_get("TeSt");
|
|
enc2 = cfg_encoder_get("test");
|
|
ck_assert_ptr_eq(enc, enc2);
|
|
}
|
|
END_TEST
|
|
|
|
#define TEST_ENC_XSTRDUP(s, g) do { \
|
|
cfg_encoder_t enc = cfg_encoder_get(#s); \
|
|
const char *errstr; \
|
|
\
|
|
errstr = NULL; \
|
|
ck_assert_int_ne(s(enc, NULL, &errstr), 0); \
|
|
ck_assert_str_eq(errstr, "empty"); \
|
|
ck_assert_int_ne(s(enc, "", NULL), 0); \
|
|
\
|
|
ck_assert_int_eq(s(enc, "test", NULL), 0); \
|
|
ck_assert_str_eq(g(enc), "test"); \
|
|
\
|
|
ck_assert_int_eq(s(enc, #s, NULL), 0); \
|
|
ck_assert_str_eq(g(enc), #s); \
|
|
} while (0)
|
|
|
|
START_TEST(test_encoder_set_name)
|
|
{
|
|
TEST_ENC_XSTRDUP(cfg_encoder_set_name, cfg_encoder_get_name);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_encoder_set_program)
|
|
{
|
|
cfg_encoder_t enc = cfg_encoder_get("test_encoder_set_program");
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, NULL, NULL), 0);
|
|
ck_assert_ptr_eq(cfg_encoder_get_program(enc), NULL);
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, "test", NULL), 0);
|
|
ck_assert_str_eq(cfg_encoder_get_program(enc), "test");
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_encoder_set_format_str)
|
|
{
|
|
cfg_encoder_t enc = cfg_encoder_get("test_encoder_set_format_str");
|
|
const char *errstr;
|
|
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_set_format_str(enc, NULL, &errstr), 0);
|
|
ck_assert_str_eq(errstr, "empty");
|
|
ck_assert_int_ne(cfg_encoder_set_format_str(enc, "", NULL), 0);
|
|
|
|
errstr = NULL;
|
|
ck_assert_int_ne(cfg_encoder_set_format_str(enc, "test", &errstr), 0);
|
|
ck_assert_str_eq(errstr, "unsupported stream format");
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_format_str(enc, CFG_SFMT_VORBIS,
|
|
NULL), 0);
|
|
ck_assert_int_eq(cfg_encoder_set_format_str(enc, CFG_SFMT_MP3,
|
|
NULL), 0);
|
|
ck_assert_int_eq(cfg_encoder_set_format_str(enc, CFG_SFMT_THEORA,
|
|
NULL), 0);
|
|
ck_assert_uint_eq(cfg_encoder_get_format(enc), CFG_STREAM_THEORA);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_encoder_validate)
|
|
{
|
|
cfg_encoder_t enc = cfg_encoder_get("test_encoder_validate");
|
|
const char *errstr;
|
|
|
|
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_VORBIS, NULL),
|
|
0);
|
|
|
|
ck_assert_int_eq(cfg_encoder_validate(enc, NULL), 0);
|
|
|
|
ck_assert_int_eq(cfg_encoder_set_program(enc, 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, 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,
|
|
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,
|
|
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,
|
|
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_core;
|
|
TCase *tc_program;
|
|
TCase *tc_server;
|
|
TCase *tc_stream;
|
|
TCase *tc_media;
|
|
TCase *tc_metadata;
|
|
TCase *tc_decoder;
|
|
TCase *tc_encoder;
|
|
|
|
s = suite_create("Config");
|
|
|
|
tc_core = tcase_create("Core");
|
|
tcase_add_checked_fixture(tc_core, setup_checked, teardown_checked);
|
|
tcase_add_test(tc_core, test_stash);
|
|
tcase_add_test(tc_core, test_check);
|
|
tcase_add_test(tc_core, test_stream_str2fmt);
|
|
tcase_add_test(tc_core, test_stream_fmt2str);
|
|
tcase_add_test(tc_core, test_file_check);
|
|
suite_add_tcase(s, tc_core);
|
|
|
|
tc_program = tcase_create("Program");
|
|
tcase_add_checked_fixture(tc_program, setup_checked,
|
|
teardown_checked);
|
|
tcase_add_test(tc_program, test_program_name);
|
|
tcase_add_test(tc_program, test_program_config_type);
|
|
tcase_add_test(tc_program, test_program_config_file);
|
|
tcase_add_test(tc_program, test_program_quiet_stderr);
|
|
tcase_add_test(tc_program, test_program_rtstatus_output);
|
|
tcase_add_test(tc_program, test_program_verbosity);
|
|
suite_add_tcase(s, tc_program);
|
|
|
|
tc_server = tcase_create("Server");
|
|
tcase_add_checked_fixture(tc_server, setup_checked, teardown_checked);
|
|
tcase_add_test(tc_server, test_server_protocol);
|
|
tcase_add_test(tc_server, test_server_hostname);
|
|
tcase_add_test(tc_server, test_server_port);
|
|
tcase_add_test(tc_server, test_server_user);
|
|
tcase_add_test(tc_server, test_server_password);
|
|
tcase_add_test(tc_server, test_server_tls);
|
|
tcase_add_test(tc_server, test_server_tls_cipher_suite);
|
|
tcase_add_test(tc_server, test_server_ca_dir);
|
|
tcase_add_test(tc_server, test_server_ca_file);
|
|
tcase_add_test(tc_server, test_server_client_cert);
|
|
tcase_add_test(tc_server, test_server_reconnect_attempts);
|
|
suite_add_tcase(s, tc_server);
|
|
|
|
tc_stream = tcase_create("Stream");
|
|
tcase_add_checked_fixture(tc_stream, setup_checked, teardown_checked);
|
|
tcase_add_test(tc_stream, test_stream_mountpoint);
|
|
tcase_add_test(tc_stream, test_stream_name);
|
|
tcase_add_test(tc_stream, test_stream_url);
|
|
tcase_add_test(tc_stream, test_stream_genre);
|
|
tcase_add_test(tc_stream, test_stream_description);
|
|
tcase_add_test(tc_stream, test_stream_quality);
|
|
tcase_add_test(tc_stream, test_stream_bitrate);
|
|
tcase_add_test(tc_stream, test_stream_samplerate);
|
|
tcase_add_test(tc_stream, test_stream_channels);
|
|
tcase_add_test(tc_stream, test_stream_server_public);
|
|
tcase_add_test(tc_stream, test_stream_format);
|
|
tcase_add_test(tc_stream, test_stream_encoder);
|
|
suite_add_tcase(s, tc_stream);
|
|
|
|
tc_media = tcase_create("Media");
|
|
tcase_add_checked_fixture(tc_media, setup_checked, teardown_checked);
|
|
tcase_add_test(tc_media, test_media_type);
|
|
tcase_add_test(tc_media, test_media_filename);
|
|
tcase_add_test(tc_media, test_media_shuffle);
|
|
tcase_add_test(tc_media, test_media_stream_once);
|
|
suite_add_tcase(s, tc_media);
|
|
|
|
tc_metadata = tcase_create("Metadata");
|
|
tcase_add_checked_fixture(tc_metadata, setup_checked,
|
|
teardown_checked);
|
|
tcase_add_test(tc_metadata, test_metadata_program);
|
|
tcase_add_test(tc_metadata, test_metadata_format_str);
|
|
tcase_add_test(tc_metadata, test_metadata_refresh_interval);
|
|
tcase_add_test(tc_metadata, test_metadata_normalize_strings);
|
|
tcase_add_test(tc_metadata, test_metadata_no_updates);
|
|
suite_add_tcase(s, tc_metadata);
|
|
|
|
tc_decoder = tcase_create("Decoder");
|
|
tcase_add_checked_fixture(tc_decoder, setup_checked,
|
|
teardown_checked);
|
|
tcase_add_test(tc_decoder, test_decoder_get);
|
|
tcase_add_test(tc_decoder, test_decoder_set_name);
|
|
tcase_add_test(tc_decoder, test_decoder_set_program);
|
|
tcase_add_test(tc_decoder, test_decoder_add_match);
|
|
tcase_add_test(tc_decoder, test_decoder_validate);
|
|
suite_add_tcase(s, tc_decoder);
|
|
|
|
tc_encoder = tcase_create("Encoder");
|
|
tcase_add_checked_fixture(tc_encoder, setup_checked,
|
|
teardown_checked);
|
|
tcase_add_test(tc_encoder, test_encoder_get);
|
|
tcase_add_test(tc_decoder, test_encoder_set_name);
|
|
tcase_add_test(tc_decoder, test_encoder_set_program);
|
|
tcase_add_test(tc_decoder, test_encoder_set_format_str);
|
|
tcase_add_test(tc_decoder, test_encoder_validate);
|
|
suite_add_tcase(s, tc_encoder);
|
|
|
|
return (s);
|
|
}
|
|
|
|
void
|
|
setup_checked(void)
|
|
{
|
|
if (0 < cfg_init() ||
|
|
0 < cfg_decoder_init() ||
|
|
0 < cfg_encoder_init() ||
|
|
0 < log_init())
|
|
ck_abort_msg("setup_checked failed");
|
|
}
|
|
|
|
void
|
|
teardown_checked(void)
|
|
{
|
|
log_exit();
|
|
cfg_encoder_exit();
|
|
cfg_decoder_exit();
|
|
cfg_exit();
|
|
}
|
|
|
|
int
|
|
main(void)
|
|
{
|
|
unsigned 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);
|
|
}
|