mirror of
https://github.com/thepigeongenerator/mcaselector-lite.git
synced 2025-12-17 07:35:45 +01:00
expand integer config tests
This commit is contained in:
11
test/dat.h
11
test/dat.h
@@ -16,7 +16,7 @@ testdat tests[] = {
|
|||||||
{"", test_bswap32_impl, (uint32_t[]){0x1142ADEE, 0xEEAD4211} },
|
{"", test_bswap32_impl, (uint32_t[]){0x1142ADEE, 0xEEAD4211} },
|
||||||
{"", test_bswap64_impl, (uint64_t[]){0x114266897799ADEE, 0xEEAD997789664211} },
|
{"", test_bswap64_impl, (uint64_t[]){0x114266897799ADEE, 0xEEAD997789664211} },
|
||||||
{"k=v", test_procbuf, &(struct test_procbuf){"key=val", "key", "val", 0} },
|
{"k=v", test_procbuf, &(struct test_procbuf){"key=val", "key", "val", 0} },
|
||||||
{"sometxt", test_procbuf, &(struct test_procbuf){"sometxt", "sometxt", "", CONF_ESYNTAX}},
|
{"sometxt", test_procbuf, &(struct test_procbuf){"sometxt", "sometxt", "", CONF_ESYNTAX} },
|
||||||
{"comment", test_procbuf, &(struct test_procbuf){"# comment", "", "", CONF_ENODAT} },
|
{"comment", test_procbuf, &(struct test_procbuf){"# comment", "", "", CONF_ENODAT} },
|
||||||
{"empty", test_procbuf, &(struct test_procbuf){"", "", "", CONF_ENODAT} },
|
{"empty", test_procbuf, &(struct test_procbuf){"", "", "", CONF_ENODAT} },
|
||||||
{"LF", test_procbuf, &(struct test_procbuf){"\n", "", "", CONF_ENODAT} },
|
{"LF", test_procbuf, &(struct test_procbuf){"\n", "", "", CONF_ENODAT} },
|
||||||
@@ -25,9 +25,12 @@ testdat tests[] = {
|
|||||||
{"k=v (CRLF)", test_procbuf, &(struct test_procbuf){"k=v\r\na", "k", "v", 0} },
|
{"k=v (CRLF)", test_procbuf, &(struct test_procbuf){"k=v\r\na", "k", "v", 0} },
|
||||||
{"get", test_matchopt, &(struct test_matchopt){"key3", 2} },
|
{"get", test_matchopt, &(struct test_matchopt){"key3", 2} },
|
||||||
{"invalid", test_matchopt, &(struct test_matchopt){"nono", -1} },
|
{"invalid", test_matchopt, &(struct test_matchopt){"nono", -1} },
|
||||||
{"", test_colour32_endianess, NULL },
|
{"", test_colour32_endianess, NULL }, // NOTE: formatter is fucking with alignment making it use tabs @.@
|
||||||
{"", test_procval_i32, NULL },
|
{"i32", test_procval_int, &(struct test_procval_int){"42", 42, CONF_I32} },
|
||||||
{"", test_procval_u64, NULL },
|
{"i32_neg", test_procval_int, &(struct test_procval_int){"-42", (uint32_t)-42, CONF_I32} },
|
||||||
|
{"u32_max", test_procval_int, &(struct test_procval_int){"4294967295", UINT32_MAX, CONF_U64} },
|
||||||
|
{"u64", test_procval_int, &(struct test_procval_int){"3141592653589793238", 3141592653589793238, CONF_U64}},
|
||||||
|
{"u8_overflow", test_procval_int, &(struct test_procval_int){"256", 255, CONF_U8} },
|
||||||
{"", test_procval_f32, NULL },
|
{"", test_procval_f32, NULL },
|
||||||
{"", test_procval_str, NULL },
|
{"", test_procval_str, NULL },
|
||||||
{"", test_procval_str_predef, NULL },
|
{"", test_procval_str_predef, NULL },
|
||||||
|
|||||||
@@ -94,18 +94,16 @@ int test_matchopt(void* arg) {
|
|||||||
return assert_true(conf_matchopt(opts, 3, dat->key) == xopt);
|
return assert_true(conf_matchopt(opts, 3, dat->key) == xopt);
|
||||||
}
|
}
|
||||||
|
|
||||||
int test_procval_i32(void* arg) {
|
struct test_procval_int {
|
||||||
(void)arg;
|
char const* val;
|
||||||
int32_t out;
|
uint64_t xres;
|
||||||
return assert_true(!conf_procval(&(struct conf_entry){NULL, &out, CONF_I32}, "42")) ||
|
uint8_t type;
|
||||||
assert_true(out == 42);
|
};
|
||||||
}
|
int test_procval_int(void* arg) {
|
||||||
|
struct test_procval_int* dat = arg;
|
||||||
int test_procval_u64(void* arg) {
|
|
||||||
(void)arg;
|
|
||||||
uint64_t out;
|
uint64_t out;
|
||||||
return assert_true(!conf_procval(&(struct conf_entry){NULL, &out, CONF_U64}, "3141592653589793238")) ||
|
return assert_true(!conf_procval(&(struct conf_entry){NULL, &out, dat->type}, dat->val)) ||
|
||||||
assert_true(out == 3141592653589793238);
|
assert_true(out == dat->xres);
|
||||||
}
|
}
|
||||||
|
|
||||||
int test_procval_f32(void* arg) {
|
int test_procval_f32(void* arg) {
|
||||||
|
|||||||
Reference in New Issue
Block a user