diff options
-rw-r--r-- | src/env.c | 5 | ||||
-rw-r--r-- | tests/env_test.c | 261 |
2 files changed, 188 insertions, 78 deletions
@@ -121,6 +121,7 @@ serd_env_set_base_uri(SerdEnv* env, serd_node_free(env->base_uri_node); env->base_uri_node = NULL; env->base_uri = SERD_URI_NULL; + return SERD_SUCCESS; } // Resolve base URI and create a new node and URI for it @@ -181,11 +182,13 @@ serd_env_set_prefix(SerdEnv* env, const SerdNode* name, const SerdNode* uri) { - if (!name || uri->type != SERD_URI) { + if (!name || name->type != SERD_LITERAL || uri->type != SERD_URI) { return SERD_ERR_BAD_ARG; } else if (serd_uri_string_has_scheme(serd_node_string(uri))) { // Set prefix to absolute URI serd_env_add(env, name, uri); + } else if (!env->base_uri_node) { + return SERD_ERR_BAD_ARG; } else { // Resolve relative URI and create a new node and URI for it SerdNode* abs_uri = serd_new_resolved_uri_i( diff --git a/tests/env_test.c b/tests/env_test.c index cff8e3cf..1d8b612f 100644 --- a/tests/env_test.c +++ b/tests/env_test.c @@ -21,123 +21,230 @@ #include <assert.h> #include <string.h> +#define NS_EG "http://example.org/" + static SerdStatus count_prefixes(void* handle, const SerdEvent* event) { - if (event->type == SERD_PREFIX) { - ++*(int*)handle; - } + *(int*)handle += event->type == SERD_PREFIX; return SERD_SUCCESS; } static void -test_env(void) +test_null(void) { - SerdWorld* world = serd_world_new(); - - SerdNode* hello = serd_new_string("hello\""); - SerdNode* eg = serd_new_uri("http://example.org/"); - SerdNode* foo_u = serd_new_uri("http://example.org/foo"); - SerdNode* empty = serd_new_uri(""); - SerdNode* foo_c = serd_new_curie("eg.2:foo"); - SerdNode* b = serd_new_curie("invalid"); - SerdNode* pre = serd_new_curie("eg.2"); - SerdEnv* env = serd_env_new(NULL); - serd_env_set_prefix(env, pre, eg); - + // Accessors are tolerant to a NULL env for convenience assert(!serd_env_base_uri(NULL)); assert(!serd_env_expand(NULL, NULL)); assert(!serd_env_qualify(NULL, NULL)); + // Only null is equal to null + assert(serd_env_equals(NULL, NULL)); +} + +static void +test_base_uri(void) +{ + SerdEnv* const env = serd_env_new(NULL); + SerdNode* const empty = serd_new_uri(""); + SerdNode* const hello = serd_new_string("hello"); + SerdNode* const eg = serd_new_uri(NS_EG); + + // Test that invalid calls work as expected assert(!serd_env_base_uri(env)); - assert(serd_env_set_base_uri(env, NULL)); - assert(serd_env_set_base_uri(env, empty)); - assert(serd_env_set_base_uri(env, hello)); + assert(serd_env_set_base_uri(env, empty) == SERD_ERR_BAD_ARG); + assert(serd_env_set_base_uri(env, hello) == SERD_ERR_BAD_ARG); + assert(serd_env_set_base_uri(NULL, eg) == SERD_ERR_BAD_ARG); assert(!serd_env_base_uri(env)); - SerdNode* xnode = serd_env_expand(env, hello); - assert(!xnode); - - assert(!serd_env_expand(env, b)); - assert(!serd_env_expand(env, hello)); + // Set a valid base URI + assert(!serd_env_set_base_uri(env, eg)); + assert(serd_node_equals(serd_env_base_uri(env), eg)); - assert(serd_env_set_base_uri(NULL, eg)); - assert(serd_env_set_base_uri(env, NULL)); + // Reset the base URI + assert(!serd_env_set_base_uri(env, NULL)); + assert(!serd_env_base_uri(env)); + serd_node_free(eg); serd_node_free(hello); + serd_node_free(empty); + serd_env_free(env); +} + +static void +test_set_prefix(void) +{ + SerdEnv* const env = serd_env_new(NULL); + SerdNode* const name1 = serd_new_string("eg.1"); + SerdNode* const name2 = serd_new_string("eg.2"); + SerdNode* const eg = serd_new_uri(NS_EG); + SerdNode* const curie = serd_new_curie("invalid"); + SerdNode* const rel = serd_new_uri("rel"); + SerdNode* const base = serd_new_uri("http://example.org/"); + + // Test that invalid calls work as expected + assert(serd_env_set_prefix(env, NULL, NULL) == SERD_ERR_BAD_ARG); + assert(serd_env_set_prefix(env, NULL, eg) == SERD_ERR_BAD_ARG); + assert(serd_env_set_prefix(env, curie, eg) == SERD_ERR_BAD_ARG); + assert(serd_env_set_prefix(env, name1, curie) == SERD_ERR_BAD_ARG); + + // Set a valid prefix + assert(!serd_env_set_prefix(env, name1, eg)); + + // Test setting a prefix from a relative URI + assert(serd_env_set_prefix(env, name2, rel) == SERD_ERR_BAD_ARG); + assert(!serd_env_set_base_uri(env, base)); + assert(!serd_env_set_prefix(env, name2, rel)); + + // Test setting a prefix from strings + assert(!serd_env_set_prefix_from_strings(env, + "eg.3", + "http://example.org/three")); + + // Test that we ended up with the expected number of prefixes + size_t n_prefixes = 0; + SerdSink* count_prefixes_sink = serd_sink_new(&n_prefixes, NULL); + serd_sink_set_event_func(count_prefixes_sink, count_prefixes); + serd_env_write_prefixes(env, count_prefixes_sink); + serd_sink_free(count_prefixes_sink); + assert(n_prefixes == 3); + + serd_node_free(base); + serd_node_free(rel); + serd_node_free(curie); + serd_node_free(eg); + serd_node_free(name2); + serd_node_free(name1); + serd_env_free(env); +} - SerdNode* xu = serd_env_expand(env, foo_c); - assert(!strcmp(serd_node_string(xu), "http://example.org/foo")); - serd_node_free(xu); +static void +test_expand(void) +{ + SerdNode* const name = serd_new_string("eg.1"); + SerdNode* const eg = serd_new_uri(NS_EG); + SerdNode* const blank = serd_new_blank("b1"); + SerdNode* const rel = serd_new_uri("rel"); + SerdNode* const base = serd_new_uri("http://example.org/b/"); + SerdNode* const c1 = serd_new_curie("eg.1:foo"); + SerdNode* const c1_full = serd_new_uri("http://example.org/foo"); + SerdNode* const c2 = serd_new_curie("hm:what"); + SerdNode* const type = serd_new_uri("Type"); + SerdNode* const typed = serd_new_typed_literal("data", type); + SerdEnv* const env = serd_env_new(base); + + assert(!serd_env_set_prefix(env, name, eg)); + + assert(!serd_env_expand(env, name)); + assert(!serd_env_expand(env, blank)); - SerdNode* badpre = serd_new_curie("hm:what"); - SerdNode* xbadpre = serd_env_expand(env, badpre); - assert(!xbadpre); - serd_node_free(badpre); + // Expand CURIE + SerdNode* const c1_out = serd_env_expand(env, c1); + assert(serd_node_equals(c1_out, c1_full)); + serd_node_free(c1_out); - SerdNode* xc = serd_env_expand(env, foo_c); - assert(serd_node_equals(xc, foo_u)); - serd_node_free(xc); + // Expand relative URI + SerdNode* const rel_out = serd_env_expand(env, rel); + assert(!strcmp(serd_node_string(rel_out), "http://example.org/b/rel")); + serd_node_free(rel_out); - assert(serd_env_set_prefix(env, NULL, NULL)); + // Expand literal with URI datatype + SerdNode* const typed_out = serd_env_expand(env, typed); + assert(typed_out); + assert(!strcmp(serd_node_string(typed_out), "data")); + assert(serd_node_datatype(typed_out)); + assert(!strcmp(serd_node_string(serd_node_datatype(typed_out)), + "http://example.org/b/Type")); + serd_node_free(typed_out); - SerdNode* lit = serd_new_string("hello"); - assert(serd_env_set_prefix(env, b, lit)); + assert(!serd_env_expand(env, c2)); - SerdNode* blank = serd_new_blank("b1"); - assert(!serd_env_expand(env, blank)); + serd_env_free(env); + serd_node_free(typed); + serd_node_free(type); + serd_node_free(c2); + serd_node_free(c1_full); + serd_node_free(c1); + serd_node_free(base); + serd_node_free(rel); serd_node_free(blank); + serd_node_free(eg); + serd_node_free(name); +} - size_t n_prefixes = 0; - SerdSink* count_prefixes_sink = serd_sink_new(&n_prefixes, NULL); - serd_sink_set_event_func(count_prefixes_sink, count_prefixes); - serd_env_set_prefix(env, pre, eg); - serd_env_write_prefixes(env, count_prefixes_sink); - serd_sink_free(count_prefixes_sink); - assert(n_prefixes == 1); +static void +test_qualify(void) +{ + SerdNode* const name = serd_new_string("eg"); + SerdNode* const eg = serd_new_uri(NS_EG); + SerdNode* const u1 = serd_new_uri("http://example.org/foo"); + SerdNode* const c1 = serd_new_curie("eg:foo"); + SerdNode* const u2 = serd_new_uri("http://drobilla.net/bar"); + SerdEnv* const env = serd_env_new(NULL); + + assert(!serd_env_set_prefix(env, name, eg)); + + assert(!serd_env_expand(env, name)); + + SerdNode* const u1_out = serd_env_qualify(env, u1); + assert(serd_node_equals(u1_out, c1)); + serd_node_free(u1_out); - SerdNode* shorter_uri = serd_new_uri("urn:foo"); - assert(!serd_env_qualify(env, shorter_uri)); - serd_node_free(shorter_uri); + assert(!serd_env_qualify(env, u2)); - SerdNode* qualified = serd_env_qualify(env, foo_u); - assert(serd_node_equals(qualified, foo_c)); + serd_env_free(env); + serd_node_free(u2); + serd_node_free(c1); + serd_node_free(u1); + serd_node_free(eg); + serd_node_free(name); +} - SerdEnv* env_copy = serd_env_copy(env); - assert(serd_env_equals(env, env_copy)); - assert(!serd_env_equals(env, NULL)); - assert(!serd_env_equals(NULL, env)); +static void +test_equals(void) +{ + SerdNode* const base1 = serd_new_uri(NS_EG "b1/"); + SerdNode* const base2 = serd_new_uri(NS_EG "b2/"); + SerdEnv* const env1 = serd_env_new(base1); + SerdEnv* const env2 = serd_env_new(base2); + + assert(!serd_env_equals(env1, NULL)); + assert(!serd_env_equals(NULL, env1)); assert(serd_env_equals(NULL, NULL)); + assert(!serd_env_equals(env1, env2)); - SerdNode* qualified2 = serd_env_expand(env_copy, foo_u); - assert(serd_node_equals(qualified, foo_c)); - serd_node_free(qualified2); + serd_env_set_base_uri(env2, base1); + assert(serd_env_equals(env1, env2)); - serd_env_set_prefix_from_strings( - env_copy, "test", "http://example.org/test"); - assert(!serd_env_equals(env, env_copy)); + assert(!serd_env_set_prefix_from_strings(env1, "n1", NS_EG "n1")); + assert(!serd_env_equals(env1, env2)); + assert(!serd_env_set_prefix_from_strings(env2, "n1", NS_EG "othern1")); + assert(!serd_env_equals(env1, env2)); + assert(!serd_env_set_prefix_from_strings(env2, "n1", NS_EG "n1")); + assert(serd_env_equals(env1, env2)); - serd_env_set_prefix_from_strings(env, "test2", "http://example.org/test"); - assert(!serd_env_equals(env, env_copy)); + serd_env_set_base_uri(env2, base2); + assert(!serd_env_equals(env1, env2)); - serd_node_free(qualified); - serd_node_free(foo_c); - serd_node_free(empty); - serd_node_free(foo_u); - serd_node_free(lit); - serd_node_free(b); - serd_node_free(pre); - serd_node_free(eg); - serd_env_free(env_copy); + SerdEnv* const env3 = serd_env_copy(env2); + assert(serd_env_equals(env3, env2)); + serd_env_free(env3); - serd_env_free(env); - serd_world_free(world); + serd_node_free(base1); + serd_node_free(base2); + serd_env_free(env1); + serd_env_free(env2); } int main(void) { - test_env(); + test_null(); + test_base_uri(); + test_set_prefix(); + test_expand(); + test_qualify(); + test_equals(); return 0; } |