From cfaf7d029da6f66bddfd91c7874d4019c502ea5c Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sat, 13 Dec 2008 03:44:56 +0000 Subject: Complete test coverage for plugin class stuff: 71.4% coverage git-svn-id: http://svn.drobilla.net/lad/trunk/slv2@1857 a436a847-0d15-0410-975c-d299462d15a1 --- test/slv2_test.c | 46 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) (limited to 'test') diff --git a/test/slv2_test.c b/test/slv2_test.c index 152d6b3..c8b8a4f 100644 --- a/test/slv2_test.c +++ b/test/slv2_test.c @@ -440,6 +440,51 @@ test_verify() /*****************************************************************************/ +int +test_classes() +{ + if (!start_bundle(MANIFEST_PREFIXES + ":plug a lv2:Plugin ; lv2:binary ; rdfs:seeAlso .\n", + BUNDLE_PREFIXES + ":plug a lv2:Plugin ; a lv2:CompressorPlugin ; " + PLUGIN_NAME("Test plugin") " ; " + LICENSE_GPL " ; " + "lv2:port [ " + " a lv2:ControlPort ; a lv2:InputPort ; " + " lv2:index 0 ; lv2:symbol \"foo\" ; lv2:name \"Foo\" ; " + "] .", + 1)) + return 0; + + init_uris(); + SLV2PluginClass plugin = slv2_world_get_plugin_class(world); + SLV2PluginClasses classes = slv2_world_get_plugin_classes(world); + SLV2PluginClasses children = slv2_plugin_class_get_children(plugin); + + TEST_ASSERT(slv2_plugin_class_get_parent_uri(plugin) == NULL); + TEST_ASSERT(slv2_plugin_classes_size(classes) > slv2_plugin_classes_size(children)) + TEST_ASSERT(!strcmp(slv2_value_as_string(slv2_plugin_class_get_label(plugin)), "Plugin")); + TEST_ASSERT(!strcmp(slv2_value_as_string(slv2_plugin_class_get_uri(plugin)), + "http://lv2plug.in/ns/lv2core#Plugin")); + + for (unsigned i = 0; i < slv2_plugin_classes_size(children); ++i) { + TEST_ASSERT(slv2_value_equals( + slv2_plugin_class_get_parent_uri(slv2_plugin_classes_get_at(children, i)), + slv2_plugin_class_get_uri(plugin))); + } + + SLV2Value some_uri = slv2_value_new_uri(world, "http://example.org/whatever"); + TEST_ASSERT(slv2_plugin_classes_get_by_uri(classes, some_uri) == NULL); + slv2_value_free(some_uri); + + TEST_ASSERT(slv2_plugin_classes_get_at(classes, (unsigned)INT_MAX + 1) == NULL); + + cleanup_uris(); + return 1; +} + +/*****************************************************************************/ + int test_plugin() { @@ -630,6 +675,7 @@ static struct TestCase tests[] = { /* TEST_CASE(discovery_load_bundle), */ TEST_CASE(verify), TEST_CASE(discovery_load_all), + TEST_CASE(classes), TEST_CASE(plugin), TEST_CASE(port), TEST_CASE(plugin), -- cgit v1.2.1