diff options
Diffstat (limited to 'tests')
-rw-r--r-- | tests/env_test.c | 18 | ||||
-rw-r--r-- | tests/serd_test.c | 150 |
2 files changed, 92 insertions, 76 deletions
diff --git a/tests/env_test.c b/tests/env_test.c index 607b8763..07e3700e 100644 --- a/tests/env_test.c +++ b/tests/env_test.c @@ -36,11 +36,11 @@ test_env(void) { SerdWorld* world = serd_world_new(); - SerdNode* hello = serd_node_new_string("hello\""); - SerdNode* u = serd_node_new_uri("http://example.org/foo"); - SerdNode* b = serd_node_new_curie("invalid"); - SerdNode* c = serd_node_new_curie("eg.2:b"); - SerdNode* s = serd_node_new_string("hello"); + SerdNode* hello = serd_new_string("hello\""); + SerdNode* u = serd_new_uri("http://example.org/foo"); + SerdNode* b = serd_new_curie("invalid"); + SerdNode* c = serd_new_curie("eg.2:b"); + SerdNode* s = serd_new_string("hello"); SerdEnv* env = serd_env_new(NULL); serd_env_set_prefix_from_strings(env, "eg.2", "http://example.org/"); @@ -65,7 +65,7 @@ test_env(void) assert(!strcmp(serd_node_string(xu), "http://example.org/foo")); serd_node_free(xu); - SerdNode* badpre = serd_node_new_curie("hm:what"); + SerdNode* badpre = serd_new_curie("hm:what"); SerdNode* xbadpre = serd_env_expand_node(env, badpre); assert(!xbadpre); @@ -75,10 +75,10 @@ test_env(void) assert(serd_env_set_prefix(env, NULL, NULL)); - SerdNode* lit = serd_node_new_string("hello"); + SerdNode* lit = serd_new_string("hello"); assert(serd_env_set_prefix(env, b, lit)); - SerdNode* blank = serd_node_new_blank("b1"); + SerdNode* blank = serd_new_blank("b1"); assert(!serd_env_expand_node(env, blank)); serd_node_free(blank); @@ -87,7 +87,7 @@ test_env(void) serd_env_foreach(env, count_prefixes, &n_prefixes); assert(n_prefixes == 1); - SerdNode* shorter_uri = serd_node_new_uri("urn:foo"); + SerdNode* shorter_uri = serd_new_uri("urn:foo"); const SerdNode* prefix_name = NULL; assert(!serd_env_qualify(env, shorter_uri, &prefix_name, &suffix)); serd_node_free(shorter_uri); diff --git a/tests/serd_test.c b/tests/serd_test.c index 2f0a3b07..2a8f7edf 100644 --- a/tests/serd_test.c +++ b/tests/serd_test.c @@ -107,7 +107,7 @@ test_file_uri(const char* hostname, expected_path = path; } - SerdNode* node = serd_node_new_file_uri(path, hostname, escape); + SerdNode* node = serd_new_file_uri(path, hostname, escape); const char* node_str = serd_node_string(node); char* out_hostname = NULL; char* out_path = serd_file_uri_parse(node_str, &out_hostname); @@ -267,7 +267,7 @@ test_double_to_node(void) }; for (size_t i = 0; i < sizeof(dbl_test_nums) / sizeof(double); ++i) { - SerdNode* node = serd_node_new_decimal(dbl_test_nums[i], 8, NULL); + SerdNode* node = serd_new_decimal(dbl_test_nums[i], 8, NULL); const char* node_str = serd_node_string(node); const bool pass = (node_str && dbl_test_strs[i]) ? !strcmp(node_str, dbl_test_strs[i]) @@ -294,7 +294,7 @@ test_integer_to_node(void) }; for (size_t i = 0; i < sizeof(int_test_nums) / sizeof(double); ++i) { - SerdNode* node = serd_node_new_integer(int_test_nums[i], NULL); + SerdNode* node = serd_new_integer(int_test_nums[i], NULL); const char* node_str = serd_node_string(node); assert(!strcmp(node_str, int_test_strs[i])); const size_t len = strlen(node_str); @@ -308,8 +308,8 @@ test_integer_to_node(void) static void test_blob_to_node(void) { - assert(!serd_node_new_blob(NULL, 0, true, NULL)); - assert(!serd_node_new_blob("data", 0, true, NULL)); + assert(!serd_new_blob(NULL, 0, true, NULL)); + assert(!serd_new_blob("data", 0, true, NULL)); for (size_t size = 1; size < 256; ++size) { uint8_t* data = size > 0 ? (uint8_t*)malloc(size) : NULL; @@ -318,7 +318,7 @@ test_blob_to_node(void) } size_t out_size = 0; - SerdNode* blob = serd_node_new_blob(data, size, size % 5, NULL); + SerdNode* blob = serd_new_blob(data, size, size % 5, NULL); const char* blob_str = serd_node_string(blob); uint8_t* out = (uint8_t*)serd_base64_decode( blob_str, serd_node_length(blob), &out_size); @@ -391,11 +391,11 @@ static void test_node_equals(void) { const uint8_t replacement_char_str[] = { 0xEF, 0xBF, 0xBD, 0 }; - SerdNode* lhs = serd_node_new_string((const char*)replacement_char_str); - SerdNode* rhs = serd_node_new_string("123"); + SerdNode* lhs = serd_new_string((const char*)replacement_char_str); + SerdNode* rhs = serd_new_string("123"); assert(!serd_node_equals(lhs, rhs)); - SerdNode* qnode = serd_node_new_curie("foo:bar"); + SerdNode* qnode = serd_new_curie("foo:bar"); assert(!serd_node_equals(lhs, qnode)); serd_node_free(qnode); @@ -408,9 +408,9 @@ test_node_equals(void) static void test_node_from_string(void) { - assert(!serd_node_new_string(NULL)); + assert(!serd_new_string(NULL)); - SerdNode* hello = serd_node_new_string("hello\""); + SerdNode* hello = serd_new_string("hello\""); assert(serd_node_length(hello) == 6); assert(serd_node_flags(hello) == SERD_HAS_QUOTE); assert(!strncmp(serd_node_string(hello), "hello\"", 6)); @@ -420,16 +420,16 @@ test_node_from_string(void) static void test_node_from_substring(void) { - assert(!serd_node_new_substring(NULL, 32)); + assert(!serd_new_substring(NULL, 32)); - SerdNode* a_b = serd_node_new_substring("a\"bc", 3); + SerdNode* a_b = serd_new_substring("a\"bc", 3); assert(serd_node_length(a_b) == 3); assert(serd_node_flags(a_b) == SERD_HAS_QUOTE); assert(strlen(serd_node_string(a_b)) == 3); assert(!strncmp(serd_node_string(a_b), "a\"b", 3)); serd_node_free(a_b); - a_b = serd_node_new_substring("a\"bc", 10); + a_b = serd_new_substring("a\"bc", 10); assert(serd_node_length(a_b) == 4); assert(serd_node_flags(a_b) == SERD_HAS_QUOTE); assert(strlen(serd_node_string(a_b)) == 4); @@ -440,52 +440,68 @@ test_node_from_substring(void) static void test_simple_node(void) { - assert(!serd_node_new_simple_node(SERD_LITERAL, "Literal", 7)); - assert(!serd_node_new_simple_node(SERD_URI, NULL, 0)); + assert(!serd_new_simple_node(SERD_LITERAL, "Literal", 7)); + assert(!serd_new_simple_node(SERD_URI, NULL, 0)); } static void test_literal(void) { - assert(!serd_node_new_literal(NULL, NULL, NULL)); + assert(!serd_new_literal(NULL, 0, NULL, 0, NULL, 0)); + assert(!serd_new_plain_literal(NULL, NULL)); + assert(!serd_new_typed_literal(NULL, NULL)); + + SerdNode* hello2 = serd_new_string("hello\""); + assert(!serd_new_typed_literal("bad type", hello2)); - SerdNode* hello2 = serd_node_new_literal("hello\"", NULL, NULL); assert(serd_node_length(hello2) == 6 && serd_node_flags(hello2) == SERD_HAS_QUOTE && !strcmp(serd_node_string(hello2), "hello\"")); + + SerdNode* hello3 = serd_new_plain_literal("hello\"", NULL); + assert(serd_node_equals(hello2, hello3)); + + SerdNode* hello4 = serd_new_typed_literal("hello\"", NULL); + assert(serd_node_equals(hello4, hello2)); + + serd_node_free(hello4); + serd_node_free(hello3); serd_node_free(hello2); - SerdNode* hello_l = serd_node_new_literal("hello_l\"", NULL, "en"); - assert(serd_node_length(hello_l) == 8); - assert(!strcmp(serd_node_string(hello_l), "hello_l\"")); - assert(serd_node_flags(hello_l) == - (SERD_HAS_QUOTE | SERD_HAS_LANGUAGE)); - assert(!strcmp(serd_node_string(serd_node_language(hello_l)), - "en")); - serd_node_free(hello_l); - - SerdNode* eg_Thing = serd_node_new_uri("http://example.org/Thing"); - SerdNode* hello_dt = serd_node_new_literal("hello_dt\"", eg_Thing, NULL); - assert(serd_node_length(hello_dt) == 9); - assert(!strcmp(serd_node_string(hello_dt), "hello_dt\"")); - assert(serd_node_flags(hello_dt) == (SERD_HAS_QUOTE | SERD_HAS_DATATYPE)); - assert(!strcmp(serd_node_string(serd_node_datatype(hello_dt)), - "http://example.org/Thing")); - serd_node_free(hello_dt); - serd_node_free(eg_Thing); + const char* lang_lit_str = "\"Hello\"@en"; + SerdNode* sliced_lang_lit = + serd_new_literal(lang_lit_str + 1, 5, NULL, 0, lang_lit_str + 8, 2); + assert(!strcmp(serd_node_string(sliced_lang_lit), "Hello")); + assert(!strcmp( + serd_node_string(serd_node_language(sliced_lang_lit)), + "en")); + serd_node_free(sliced_lang_lit); + + const char* type_lit_str = "\"Hallo\"^^<http://example.org/Greeting>"; + SerdNode* sliced_type_lit = + serd_new_literal(type_lit_str + 1, 5, type_lit_str + 10, 27, NULL, 0); + assert(!strcmp(serd_node_string(sliced_type_lit), "Hallo")); + assert(!strcmp( + serd_node_string(serd_node_datatype(sliced_type_lit)), + "http://example.org/Greeting")); + serd_node_free(sliced_type_lit); + + SerdNode* plain_lit = serd_new_literal("Plain", 5, NULL, 0, NULL, 0); + assert(!strcmp(serd_node_string(plain_lit), "Plain")); + serd_node_free(plain_lit); } static void test_uri_from_string(void) { - assert(!serd_node_new_uri(NULL)); - - SerdNode* base = serd_node_new_uri("http://example.org/a/b/c/"); - SerdNode* not_a_uri = serd_node_new_string("hello"); - SerdNode* nil = serd_node_new_resolved_uri(NULL, base); - SerdNode* nil2 = serd_node_new_resolved_uri("", base); - assert(!serd_node_new_resolved_uri("", NULL)); - assert(!serd_node_new_resolved_uri("", not_a_uri)); + assert(!serd_new_uri(NULL)); + + SerdNode* base = serd_new_uri("http://example.org/a/b/c/"); + SerdNode* not_a_uri = serd_new_string("hello"); + SerdNode* nil = serd_new_resolved_uri(NULL, base); + SerdNode* nil2 = serd_new_resolved_uri("", base); + assert(!serd_new_resolved_uri("", NULL)); + assert(!serd_new_resolved_uri("", not_a_uri)); assert(serd_node_type(nil) == SERD_URI); assert(!strcmp(serd_node_string(nil), serd_node_string(base))); assert(serd_node_type(nil2) == SERD_URI); @@ -502,7 +518,7 @@ check_rel_uri(const char* uri, const SerdNode* root, const char* expected) { - SerdNode* rel = serd_node_new_relative_uri(uri, base, root); + SerdNode* rel = serd_new_relative_uri(uri, base, root); const int ret = strcmp(serd_node_string(rel), expected); serd_node_free(rel); assert(!ret); @@ -511,8 +527,8 @@ check_rel_uri(const char* uri, static void test_relative_uri(void) { - SerdNode* root = serd_node_new_uri("http://example.org/a/b/"); - SerdNode* base = serd_node_new_uri("http://example.org/a/b/c/"); + SerdNode* root = serd_new_uri("http://example.org/a/b/"); + SerdNode* base = serd_new_uri("http://example.org/a/b/c/"); check_rel_uri("http://example.org/a/b/c/foo", base, NULL, "foo"); check_rel_uri("http://example.org/a/", base, NULL, "../../"); @@ -527,18 +543,18 @@ test_relative_uri(void) static void test_uri_resolution(void) { - SerdNode* base = serd_node_new_uri("http://example.org/a/b/c/"); - SerdNode* nil = serd_node_new_resolved_uri(NULL, base); - SerdNode* nil2 = serd_node_new_resolved_uri("", base); - SerdNode* not_a_uri = serd_node_new_string("hello"); - SerdNode* root = serd_node_new_uri("http://example.org/a/b/"); + SerdNode* base = serd_new_uri("http://example.org/a/b/c/"); + SerdNode* nil = serd_new_resolved_uri(NULL, base); + SerdNode* nil2 = serd_new_resolved_uri("", base); + SerdNode* not_a_uri = serd_new_string("hello"); + SerdNode* root = serd_new_uri("http://example.org/a/b/"); assert(!serd_node_resolve(NULL, base)); assert(!serd_node_resolve(nil, NULL)); assert(!serd_node_resolve(not_a_uri, base)); assert(!serd_node_resolve(nil, not_a_uri)); - SerdNode* rel = serd_node_new_relative_uri( + SerdNode* rel = serd_new_relative_uri( "http://example.org/a/b/c/foo", base, NULL); SerdNode* resolved = serd_node_resolve(rel, base); assert(!strcmp(serd_node_string(resolved), @@ -556,9 +572,9 @@ test_uri_resolution(void) static void test_blank(void) { - assert(!serd_node_new_blank(NULL)); + assert(!serd_new_blank(NULL)); - SerdNode* blank = serd_node_new_blank("b0"); + SerdNode* blank = serd_new_blank("b0"); assert(serd_node_length(blank) == 2); assert(serd_node_flags(blank) == 0); assert(!strcmp(serd_node_string(blank), "b0")); @@ -585,7 +601,7 @@ test_writer(const char* const path) serd_writer_chop_blank_prefix(writer, "tmp"); serd_writer_chop_blank_prefix(writer, NULL); - SerdNode* lit = serd_node_new_string("hello"); + SerdNode* lit = serd_new_string("hello"); const SerdSink* iface = serd_writer_get_sink(writer); assert(iface->base(iface->handle, lit)); @@ -594,9 +610,9 @@ test_writer(const char* const path) assert(serd_writer_env(writer) == env); uint8_t buf[] = { 0xEF, 0xBF, 0xBD, 0 }; - SerdNode* s = serd_node_new_uri(""); - SerdNode* p = serd_node_new_uri("http://example.org/pred"); - SerdNode* o = serd_node_new_string((char*)buf); + SerdNode* s = serd_new_uri(""); + SerdNode* p = serd_new_uri("http://example.org/pred"); + SerdNode* o = serd_new_string((char*)buf); // Write 3 invalid statements (should write nothing) const SerdNode* junk[][5] = { { s, p, NULL }, @@ -614,10 +630,10 @@ test_writer(const char* const path) iface, 0, junk[i][0], junk[i][1], junk[i][2], 0)); } - SerdNode* urn_Type = serd_node_new_uri("urn:Type"); + SerdNode* urn_Type = serd_new_uri("urn:Type"); - SerdNode* t = serd_node_new_literal((char*)buf, urn_Type, NULL); - SerdNode* l = serd_node_new_literal((char*)buf, NULL, "en"); + SerdNode* t = serd_new_typed_literal((char*)buf, urn_Type); + SerdNode* l = serd_new_plain_literal((char*)buf, "en"); const SerdNode* good[][5] = { { s, p, o }, { s, p, o }, { s, p, t }, @@ -635,8 +651,8 @@ test_writer(const char* const path) // Write statements with bad UTF-8 (should be replaced) const char bad_str[] = { (char)0xFF, (char)0x90, 'h', 'i', 0 }; - SerdNode* bad_lit = serd_node_new_string(bad_str); - SerdNode* bad_uri = serd_node_new_uri(bad_str); + SerdNode* bad_lit = serd_new_string(bad_str); + SerdNode* bad_uri = serd_new_uri(bad_str); assert(!serd_sink_write(iface, 0, s, p, bad_lit, 0)); assert(!serd_sink_write(iface, 0, s, p, bad_uri, 0)); serd_node_free(bad_uri); @@ -644,7 +660,7 @@ test_writer(const char* const path) // Write 1 valid statement serd_node_free(o); - o = serd_node_new_string("hello"); + o = serd_new_string("hello"); assert(!serd_sink_write(iface, 0, s, p, o, 0)); serd_writer_free(writer); @@ -659,7 +675,7 @@ test_writer(const char* const path) writer = serd_writer_new( world, SERD_TURTLE, (SerdStyle)0, env, serd_buffer_sink, &buffer); - o = serd_node_new_uri("http://example.org/base"); + o = serd_new_uri("http://example.org/base"); assert(!serd_writer_set_base_uri(writer, o)); serd_node_free(o); @@ -683,7 +699,7 @@ test_reader(const char* path) SerdReader* reader = serd_reader_new(world, SERD_TURTLE, &sink, 4096); assert(reader); - SerdNode* g = serd_node_new_uri("http://example.org/"); + SerdNode* g = serd_new_uri("http://example.org/"); serd_reader_set_default_graph(reader, g); serd_reader_add_blank_prefix(reader, "tmp"); serd_reader_add_blank_prefix(reader, NULL); |