aboutsummaryrefslogtreecommitdiffstats
path: root/test/test_writer.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2021-05-29 15:20:23 -0400
committerDavid Robillard <d@drobilla.net>2023-12-02 18:49:07 -0500
commit55cb2411c1ddfe268c5d48f486f4da02470ab3d1 (patch)
treeedf6bc3e7db57a88c2b0acc4c3f3e87c1b47530d /test/test_writer.c
parent930f28478ca2573b7f7baf29a57a03cfa95a841f (diff)
downloadserd-55cb2411c1ddfe268c5d48f486f4da02470ab3d1.tar.gz
serd-55cb2411c1ddfe268c5d48f486f4da02470ab3d1.tar.bz2
serd-55cb2411c1ddfe268c5d48f486f4da02470ab3d1.zip
Use a simple type-safe stack in writer
Diffstat (limited to 'test/test_writer.c')
-rw-r--r--test/test_writer.c47
1 files changed, 47 insertions, 0 deletions
diff --git a/test/test_writer.c b/test/test_writer.c
index 9b885dd6..1334bb02 100644
--- a/test/test_writer.c
+++ b/test/test_writer.c
@@ -247,6 +247,52 @@ test_write_error(void)
serd_world_free(world);
}
+static void
+test_writer_stack_overflow(void)
+{
+ SerdWorld* world = serd_world_new();
+ SerdEnv* env = serd_env_new(serd_empty_string());
+
+ SerdWriter* writer =
+ serd_writer_new(world, SERD_TURTLE, 0U, env, null_sink, NULL);
+
+ const SerdSink* sink = serd_writer_sink(writer);
+
+ SerdNode* const s = serd_new_uri(serd_string("http://example.org/s"));
+ SerdNode* const p = serd_new_uri(serd_string("http://example.org/p"));
+
+ SerdNode* o = serd_new_blank(serd_string("blank"));
+ SerdStatus st = serd_sink_write(sink, SERD_ANON_O, s, p, o, NULL);
+ assert(!st);
+
+ // Repeatedly write nested anonymous objects until the writer stack overflows
+ for (unsigned i = 0U; i < 512U; ++i) {
+ char buf[1024];
+ snprintf(buf, sizeof(buf), "b%u", i);
+
+ SerdNode* next_o = serd_new_blank(serd_string(buf));
+
+ st = serd_sink_write(sink, SERD_ANON_O, o, p, next_o, NULL);
+
+ serd_node_free(o);
+ o = next_o;
+
+ if (st) {
+ assert(st == SERD_BAD_STACK);
+ break;
+ }
+ }
+
+ assert(st == SERD_BAD_STACK);
+
+ serd_node_free(o);
+ serd_node_free(p);
+ serd_node_free(s);
+ serd_writer_free(writer);
+ serd_env_free(env);
+ serd_world_free(world);
+}
+
int
main(void)
{
@@ -256,6 +302,7 @@ main(void)
test_writer_cleanup();
test_strict_write();
test_write_error();
+ test_writer_stack_overflow();
return 0;
}