X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=t%2Funit%2Fcore%2Fdata_test.c;h=a647e020bb7e63b8b34d3d95c6eee81201c00474;hb=34bfa9790e6e7ed1ba9f1d4ed17fa34a73a1b064;hp=c33382386e8c99e60ac08c69af95cd6cba0486e5;hpb=c5e7e465a3ec8eccfd881411f08244d8c5265660;p=sysdb.git diff --git a/t/unit/core/data_test.c b/t/unit/core/data_test.c index c333823..a647e02 100644 --- a/t/unit/core/data_test.c +++ b/t/unit/core/data_test.c @@ -38,7 +38,7 @@ START_TEST(test_data) sdb_data_t d1, d2; int check; - int int_values[] = { 47, 11, 23 }; + int64_t int_values[] = { 47, 11, 23 }; char *string_values[] = { "foo", "bar", "qux" "baz" }; size_t i; @@ -225,6 +225,11 @@ END_TEST START_TEST(test_cmp) { + int64_t int_values1[] = { 1, 2, 3 }; + int64_t int_values2[] = { 1, 3, 2 }; + char *string_values1[] = { "a", "b", "c" }; + char *string_values2[] = { "a", "c", "b" }; + struct { sdb_data_t d1; sdb_data_t d2; @@ -400,6 +405,72 @@ START_TEST(test_cmp) { SDB_TYPE_REGEX, { .re = { "a", empty_re } } }, 1, }, + { + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values1), int_values1 } }, + }, + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values1), int_values1 } }, + }, + 0, + }, + { + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values1), int_values1 } }, + }, + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values2), int_values2 } }, + }, + -1, + }, + { + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values2), int_values2 } }, + }, + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values1), int_values1 } }, + }, + 1, + }, + { + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values1), string_values1 } }, + }, + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values1), string_values1 } }, + }, + 0, + }, + { + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values1), string_values1 } }, + }, + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values2), string_values2 } }, + }, + -1, + }, + { + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values2), string_values2 } }, + }, + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values1), string_values1 } }, + }, + 1, + }, }; size_t i; @@ -656,6 +727,73 @@ START_TEST(test_strcmp) } END_TEST +START_TEST(test_inarray) +{ + int64_t int_values[] = { 47, 11, 64 }; + double dec_values[] = { 12.3, 47.11, 64.0 }; + char *string_values[] = { "foo", "bar", "qux", "baz" }; + + sdb_data_t int_array = { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values), int_values } } + }; + sdb_data_t dec_array = { + SDB_TYPE_ARRAY | SDB_TYPE_DECIMAL, + { .array = { SDB_STATIC_ARRAY_LEN(dec_values), dec_values } } + }; + sdb_data_t string_array = { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values), string_values } } + }; + + struct { + sdb_data_t value; + sdb_data_t array; + _Bool expected; + } golden_data[] = { + { { SDB_TYPE_INTEGER, { .integer = 47 } }, int_array, 1 }, + { { SDB_TYPE_INTEGER, { .integer = 11 } }, int_array, 1 }, + { { SDB_TYPE_INTEGER, { .integer = 64 } }, int_array, 1 }, + { { SDB_TYPE_INTEGER, { .integer = 65 } }, int_array, 0 }, + { { SDB_TYPE_NULL, { .integer = 0 } }, int_array, 0 }, + { int_array, { SDB_TYPE_INTEGER, { .integer = 47 } }, 0 }, + { int_array, int_array, 0 }, + { { SDB_TYPE_DECIMAL, { .decimal = 12.3 } }, dec_array, 1 }, + { { SDB_TYPE_DECIMAL, { .decimal = 47.11 } }, dec_array, 1 }, + { { SDB_TYPE_DECIMAL, { .decimal = 64.0 } }, dec_array, 1 }, + { { SDB_TYPE_DECIMAL, { .decimal = 60.0 } }, dec_array, 0 }, + { { SDB_TYPE_INTEGER, { .integer = 64 } }, dec_array, 0 }, + { { SDB_TYPE_NULL, { .integer = 0 } }, dec_array, 0 }, + { { SDB_TYPE_STRING, { .string = "Foo" } }, string_array, 1 }, + { { SDB_TYPE_STRING, { .string = "FOO" } }, string_array, 1 }, + { { SDB_TYPE_STRING, { .string = "foo" } }, string_array, 1 }, + { { SDB_TYPE_STRING, { .string = "bar" } }, string_array, 1 }, + { { SDB_TYPE_STRING, { .string = "qux" } }, string_array, 1 }, + { { SDB_TYPE_STRING, { .string = "baz" } }, string_array, 1 }, + { { SDB_TYPE_STRING, { .string = "ba" } }, string_array, 0 }, + { { SDB_TYPE_STRING, { .string = "abc" } }, string_array, 0 }, + { { SDB_TYPE_NULL, { .integer = 0 } }, string_array, 0 }, + }; + + size_t i; + + for (i = 0; i < SDB_STATIC_ARRAY_LEN(golden_data); ++i) { + char v_str[1024] = "", a_str[1024] = ""; + _Bool check; + + sdb_data_format(&golden_data[i].value, + v_str, sizeof(v_str), SDB_UNQUOTED); + sdb_data_format(&golden_data[i].array, + a_str, sizeof(a_str), SDB_UNQUOTED); + + check = sdb_data_inarray(&golden_data[i].value, &golden_data[i].array); + fail_unless(check == golden_data[i].expected, + "sdb_data_inarray(%s, %s) = %d; expected: %d", + v_str, a_str, check, golden_data[i].expected); + } +} +END_TEST + START_TEST(test_parse_op) { struct { @@ -697,6 +835,12 @@ START_TEST(test_expr_eval) { sdb_data_t err = { -1, { .integer = 0 } }; + int64_t int_values[] = { 47, 11, 23 }; + int64_t expected_int_concat[] = { 47, 11, 23, 47, 11, 23 }; + char *string_values[] = { "foo", "bar", "qux" "baz" }; + char *expected_string_concat[] = + { "foo", "bar", "qux" "baz", "foo", "bar", "qux" "baz" }; + struct { sdb_data_t d1; sdb_data_t d2; @@ -836,6 +980,50 @@ START_TEST(test_expr_eval) err, err, }, + { + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values), int_values } }, + }, + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { SDB_STATIC_ARRAY_LEN(int_values), int_values } }, + }, + err, + err, + err, + err, + err, + { + SDB_TYPE_ARRAY | SDB_TYPE_INTEGER, + { .array = { + SDB_STATIC_ARRAY_LEN(expected_int_concat), + expected_int_concat + } }, + }, + }, + { + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values), string_values } }, + }, + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { SDB_STATIC_ARRAY_LEN(string_values), string_values } }, + }, + err, + err, + err, + err, + err, + { + SDB_TYPE_ARRAY | SDB_TYPE_STRING, + { .array = { + SDB_STATIC_ARRAY_LEN(expected_string_concat), + expected_string_concat + } }, + }, + }, { { SDB_TYPE_NULL, { .integer = 0 } }, { SDB_TYPE_NULL, { .integer = 0 } }, @@ -1011,6 +1199,237 @@ START_TEST(test_expr_eval) { SDB_TYPE_DATETIME, { .datetime = 0 } }, err, }, + /* unsupported type-mismatches */ + { + { SDB_TYPE_INTEGER, { .integer = 20 } }, + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_INTEGER, { .integer = 20 } }, + { SDB_TYPE_STRING, { .string = "20" } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_INTEGER, { .integer = 20 } }, + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_INTEGER, { .integer = 20 } }, + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_INTEGER, { .integer = 20 } }, + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_INTEGER, { .integer = 20 } }, + { SDB_TYPE_REGEX + 1, { .integer = 0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + { SDB_TYPE_INTEGER, { .integer = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + { SDB_TYPE_STRING, { .string = "20.0" } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + { SDB_TYPE_BINARY, { .binary = { 4, (unsigned char *)"20.0" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + { SDB_TYPE_REGEX + 1, { .integer = 0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_STRING, { .string = "20" } }, + { SDB_TYPE_INTEGER, { .integer = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_STRING, { .string = "20" } }, + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_STRING, { .string = "20" } }, + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_STRING, { .string = "20" } }, + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_STRING, { .string = "20" } }, + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_STRING, { .string = "20" } }, + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_STRING, { .string = "20" } }, + { SDB_TYPE_REGEX + 1, { .integer = 0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + { SDB_TYPE_STRING, { .string = "20" } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + { SDB_TYPE_REGEX + 1, { .integer = 0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + { SDB_TYPE_INTEGER, { .integer = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + { SDB_TYPE_INTEGER, { .integer = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + { SDB_TYPE_STRING, { .string = "20" } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + { SDB_TYPE_STRING, { .string = "20" } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + { SDB_TYPE_STRING, { .string = "20" } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + { SDB_TYPE_STRING, { .string = "20" } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + { SDB_TYPE_REGEX + 1, { .integer = 0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + { SDB_TYPE_REGEX + 1, { .integer = 0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + { SDB_TYPE_INTEGER, { .integer = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + { SDB_TYPE_DECIMAL, { .decimal = 20.0 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + { SDB_TYPE_STRING, { .string = "20" } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + { SDB_TYPE_DATETIME, { .datetime = 20 } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + { SDB_TYPE_BINARY, { .binary = { 2, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + { SDB_TYPE_BINARY, { .binary = { 3, (unsigned char *)"20" } } }, + err, err, err, err, err, err, + }, + { + { SDB_TYPE_REGEX, { .re = { ".", empty_re } } }, + { SDB_TYPE_REGEX + 1, { .integer = 0 } }, + err, err, err, err, err, err, + }, }; size_t i; @@ -1032,6 +1451,7 @@ START_TEST(test_expr_eval) for (j = 0; j < SDB_STATIC_ARRAY_LEN(tests); ++j) { sdb_data_t res; int check; + int type1, type2, type; char d1_str[64] = "", d2_str[64] = ""; sdb_data_format(&golden_data[i].d1, d1_str, sizeof(d1_str), @@ -1039,12 +1459,29 @@ START_TEST(test_expr_eval) sdb_data_format(&golden_data[i].d2, d2_str, sizeof(d2_str), SDB_DOUBLE_QUOTED); + type1 = golden_data[i].d1.type; + type2 = golden_data[i].d2.type; + if (sdb_data_isnull(&golden_data[i].d1)) + type1 = SDB_TYPE_NULL; + if (sdb_data_isnull(&golden_data[i].d2)) + type2 = SDB_TYPE_NULL; + type = sdb_data_expr_type(tests[j].op, type1, type2); + check = sdb_data_expr_eval(tests[j].op, &golden_data[i].d1, &golden_data[i].d2, &res); fail_unless((check == 0) == (tests[j].expected.type != -1), "sdb_data_expr_eval(%s, %s, %s) = %d; expected: %d", SDB_DATA_OP_TO_STRING(tests[j].op), d1_str, d2_str, check, tests[j].expected.type == -1 ? -1 : 0); + + fail_unless(tests[j].expected.type == type, + "sdb_data_expr_eval(%s, %s, %s) expected to evaluate " + "to type %d while sdb_data_expr_type(%d, %d, %d) " + "predicted type %d", SDB_DATA_OP_TO_STRING(tests[j].op), + d1_str, d2_str, tests[j].expected.type, + tests[j].op, golden_data[i].d1.type, + golden_data[i].d2.type, type); + if (tests[j].expected.type == -1) continue; @@ -1097,7 +1534,7 @@ START_TEST(test_format) }, { { SDB_TYPE_STRING, { .string = NULL } }, - "\"\"", + "NULL", }, { { SDB_TYPE_STRING, { .string = "this is a test" } }, @@ -1113,7 +1550,7 @@ START_TEST(test_format) }, { { SDB_TYPE_BINARY, { .binary = { 0, NULL } } }, - "\"\"", + "NULL", }, { { @@ -1232,6 +1669,7 @@ core_data_suite(void) tcase_add_test(tc, test_data); tcase_add_test(tc, test_cmp); tcase_add_test(tc, test_strcmp); + tcase_add_test(tc, test_inarray); tcase_add_test(tc, test_parse_op); tcase_add_test(tc, test_expr_eval); tcase_add_test(tc, test_format);