aboutsummaryrefslogtreecommitdiffstats
path: root/test/test_sink.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-06-03 19:24:59 +0200
committerDavid Robillard <d@drobilla.net>2023-12-02 18:49:07 -0500
commit40534e6c42daabb6cc8ec2d49785bec088d1d3a8 (patch)
tree593e37de3e9bce98e291ec098a7081e6e26240b0 /test/test_sink.c
parent38f85ad8c53c618033e3d0b7cb1fe782c38cf0a3 (diff)
downloadserd-40534e6c42daabb6cc8ec2d49785bec088d1d3a8.tar.gz
serd-40534e6c42daabb6cc8ec2d49785bec088d1d3a8.tar.bz2
serd-40534e6c42daabb6cc8ec2d49785bec088d1d3a8.zip
Add SerdStatement
Diffstat (limited to 'test/test_sink.c')
-rw-r--r--test/test_sink.c44
1 files changed, 19 insertions, 25 deletions
diff --git a/test/test_sink.c b/test/test_sink.c
index 944dea1a..4b9a2eb2 100644
--- a/test/test_sink.c
+++ b/test/test_sink.c
@@ -18,15 +18,12 @@
#define NS_EG "http://example.org/"
typedef struct {
- const SerdNode* last_base;
- const SerdNode* last_name;
- const SerdNode* last_namespace;
- const SerdNode* last_end;
- const SerdNode* last_subject;
- const SerdNode* last_predicate;
- const SerdNode* last_object;
- const SerdNode* last_graph;
- SerdStatus return_status;
+ const SerdNode* last_base;
+ const SerdNode* last_name;
+ const SerdNode* last_namespace;
+ const SerdNode* last_end;
+ const SerdStatement* last_statement;
+ SerdStatus return_status;
} State;
static SerdStatus
@@ -49,21 +46,15 @@ on_prefix(void* handle, const SerdNode* name, const SerdNode* uri)
}
static SerdStatus
-on_statement(void* handle,
- SerdStatementFlags flags,
- const SerdNode* const graph,
- const SerdNode* const subject,
- const SerdNode* const predicate,
- const SerdNode* const object)
+on_statement(void* handle,
+ SerdStatementFlags flags,
+ const SerdStatement* const statement)
{
(void)flags;
State* state = (State*)handle;
- state->last_subject = subject;
- state->last_predicate = predicate;
- state->last_object = object;
- state->last_graph = graph;
+ state->last_statement = statement;
return state->return_status;
}
@@ -85,13 +76,17 @@ test_callbacks(void)
SerdNode* const uri = serd_new_uri(serd_string(NS_EG "uri"));
SerdNode* const blank = serd_new_blank(serd_string("b1"));
SerdEnv* env = serd_env_new(serd_node_string_view(base));
- State state = {0, 0, 0, 0, 0, 0, 0, 0, SERD_SUCCESS};
+ State state = {0, 0, 0, 0, 0, SERD_SUCCESS};
+
+ SerdStatement* const statement =
+ serd_statement_new(base, uri, blank, NULL, NULL);
// Call functions on a sink with no functions set
SerdSink* null_sink = serd_sink_new(&state, NULL);
assert(!serd_sink_write_base(null_sink, base));
assert(!serd_sink_write_prefix(null_sink, name, uri));
+ assert(!serd_sink_write_statement(null_sink, 0, statement));
assert(!serd_sink_write(null_sink, 0, base, uri, blank, NULL));
assert(!serd_sink_write_end(null_sink, blank));
serd_sink_free(null_sink);
@@ -111,16 +106,15 @@ test_callbacks(void)
assert(serd_node_equals(state.last_name, name));
assert(serd_node_equals(state.last_namespace, uri));
- assert(!serd_sink_write(sink, 0, base, uri, blank, NULL));
- assert(serd_node_equals(state.last_subject, base));
- assert(serd_node_equals(state.last_predicate, uri));
- assert(serd_node_equals(state.last_object, blank));
- assert(!state.last_graph);
+ assert(!serd_sink_write_statement(sink, 0, statement));
+ assert(serd_statement_equals(state.last_statement, statement));
assert(!serd_sink_write_end(sink, blank));
assert(serd_node_equals(state.last_end, blank));
serd_sink_free(sink);
+
+ serd_statement_free(statement);
serd_env_free(env);
serd_node_free(blank);
serd_node_free(uri);