From 95672b2e7a6cc0c07306893d5bb0b80ee3570f7a Mon Sep 17 00:00:00 2001 From: Joseph Hunkeler Date: Mon, 12 Aug 2024 15:11:17 -0400 Subject: More unit tests (and fixing bugs) (#23) * Add test_artifactory.c to suite * Add test_ini_getval_wrapper to ini.c * basic ini_getval_TYPE() conversion checks * bugfix: use strtof in INIVAL_TYPE_FLOAT case * Include stdio.h to pull in FILE structure * bugfix: free data at index during strlist_set operation * Previous behavior of setting the pointer to NULL introduced a subtle memory leak * Set strlist error when index it out of range * Import private delivery functions required for mock context creation * Remove static declaration * populate_delivery_cfg() * Add test_junitxml.c * Fix duplicate define value for JUNIT_RESULT_STATE_ERROR * Add static junit test data * Copy test data to current test directory --- tests/test_ini.c | 99 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 99 insertions(+) (limited to 'tests/test_ini.c') diff --git a/tests/test_ini.c b/tests/test_ini.c index 7fb13a0..2579e21 100644 --- a/tests/test_ini.c +++ b/tests/test_ini.c @@ -95,6 +95,104 @@ void test_ini_setval_getval() { remove(filename); } +void test_ini_getval_wrappers() { + int render_mode = INI_READ_RENDER; + const char *filename = "ini_open.ini"; + const char *data = "[default]\n" + "char_01a=-1\n" + "char_01b=127\n" + "uchar_01a=0\n" + "uchar_01b=255\n" + "short_01a=-1\n" + "short_01b=1\n" + "ushort_01a=0\n" + "ushort_01b=1\n" + "int_01a=-1\n" + "int_01b=1\n" + "uint_01a=0\n" + "uint_01b=1\n" + "long_01a=-1\n" + "long_01b=1\n" + "ulong_01a=0\n" + "ulong_01b=1\n" + "llong_01a=-1\n" + "llong_01b=1\n" + "ullong_01a=0\n" + "ullong_01b=1\n" + "float_01a=-1.5\n" + "float_01b=1.5\n" + "double_01a=-1.5\n" + "double_01b=1.5\n"; + struct INIFILE *ini = NULL; + int err = 0; + + stasis_testing_write_ascii(filename, data); + ini = ini_open(filename); + STASIS_ASSERT_FATAL(ini != NULL, "could not open test data"); + + STASIS_ASSERT(ini_getval_char(ini, "default", "char_01a", render_mode, &err) == -1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: char"); + STASIS_ASSERT(ini_getval_char(ini, "default", "char_01b", render_mode, &err) == 127, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: char"); + + STASIS_ASSERT(ini_getval_uchar(ini, "default", "uchar_01a", render_mode, &err) == 0, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: uchar"); + STASIS_ASSERT(ini_getval_uchar(ini, "default", "uchar_01b", render_mode, &err) == 255, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: uchar"); + + STASIS_ASSERT(ini_getval_short(ini, "default", "short_01a", render_mode, &err) == -1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: short"); + STASIS_ASSERT(ini_getval_short(ini, "default", "short_01b", render_mode, &err) == 1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: short"); + + STASIS_ASSERT(ini_getval_ushort(ini, "default", "ushort_01a", render_mode, &err) == 0, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: ushort"); + STASIS_ASSERT(ini_getval_ushort(ini, "default", "ushort_01b", render_mode, &err) == 1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: ushort"); + + STASIS_ASSERT(ini_getval_int(ini, "default", "int_01a", render_mode, &err) == -1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: int"); + STASIS_ASSERT(ini_getval_int(ini, "default", "int_01b", render_mode, &err) == 1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: int"); + + STASIS_ASSERT(ini_getval_uint(ini, "default", "uint_01a", render_mode, &err) == 0, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: uint"); + STASIS_ASSERT(ini_getval_uint(ini, "default", "uint_01b", render_mode, &err) == 1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: uint"); + + STASIS_ASSERT(ini_getval_long(ini, "default", "long_01a", render_mode, &err) == -1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: long"); + STASIS_ASSERT(ini_getval_long(ini, "default", "long_01b", render_mode, &err) == 1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: long"); + + STASIS_ASSERT(ini_getval_ulong(ini, "default", "ulong_01a", render_mode, &err) == 0, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: ulong"); + STASIS_ASSERT(ini_getval_ulong(ini, "default", "ulong_01b", render_mode, &err) == 1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: ulong"); + + STASIS_ASSERT(ini_getval_llong(ini, "default", "llong_01a", render_mode, &err) == -1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: llong"); + STASIS_ASSERT(ini_getval_llong(ini, "default", "llong_01b", render_mode, &err) == 1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: llong"); + + STASIS_ASSERT(ini_getval_ullong(ini, "default", "ullong_01a", render_mode, &err) == 0, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: ullong"); + STASIS_ASSERT(ini_getval_ullong(ini, "default", "ullong_01b", render_mode, &err) == 1, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: ullong"); + + STASIS_ASSERT(ini_getval_float(ini, "default", "float_01a", render_mode, &err) == -1.5F, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: float"); + STASIS_ASSERT(ini_getval_float(ini, "default", "float_01b", render_mode, &err) == 1.5F, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: float"); + + STASIS_ASSERT(ini_getval_double(ini, "default", "double_01a", render_mode, &err) == -1.5L, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: double"); + STASIS_ASSERT(ini_getval_double(ini, "default", "double_01b", render_mode, &err) == 1.5L, "returned unexpected value"); + STASIS_ASSERT(err == 0, "failed to convert type: double"); + + ini_free(&ini); +} + int main(int argc, char *argv[]) { STASIS_TEST_BEGIN_MAIN(); STASIS_TEST_FUNC *tests[] = { @@ -103,6 +201,7 @@ int main(int argc, char *argv[]) { test_ini_section_search, test_ini_has_key, test_ini_setval_getval, + test_ini_getval_wrappers, }; STASIS_TEST_RUN(tests); STASIS_TEST_END_MAIN(); -- cgit