/* SLV2 Tests * Copyright (C) 2008 Dave Robillard * Copyright (C) 2008 Krzysztof Foltman * * This library is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation; either version 2 of the License, or (at your option) * any later version. * * This library is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. */ #define _XOPEN_SOURCE 500 #include #include #include #include #include #include #include #include "slv2/slv2.h" static char bundle_dir_name[1024]; static char bundle_dir_uri[1024]; static char manifest_name[1024]; static char content_name[1024]; static SLV2World world; int test_count = 0; int error_count = 0; void delete_bundle() { unlink(content_name); unlink(manifest_name); rmdir(bundle_dir_name); } void init_tests() { strncpy(bundle_dir_name, getenv("HOME"), 900); strcat(bundle_dir_name, "/.lv2/slv2-test.lv2"); sprintf(bundle_dir_uri, "file:///%s/", bundle_dir_name); sprintf(manifest_name, "%s/manifest.ttl", bundle_dir_name); sprintf(content_name, "%s/plugin.ttl", bundle_dir_name); delete_bundle(); } void fatal_error(const char *err, const char *arg) { /* TODO: possibly change to vfprintf later */ fprintf(stderr, err, arg); /* IMHO, the bundle should be left in place after an error, for possible investigation */ /* delete_bundle(); */ exit(1); } void write_file(const char *name, const char *content) { FILE* f = fopen(name, "w"); size_t len = strlen(content); if (fwrite(content, 1, len, f) != len) fatal_error("Cannot write file %s\n", name); fclose(f); } int init_world() { world = slv2_world_new(); return world != NULL; } int load_all_bundles() { if (!init_world()) return 0; slv2_world_load_all(world); return 1; } int load_bundle() { SLV2Value uri; if (!init_world()) return 0; uri = slv2_value_new_uri(world, bundle_dir_uri); slv2_world_load_bundle(world, uri); slv2_value_free(uri); return 1; } void create_bundle(char *manifest, char *content) { if (mkdir(bundle_dir_name, 0700)) fatal_error("Cannot create directory %s\n", bundle_dir_name); write_file(manifest_name, manifest); write_file(content_name, content); } int start_bundle(char *manifest, char *content, int load_all) { create_bundle(manifest, content); if (load_all) return load_all_bundles(); else return load_bundle(); } void unload_bundle() { if (world) slv2_world_free(world); world = NULL; } void cleanup() { delete_bundle(); } /*****************************************************************************/ #define TEST_CASE(name) { #name, test_##name } #define TEST_ASSERT(check) do {\ test_count++;\ if (!(check)) {\ error_count++;\ fprintf(stderr, "Failure at slv2_test.c:%d: %s\n", __LINE__, #check);\ }\ } while (0); typedef int (*TestFunc)(); struct TestCase { const char *title; TestFunc func; }; #define PREFIX_LINE "@prefix : .\n" #define PREFIX_LV2 "@prefix lv2: .\n" #define PREFIX_RDFS "@prefix rdfs: .\n" #define PREFIX_FOAF "@prefix foaf: .\n" #define PREFIX_DOAP "@prefix doap: .\n" #define MANIFEST_PREFIXES PREFIX_LINE PREFIX_LV2 PREFIX_RDFS #define BUNDLE_PREFIXES PREFIX_LINE PREFIX_LV2 PREFIX_RDFS PREFIX_FOAF PREFIX_DOAP #define PLUGIN_NAME(name) "doap:name \"" name "\"" #define LICENSE_GPL "doap:license " static char *uris_plugin = "http://example.com/plug"; static SLV2Value plugin_uri_value, plugin2_uri_value; /*****************************************************************************/ void init_uris() { plugin_uri_value = slv2_value_new_uri(world, uris_plugin); plugin2_uri_value = slv2_value_new_uri(world, "http://example.com/foobar"); TEST_ASSERT(plugin_uri_value); TEST_ASSERT(plugin2_uri_value); } void cleanup_uris() { slv2_value_free(plugin2_uri_value); slv2_value_free(plugin_uri_value); plugin2_uri_value = NULL; plugin_uri_value = NULL; } /*****************************************************************************/ int test_utils() { TEST_ASSERT(!strcmp(slv2_uri_to_path("file:///tmp/blah"), "/tmp/blah")); TEST_ASSERT(!slv2_uri_to_path("file:/example.com/blah")); TEST_ASSERT(!slv2_uri_to_path("http://example.com/blah")); return 1; } /*****************************************************************************/ int test_value() { SLV2Value v1, v2, v3; const char *uri = "http://example.com/"; char *res; init_world(); v1 = slv2_value_new_uri(world, "http://example.com/"); TEST_ASSERT(v1); TEST_ASSERT(slv2_value_is_uri(v1)); TEST_ASSERT(!strcmp(slv2_value_as_uri(v1), uri)); TEST_ASSERT(!slv2_value_is_literal(v1)); TEST_ASSERT(!slv2_value_is_string(v1)); TEST_ASSERT(!slv2_value_is_float(v1)); TEST_ASSERT(!slv2_value_is_int(v1)); res = slv2_value_get_turtle_token(v1); TEST_ASSERT(!strcmp(res, "")); v2 = slv2_value_new_uri(world, uri); TEST_ASSERT(v2); TEST_ASSERT(slv2_value_is_uri(v2)); TEST_ASSERT(!strcmp(slv2_value_as_uri(v2), uri)); TEST_ASSERT(slv2_value_equals(v1, v2)); v3 = slv2_value_new_uri(world, "http://example.com/another"); TEST_ASSERT(v3); TEST_ASSERT(slv2_value_is_uri(v3)); TEST_ASSERT(!strcmp(slv2_value_as_uri(v3), "http://example.com/another")); TEST_ASSERT(!slv2_value_equals(v1, v3)); slv2_value_free(v2); v2 = slv2_value_duplicate(v1); TEST_ASSERT(slv2_value_equals(v1, v2)); TEST_ASSERT(slv2_value_is_uri(v2)); TEST_ASSERT(!strcmp(slv2_value_as_uri(v2), uri)); TEST_ASSERT(!slv2_value_is_literal(v2)); TEST_ASSERT(!slv2_value_is_string(v2)); TEST_ASSERT(!slv2_value_is_float(v2)); TEST_ASSERT(!slv2_value_is_int(v2)); slv2_value_free(v3); slv2_value_free(v2); slv2_value_free(v1); return 1; } /*****************************************************************************/ int test_values() { SLV2Value v0; SLV2Values vs1; init_world(); v0 = slv2_value_new_uri(world, "http://example.com/"); vs1 = slv2_values_new(); TEST_ASSERT(vs1); TEST_ASSERT(!slv2_values_size(vs1)); TEST_ASSERT(!slv2_values_contains(vs1, v0)); slv2_values_free(vs1); slv2_value_free(v0); return 1; } /*****************************************************************************/ static int discovery_plugin_found = 0; static bool discovery_plugin_filter_all(SLV2Plugin plugin) { return true; } static bool discovery_plugin_filter_none(SLV2Plugin plugin) { return false; } static bool discovery_plugin_filter_ours(SLV2Plugin plugin) { return slv2_value_equals(slv2_plugin_get_uri(plugin), plugin_uri_value); } static bool discovery_plugin_filter_fake(SLV2Plugin plugin) { return slv2_value_equals(slv2_plugin_get_uri(plugin), plugin2_uri_value); } static void discovery_verify_plugin(SLV2Plugin plugin) { SLV2Value value = slv2_plugin_get_uri(plugin); if (slv2_value_equals(value, plugin_uri_value)) { SLV2Value lib_uri = NULL; TEST_ASSERT(!slv2_value_equals(value, plugin2_uri_value)); discovery_plugin_found = 1; lib_uri = slv2_plugin_get_library_uri(plugin); TEST_ASSERT(lib_uri); TEST_ASSERT(slv2_value_is_uri(lib_uri)); TEST_ASSERT(slv2_value_as_uri(lib_uri)); TEST_ASSERT(strstr(slv2_value_as_uri(lib_uri), "foo.so")); /* this is already being tested as ticket291, but the discovery and ticket291 * may diverge at some point, so I'm duplicating it here */ TEST_ASSERT(slv2_plugin_verify(plugin)); } } int test_discovery_variant(int load_all) { SLV2Plugins plugins; SLV2Plugin explug, explug2; if (!start_bundle(MANIFEST_PREFIXES ":plug a lv2:Plugin ; lv2:binary ; rdfs:seeAlso .\n", BUNDLE_PREFIXES ":plug a lv2:Plugin ;" PLUGIN_NAME("Test plugin") " ; " LICENSE_GPL " ; " "lv2:port [ a lv2:ControlPort ; a lv2:InputPort ;" " lv2:index 0 ; lv2:symbol \"foo\" ; lv2:name \"bar\" ; ] .", load_all)) return 0; init_uris(); /* lookup 1: all plugins (get_all_plugins) * lookup 2: all plugins (get_plugins_by_filter, always true) * lookup 3: no plugins (get_plugins_by_filter, always false) * lookup 4: only example plugin (get_plugins_by_filter) * lookup 5: no plugins (get_plugins_by_filter, non-existing plugin) */ for (int lookup = 1; lookup <= 5; lookup++) { //printf("Lookup variant %d\n", lookup); int expect_found = 0; switch (lookup) { case 1: plugins = slv2_world_get_all_plugins(world); TEST_ASSERT(slv2_plugins_size(plugins) > 0); expect_found = 1; break; case 2: plugins = slv2_world_get_plugins_by_filter(world, discovery_plugin_filter_all); TEST_ASSERT(slv2_plugins_size(plugins) > 0); expect_found = 1; break; case 3: plugins = slv2_world_get_plugins_by_filter(world, discovery_plugin_filter_none); TEST_ASSERT(slv2_plugins_size(plugins) == 0); break; case 4: plugins = slv2_world_get_plugins_by_filter(world, discovery_plugin_filter_ours); TEST_ASSERT(slv2_plugins_size(plugins) == 1); expect_found = 1; break; case 5: plugins = slv2_world_get_plugins_by_filter(world, discovery_plugin_filter_fake); TEST_ASSERT(slv2_plugins_size(plugins) == 0); break; } explug = slv2_plugins_get_by_uri(plugins, plugin_uri_value); TEST_ASSERT((explug != NULL) == expect_found); explug2 = slv2_plugins_get_by_uri(plugins, plugin2_uri_value); TEST_ASSERT(explug2 == NULL); if (explug && expect_found) { TEST_ASSERT(!strcmp(slv2_value_as_string(slv2_plugin_get_name(explug)), "Test plugin")); } discovery_plugin_found = 0; for (size_t i = 0; i < slv2_plugins_size(plugins); i++) discovery_verify_plugin(slv2_plugins_get_at(plugins, i)); TEST_ASSERT(discovery_plugin_found == expect_found); slv2_plugins_free(world, plugins); plugins = NULL; } cleanup_uris(); return 1; } int test_discovery_load_bundle() { return test_discovery_variant(0); } int test_discovery_load_all() { return test_discovery_variant(1); } /*****************************************************************************/ int test_verify() { SLV2Plugins plugins; SLV2Plugin explug; if (!start_bundle(MANIFEST_PREFIXES ":plug a lv2:Plugin ; lv2:binary ; rdfs:seeAlso .\n", BUNDLE_PREFIXES ":plug a lv2:Plugin ; " PLUGIN_NAME("Test plugin") " ; " LICENSE_GPL " ; " "lv2:port [ a lv2:ControlPort ; a lv2:InputPort ;" " lv2:index 0 ; lv2:symbol \"foo\" ; lv2:name \"bar\" ] .", 1)) return 0; init_uris(); plugins = slv2_world_get_all_plugins(world); explug = slv2_plugins_get_by_uri(plugins, plugin_uri_value); TEST_ASSERT(explug); slv2_plugin_verify(explug); slv2_plugins_free(world, plugins); cleanup_uris(); return 1; } /*****************************************************************************/ /* add tests here */ static struct TestCase tests[] = { TEST_CASE(utils), TEST_CASE(value), TEST_CASE(values), /* TEST_CASE(discovery_load_bundle), */ TEST_CASE(verify), TEST_CASE(discovery_load_all), { NULL, NULL } }; void run_tests() { int i; for (i = 0; tests[i].title; i++) { printf("\n--- Test: %s\n", tests[i].title); if (!tests[i].func()) { printf("\nTest failed\n"); /* test case that wasn't able to be executed at all counts as 1 test + 1 error */ error_count++; test_count++; } unload_bundle(); cleanup(); } } int main(int argc, char *argv[]) { if (argc != 1) { printf("Syntax: %s\n", argv[0]); return 0; } init_tests(); run_tests(); cleanup(); printf("\n--- Results: %d tests, %d errors\n", test_count, error_count); return error_count ? 1 : 0; }