void test_setDirectionMatch() { Key *parentKey = keyNew ("user/tests/glob", KEY_END); KeySet *conf = ksNew (20, keyNew ("user/glob/set/#1", KEY_VALUE, "/*", KEY_META, "testmetakey1", "testvalue1", KEY_META, "testmetakey2", "testvalue2", KEY_END), keyNew ("user/glob/get/#1", KEY_VALUE, "/*/*", KEY_META, "testmetakey1", "testvalue1", KEY_META, "testmetakey2", "testvalue2", KEY_END), KS_END); PLUGIN_OPEN("glob"); KeySet* ks = createKeys (); succeed_if(plugin->kdbSet (plugin, ks, parentKey) >= 1, "call to kdbSet was not successful"); succeed_if(output_error (parentKey), "error in kdbSet"); succeed_if(output_warnings (parentKey), "warnings in kdbSet"); testKeys (ks); ksDel(ks); keyDel(parentKey); PLUGIN_CLOSE(); }
static void test_intNoUpdateWithValueExceedingIntMin (void) { printf ("test no update with value that exceeds INT_MIN\n"); KeySet * conf = ksNew (0, KS_END); PLUGIN_OPEN ("internalnotification"); Key * valueKey = keyNew ("user/test/internalnotification/value", KEY_END); KeySet * ks = ksNew (1, valueKey, KS_END); int value = 123; succeed_if (internalnotificationRegisterInt (plugin, valueKey, &value) == 1, "call to elektraInternalnotificationRegisterInt was not successful"); long long exceedsInt = (long long) INT_MIN - 1; char * stringValue = convertLongLongToString (exceedsInt); keySetString (valueKey, stringValue); elektraInternalnotificationUpdateRegisteredKeys (plugin, ks); succeed_if (value == 123, "registered value was updated"); elektraFree (stringValue); ksDel (ks); PLUGIN_CLOSE (); }
static void test_mmap_ksCopy (const char * tmpFile) { Key * parentKey = keyNew (TEST_ROOT_KEY, KEY_VALUE, tmpFile, KEY_END); KeySet * conf = ksNew (0, KS_END); PLUGIN_OPEN ("mmapstorage"); KeySet * ks = simpleTestKeySet (); succeed_if (plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); succeed_if (plugin->kdbGet (plugin, ks, parentKey) == 1, "kdbGet was not successful"); succeed_if ((ks->flags & KS_FLAG_MMAP_ARRAY) == KS_FLAG_MMAP_ARRAY, "KeySet array not in mmap"); KeySet * copyKs = ksNew (0, KS_END); if (ksCopy (copyKs, ks) == 1) { compare_keyset (copyKs, ks); compare_keyset (ks, copyKs); } else { yield_error ("ksCopy failed"); } ksDel (copyKs); keyDel (parentKey); ksDel (ks); PLUGIN_CLOSE (); }
static void test_mmap_opmphm (const char * tmpFile) { Key * parentKey = keyNew (TEST_ROOT_KEY, KEY_VALUE, tmpFile, KEY_END); KeySet * conf = ksNew (0, KS_END); PLUGIN_OPEN ("mmapstorage"); KeySet * ks = largeTestKeySet (); succeed_if (plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); ksDel (ks); ks = ksNew (0, KS_END); succeed_if (plugin->kdbGet (plugin, ks, parentKey) == 1, "kdbGet was not successful"); const char * name = "user/tests/mmapstorage/dir7/key3"; Key * found = ksLookupByName (ks, name, KDB_O_OPMPHM); if (!found) { yield_error ("Key not found.") } // write keyset with OPMPHM structures succeed_if (plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }
void test_readfstab (const char * file) { Key * parentKey = keyNew ("user/tests/fstab", KEY_VALUE, srcdir_file (file), KEY_END); KeySet * conf = 0; PLUGIN_OPEN ("fstab"); KeySet * ks = ksNew (0, KS_END); printf ("Reading fstab using file: %s\n", file); succeed_if (plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); // output_keyset(ks); Key * key = ksLookupByName (ks, "user/tests/fstab/\\//device", 0); exit_if_fail (key, "rootfs device not found"); succeed_if (strcmp ("/dev/sda1", keyValue (key)) == 0, "device not correct"); key = ksLookupByName (ks, "user/tests/fstab/\\/media\\/ext4/device", 0); exit_if_fail (key, "media device not found"); succeed_if (strcmp ("/dev/sdg1", keyValue (key)) == 0, "device not correct"); exit_if_fail (key = ksLookupByName (ks, "user/tests/fstab/\\/media\\/ext4/dumpfreq", 0), "rootfs device not found"); succeed_if (strcmp ("0", keyValue (key)) == 0, "dumpfreq not correct"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }
void test_differentMetaNames () { Key *parentKey = keyNew ("user/tests/keytometa", KEY_END); KeySet *conf = ksNew(0, KS_END); PLUGIN_OPEN("keytometa"); KeySet *ks = createDifferentMetaNameTestKeys(); succeed_if(plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); Key *key = ksLookupByName(ks, "user/normalkey1", 0); succeed_if (key, "normalkey1 was removed"); const Key *metaKey1 = keyGetMeta(key, "testmeta1"); succeed_if (metaKey1, "normalkey1 contained no meta testmeta1"); const char *expected1 = "meta line1"; succeed_if (!strcmp (keyString(metaKey1), expected1), "metakey testmeta1 of normalkey1 contained incorrect data"); const Key *metaKey2= keyGetMeta(key, "testmeta2"); succeed_if (metaKey2, "normalkey1 contained no meta testmeta1"); const char *expected2 = "meta line2"; succeed_if (!strcmp (keyString(metaKey2), expected2), "metakey testmeta1 of normalkey1 contained incorrect data"); keyDel (parentKey); ksDel(ks); PLUGIN_CLOSE (); }
static void test_addNewBaseToParentKey() { Key *parentKey = keyNew ("user/tests/rename", KEY_END); KeySet *conf = ksNew (20, keyNew ("system/cut", KEY_VALUE, "new/base", KEY_END), KS_END); PLUGIN_OPEN("rename"); KeySet *ks = ksNew(0, KS_END); keyIncRef(parentKey); ksAppendKey (ks, parentKey); succeed_if(plugin->kdbSet (plugin, ks, parentKey) >= 1, "call to kdbSet was not successful"); succeed_if(output_error (parentKey), "error in kdbSet"); succeed_if(output_warnings (parentKey), "warnings in kdbSet"); Key *key = ksLookupByName (ks, "user/tests/rename/new/base", 0); succeed_if (key, "new base was not correctly appended to parent key"); ksDel(ks); keyDecRef(parentKey); keyDel(parentKey); PLUGIN_CLOSE (); }
static void test_mmap_metacopy (const char * tmpFile) { Key * parentKey = keyNew (TEST_ROOT_KEY, KEY_VALUE, tmpFile, KEY_END); KeySet * conf = ksNew (0, KS_END); PLUGIN_OPEN ("mmapstorage"); KeySet * ks = metaTestKeySet (); Key * shareMeta = keyNew (0); keySetMeta (shareMeta, "sharedmeta", "shared meta key test"); Key * current; ksRewind (ks); while ((current = ksNext (ks)) != 0) { keyCopyMeta (current, shareMeta, "sharedmeta"); } KeySet * expected = ksDeepDup (ks); succeed_if (plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); KeySet * returned = ksNew (0, KS_END); succeed_if (plugin->kdbGet (plugin, returned, parentKey) == 1, "kdbGet was not successful"); compare_keyset (expected, returned); ksDel (expected); ksDel (returned); keyDel (parentKey); keyDel (shareMeta); ksDel (ks); PLUGIN_CLOSE (); }
static void test_metaConfigTakesPrecedence() { Key *parentKey = keyNew ("user/tests/rename", KEY_END); KeySet *conf = ksNew (20, keyNew ("system/cut", KEY_VALUE, "will/be", KEY_END), KS_END); PLUGIN_OPEN("rename"); KeySet *ks = createSimpleMetaTestKeys(); ksAppendKey(ks, parentKey); succeed_if(plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); /* the first two keys should have been renamed by their metadata */ Key* key = ksLookupByName (ks, "user/tests/rename/key1", KDB_O_NONE); succeed_if(key, "key1 was not correctly renamed"); key = ksLookupByName (ks, "user/tests/rename/key2", KDB_O_NONE); succeed_if(key, "key2 was not correctly renamed"); /* the third key should have been renamed by the global config */ key = ksLookupByName (ks, "user/tests/rename/stripped", KDB_O_NONE); succeed_if(key, "key3 was renamed but would replace the parent key"); /* the fourth key was not renamed because the prefix did not match */ key = ksLookupByName (ks, "user/tests/rename/will/not/be/stripped/key4", KDB_O_NONE); succeed_if(key, "key4 was renamed although its prefix did not match"); keyDel (parentKey); ksDel(ks); PLUGIN_CLOSE (); }
static void test_rebaseOfNewKeys() { Key *parentKey = keyNew ("user/tests/rename", KEY_END); KeySet *conf = ksNew (20, keyNew ("system/cut", KEY_VALUE, "new/base", KEY_END), KS_END); PLUGIN_OPEN("rename"); KeySet *ks = ksNew(20, /* this key was seen by rename before and wont be changed */ keyNew("user/tests/rename/key1", KEY_VALUE, "value1", KEY_META, ELEKTRA_ORIGINAL_NAME_META, "user/tests/rename/key1", KEY_END), /* this key was not seen by rename before and will be renamed */ keyNew("user/tests/rename/key2", KEY_VALUE, "value2", KEY_END), KS_END); succeed_if(plugin->kdbSet (plugin, ks, parentKey) >= 1, "call to kdbSet was not successful"); succeed_if(output_error (parentKey), "error in kdbSet"); succeed_if(output_warnings (parentKey), "warnings in kdbSet"); Key* key = ksLookupByName (ks, "user/tests/rename/key1", KDB_O_NONE); succeed_if(key, "key1 was not found anymore, but it should not have been renamed"); key = ksLookupByName (ks, "user/tests/rename/new/base/key2", KDB_O_NONE); succeed_if(key, "key2 was not correctly renamed"); keyDel (parentKey); ksDel(ks); PLUGIN_CLOSE (); }
static void test_readPref (char * fileName) { Key * parentKey = keyNew ("user/tests/pref-read", KEY_VALUE, srcdir_file (fileName), KEY_END); KeySet * conf = ksNew (0, KS_END); PLUGIN_OPEN ("mozprefs"); KeySet * ks = ksNew (0, KS_END); succeed_if (plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); Key * key = ksLookupByName (ks, "user/tests/pref-read/user/a/user/key", KDB_O_NONE); exit_if_fail (key, "Key a.user.key not found"); succeed_if (!strcmp (keyString (key), "usertest"), "Key a.user.key contains invalid data"); key = ksLookupByName (ks, "user/tests/pref-read/lock/a/lock/key", KDB_O_NONE); exit_if_fail (key, "Key a.lock.key not found"); succeed_if (!strcmp (keyString (key), "true"), "Key a.lock.key contains invalid data"); key = ksLookupByName (ks, "user/tests/pref-read/pref/a/default/key", KDB_O_NONE); exit_if_fail (key, "Key a.default.key not found"); succeed_if (!strcmp (keyString (key), "1"), "Key a.default.key contains invalid data"); key = ksLookupByName (ks, "user/tests/pref-read/sticky/a/sticky/key", KDB_O_NONE); exit_if_fail (key, "Key a.sticky.key not found"); succeed_if (!strcmp (keyString (key), "false"), "Key a.sticky.key contains invalid data"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }
static void test_withoutConfig() { Key *parentKey = keyNew ("user/tests/rename", KEY_END); Key *parentKeyCopy = keyDup(parentKey); KeySet *conf = ksNew (0, KS_END); PLUGIN_OPEN("rename"); KeySet *ks = createSimpleTestKeys(); ksAppendKey(ks, parentKey); succeed_if(plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); KeySet *expected = createSimpleTestKeys(); ksAppendKey(expected, parentKeyCopy); compareKeySets(ks, expected); keyDel (parentKey); keyDel (parentKeyCopy); ksDel(expected); ksDel(ks); PLUGIN_CLOSE (); }
static void testreadwritecomplicated (const char * file) { Key * parentKey = keyNew ("user/tests/csvstorage", KEY_VALUE, srcdir_file (file), KEY_END); KeySet * conf = ksNew (10, keyNew ("system/delimiter", KEY_VALUE, ";", KEY_END), keyNew ("system/header", KEY_VALUE, "colname", KEY_END), KS_END); KeySet * ks = ksNew (0, KS_END); PLUGIN_OPEN ("csvstorage"); succeed_if (plugin->kdbGet (plugin, ks, parentKey) > 0, "call to kdbGet was not successful"); succeed_if (!strcmp (keyString (ksLookupByName (ks, "user/tests/csvstorage/#1/col3", KDB_O_NONE)), "l1;c3"), "key value doesn't match expected value"); succeed_if (!strcmp (keyString (ksLookupByName (ks, "user/tests/csvstorage/#1/col4", KDB_O_NONE)), "l1\"\"c4"), "key value doesn't match expected value"); succeed_if (!strcmp (keyString (ksLookupByName (ks, "user/tests/csvstorage/#2/col3", KDB_O_NONE)), "l2\nc3"), "key value doesn't match expected value"); succeed_if (!strcmp (keyString (ksLookupByName (ks, "user/tests/csvstorage/#4/col4", KDB_O_NONE)), "l4\"\"c4"), "key value doesn't match expected value"); succeed_if (!strcmp (keyString (ksLookupByName (ks, "user/tests/csvstorage/#5/col3", KDB_O_NONE)), "l5\"\"\nc3"), "key value doesn't match expected value"); keySetString (parentKey, elektraFilename ()); succeed_if (plugin->kdbSet (plugin, ks, parentKey) >= 0, "error: wrote invalid data"); succeed_if (compare_line_files (srcdir_file (file), keyString (parentKey)), "files do not match as expected"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }
static void test_mmap_ks_copy_with_meta (const char * tmpFile) { Key * parentKey = keyNew (TEST_ROOT_KEY, KEY_VALUE, tmpFile, KEY_END); KeySet * conf = ksNew (0, KS_END); PLUGIN_OPEN ("mmapstorage"); KeySet * ks = metaTestKeySet (); succeed_if (plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); ksDel (ks); KeySet * returned = ksNew (0, KS_END); succeed_if (plugin->kdbGet (plugin, returned, parentKey) == 1, "kdbGet was not successful"); KeySet * expected = metaTestKeySet (); compare_keyset (expected, returned); KeySet * copiedKs = ksNew (0, KS_END); ksCopy (copiedKs, returned); compare_keyset (expected, copiedKs); ksDel (copiedKs); ksDel (expected); ksDel (returned); keyDel (parentKey); PLUGIN_CLOSE (); }
void test_readline(){ char * filename = srcdir_file("line/linetest"); Key * parentKey = keyNew ("user/tests/line", KEY_VALUE, filename, KEY_END); KeySet *conf = 0; PLUGIN_OPEN("line"); printf("%s\n", filename); KeySet *ks=ksNew(0, KS_END); succeed_if (plugin->kdbGet(plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); Key *key = ksLookupByName(ks, "user/tests/line/#0", 0); exit_if_fail (key, "line1 key not found"); succeed_if (strcmp("test1", keyValue(key)) == 0, "line ´ does not match"); key = ksLookupByName(ks, "user/tests/line/#_10", 0); exit_if_fail (key, "line11 key not found"); succeed_if (strcmp("", keyValue(key)) == 0, "line 10 should be blank"); key = ksLookupByName(ks, "user/tests/line/#_13", 0); exit_if_fail (key, "line14 key not found"); succeed_if (strcmp("printf(\"hello world\\n\");", keyValue(key)) == 0, "line 13 not correct"); ksDel (ks); keyDel(parentKey); PLUGIN_CLOSE(); }
void test_structure (void) { printf ("Test structure of keys returned from uname plugin"); Key * parentKey = keyNew ("user/test/key", KEY_END); KeySet * keys = ksNew (0, KS_END); KeySet * conf = 0; PLUGIN_OPEN ("uname"); succeed_if (plugin->kdbGet (plugin, keys, parentKey) == 1, "could not call kdbGet"); succeed_if (ksGetSize (keys) == 6, "size not correct"); succeed_if (ksLookupByName (keys, "user/test/key", 0), "parentkey not found"); succeed_if (ksLookupByName (keys, "user/test/key/sysname", 0), "sysname key not found"); succeed_if (ksLookupByName (keys, "user/test/key/nodename", 0), "nodename key not found"); succeed_if (ksLookupByName (keys, "user/test/key/release", 0), "release key not found"); succeed_if (ksLookupByName (keys, "user/test/key/version", 0), "version key not found"); succeed_if (ksLookupByName (keys, "user/test/key/machine", 0), "machine key not found"); ksDel (keys); keyDel (parentKey); PLUGIN_CLOSE (); }
static void test_simpleCutOnGet () { Key *parentKey = keyNew ("user/tests/rename", KEY_END); KeySet *conf = ksNew (20, keyNew ("system/cut", KEY_VALUE, "will/be/stripped", KEY_END), KS_END); PLUGIN_OPEN("rename"); KeySet *ks = createSimpleTestKeys(); ksAppendKey(ks, parentKey); succeed_if(plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); checkSimpleTestKeys (ks); ksDel(ks); /* * this has to be done because the parentKey is not * part of ks anymore due to renaming */ keyDel(parentKey); PLUGIN_CLOSE (); }
static void test_replaceString() { Key *parentKey = keyNew("user/tests/rename", KEY_END); KeySet *conf = ksNew(20, keyNew("system/cut", KEY_VALUE, "will/be/stripped", KEY_END), keyNew("system/replacewith", KEY_VALUE, "stripped/it/is", KEY_END), KS_END); KeySet *ks = createSimpleTestKeys(); ksAppendKey(ks, parentKey); PLUGIN_OPEN("rename"); succeed_if(plugin->kdbGet(plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); Key *key = ksLookupByName(ks, "user/tests/rename/stripped/it/is/key1", KDB_O_NONE); succeed_if(key, "key1 was not correctly rename"); key = ksLookupByName(ks, "user/tests/rename/stripped/it/is/key2", KDB_O_NONE); succeed_if(key, "key2 was not correctly rename"); key = ksLookupByName(ks, "user/tests/rename/will/not/be/stripped/key4", KDB_O_NONE); succeed_if(key, "key4 was not correctly rename"); keyDel(parentKey); ksDel(ks); PLUGIN_CLOSE(); }
void test_hostLensFormatting(char *fileName) { Key *parentKey = keyNew ("user/tests/augeas-hosts", KEY_VALUE, srcdir_file (fileName), KEY_END); KeySet *conf = ksNew (20, keyNew ("system/lens", KEY_VALUE, "Hosts.lns", KEY_END), KS_END); PLUGIN_OPEN("augeas"); KeySet *ks = ksNew(0, KS_END); succeed_if(plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); keySetString (parentKey, elektraFilename()); succeed_if(plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); succeed_if(output_error (parentKey), "error in kdbSet"); succeed_if(output_warnings (parentKey), "warnings in kdbSet"); succeed_if( compare_line_files (srcdir_file (fileName), keyString (parentKey)), "files do not match as expected"); elektraUnlink(keyString (parentKey)); keyDel (parentKey); ksDel (ks); PLUGIN_CLOSE () ; }
void test_appendSameLevel () { Key *parentKey = keyNew ("user/tests/keytometa", KEY_END); KeySet *conf = ksNew (0, KS_END); PLUGIN_OPEN ("keytometa"); KeySet *ks = createSameLevelTestKeys(); succeed_if (plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); /* convertkey1 should be converted to childkey1 as childkey1 is on the same level as requested */ Key *childKey = ksLookupByName(ks, "user/levelkey1/childkey1", 0); succeed_if (childKey, "childkey1 was removed"); const Key *metaKey1 = keyGetMeta(childKey, "testmeta"); succeed_if (metaKey1, "childkey1 contained no meta testmeta"); const char *expected1 = "convertkey1value"; succeed_if (!strcmp (keyString(metaKey1), expected1), "metakey testmeta of childkey1 contained incorrect data"); /* convertkey2 should be converted to levelkey as the next key in order is not on the same level */ Key *levelkey1 = ksLookupByName(ks, "user/levelkey1", 0); succeed_if (levelkey1, "levelkey1 was removed"); const Key *metaKey2 = keyGetMeta(levelkey1, "testmeta"); succeed_if (metaKey2, "levelkey1 contained no meta testmeta"); const char *expected2 = "convertkey2value"; succeed_if (!strcmp (keyString(metaKey2), expected2), "metakey testmeta of levelkey1 contained incorrect data"); keyDel (parentKey); ksDel(ks); PLUGIN_CLOSE (); }
void test_hostLensDelete(char *sourceFile, char *compFile) { Key *parentKey = keyNew ("user/tests/augeas-hosts", KEY_VALUE, srcdir_file (sourceFile), KEY_END); KeySet *conf = ksNew (20, keyNew ("system/lens", KEY_VALUE, "Hosts.lns", KEY_END), KS_END); PLUGIN_OPEN("augeas"); KeySet *ks = ksNew(0, KS_END); succeed_if(plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); Key *key = ksLookupByName (ks, "user/tests/augeas-hosts/1", 0); exit_if_fail(key, "localhost not found"); ksPopAtCursor(ks, ksGetCursor(ks)); keyDel (key); key = ksLookupByName (ks, "user/tests/augeas-hosts/1/ipaddr", 0); exit_if_fail(key, "ip address of localhost not found"); ksPopAtCursor(ks, ksGetCursor(ks)); keyDel (key); key = ksLookupByName (ks, "user/tests/augeas-hosts/1/canonical", 0); exit_if_fail(key, "canonical of localhost not found"); ksPopAtCursor(ks, ksGetCursor(ks)); keyDel (key); key = ksLookupByName (ks, "user/tests/augeas-hosts/1/#comment", 0); exit_if_fail(key, "comment of localhost not found"); ksPopAtCursor(ks, ksGetCursor(ks)); keyDel (key); keySetString (parentKey, elektraFilename()); succeed_if(plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); succeed_if(output_error (parentKey), "error in kdbSet"); succeed_if(output_warnings (parentKey), "warnings in kdbSet"); succeed_if( compare_line_files (srcdir_file (compFile), keyString (parentKey)), "files do not match as expected"); ksDel (ks); elektraUnlink(keyString (parentKey)); keyDel (parentKey); PLUGIN_CLOSE () ; }
void testinvalid (const char * file) { Key * parentKey = keyNew ("user/tests/lineendings", KEY_VALUE, srcdir_file (file), KEY_END); KeySet * conf = ksNew (20, keyNew ("system/valid", KEY_VALUE, "CRLF", KEY_END), KS_END); PLUGIN_OPEN ("lineendings"); KeySet * ks = ksNew (0, KS_END); succeed_if (plugin->kdbGet (plugin, ks, parentKey) == 1, "kdbget failed"); succeed_if (plugin->kdbSet (plugin, ks, parentKey) == (-1), "should have failed"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }
void testvalid (const char * file) { Key * parentKey = keyNew ("user/tests/lineendings", KEY_VALUE, srcdir_file (file), KEY_END); KeySet * conf = 0; PLUGIN_OPEN ("lineendings"); KeySet * ks = ksNew (0, KS_END); succeed_if (plugin->kdbGet (plugin, ks, parentKey) == 1, "kdbget failed"); succeed_if (plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbset failed"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }
void test_metaMerging () { Key *parentKey = keyNew ("user/tests/keytometa", KEY_END); KeySet *conf = ksNew(0, KS_END); PLUGIN_OPEN("keytometa"); KeySet* ks = createMergeTestkeys (); succeed_if(plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); Key *key = ksLookupByName(ks, "user/normalkey1", 0); succeed_if (key, "normalkey1 was removed"); const Key *metaKey1 = keyGetMeta(key, "testmeta"); succeed_if (metaKey1, "normalkey1 contained no metakey"); const char *expected1 = "meta line 1\nmeta line 2\nmeta line 3"; succeed_if (!strcmp (keyString(metaKey1), expected1), "metakey of normalkey1 contained incorrect data"); key = ksLookupByName(ks, "user/normalkey2", 0); succeed_if (key, "normalkey2 was removed"); const Key *metaKey2 = keyGetMeta(key, "testmeta"); succeed_if (metaKey2, "normalkey2 contained no metakey"); const char *expected2 = "meta line 30\nmeta line 31\nmeta line 32"; succeed_if (!strcmp (keyString(metaKey2), expected2), "metakey of normalkey2 contained incorrect data"); /* change the value of the middle key */ keySetMeta(key, "testmeta", "meta line 30\nchanged meta line\nmeta line 32"); succeed_if(plugin->kdbSet (plugin, ks, parentKey) >= 1, "call to kdbSet was not successful"); succeed_if(output_error (parentKey), "error in kdbSet"); succeed_if(output_warnings (parentKey), "warnings in kdbSet"); key = ksLookupByName(ks, "user/convertkey30", 0); succeed_if (key, "convertkey30 was not restored"); succeed_if (!strcmp (keyString(key), "meta line 30"), "value of convertkey30 was modified"); key = ksLookupByName (ks, "user/convertkey31", 0); succeed_if (key, "convertkey31 was not restored"); succeed_if (!strcmp (keyString(key), "changed meta line"), "meta information was not written back to convertkey31"); key = ksLookupByName (ks, "user/convertkey32", 0); succeed_if (key, "convertkey32 was not restored"); succeed_if (!strcmp (keyString(key), "meta line 32"), "value of convertkey32 was modified"); keyDel (parentKey); ksDel(ks); PLUGIN_CLOSE (); }
static void clearStorage (const char * tmpFile) { Key * parentKey = keyNew (TEST_ROOT_KEY, KEY_VALUE, tmpFile, KEY_END); KeySet * conf = ksNew (0, KS_END); PLUGIN_OPEN ("mmapstorage"); KeySet * ks = ksNew (0, KS_END); succeed_if (plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); keyDel (parentKey); ksDel (ks); PLUGIN_CLOSE (); }
void test_hostLensWrite(char *fileName) { Key *parentKey = keyNew ("user/tests/augeas-hosts", KEY_VALUE, elektraFilename(), KEY_END); KeySet *conf = ksNew (20, keyNew ("system/lens", KEY_VALUE, "Hosts.lns", KEY_END), KS_END); PLUGIN_OPEN("augeas"); KeySet *ks = ksNew (30, keyNew ("user/tests/augeas-hosts/1", KEY_END), keyNew ("user/tests/augeas-hosts/1/ipaddr", KEY_VALUE, "127.0.0.1", KEY_META, "order", "10", KEY_END), keyNew ("user/tests/augeas-hosts/1/canonical", KEY_VALUE, "localhost", KEY_META, "order", "20", KEY_END), keyNew ("user/tests/augeas-hosts/1/#comment", KEY_VALUE, "hostcomment", KEY_META, "order", "21", KEY_END), keyNew ("user/tests/augeas-hosts/#comment", KEY_VALUE, "linecomment", KEY_META, "order", "22", KEY_END), keyNew ("user/tests/augeas-hosts/2/ipaddr", KEY_VALUE, "192.168.0.1", KEY_META, "order", "30", KEY_END), keyNew ("user/tests/augeas-hosts/2/canonical", KEY_VALUE, "host1", KEY_META, "order", "40", KEY_END), keyNew ("user/tests/augeas-hosts/2/alias[1]", KEY_VALUE, "host1alias1", KEY_META, "order", "50", KEY_END), keyNew ("user/tests/augeas-hosts/2/alias[2]", KEY_VALUE, "host1alias2", KEY_META, "order", "60", KEY_END), keyNew ("user/tests/augeas-hosts/3/ipaddr", KEY_VALUE, "fd00::4711:4712:2::1", KEY_META, "order", "70", KEY_END), keyNew ("user/tests/augeas-hosts/3/canonical", KEY_VALUE, "host2", KEY_META, "order", "80", KEY_END), keyNew ("user/tests/augeas-hosts/3/alias[1]", KEY_VALUE, "host2alias1", KEY_META, "order", "90", KEY_END), keyNew ("user/tests/augeas-hosts/3/alias[2]", KEY_VALUE, "host2alias2", KEY_META, "order", "100", KEY_END), KS_END); ksAppendKey (ks, parentKey); succeed_if(plugin->kdbSet (plugin, ks, parentKey) == 1, "kdbSet was not successful"); succeed_if(output_error (parentKey), "error in kdbSet"); succeed_if(output_warnings (parentKey), "warnings in kdbSet"); succeed_if( compare_line_files (srcdir_file (fileName), keyString (parentKey)), "files do not match as expected"); elektraUnlink(keyString (parentKey)); ksDel (ks); PLUGIN_CLOSE (); }
static void testreadwriteinvalid (const char * file) { Key * parentKey = keyNew ("user/tests/csvstorage", KEY_VALUE, srcdir_file (file), KEY_END); KeySet * conf = ksNew (10, keyNew ("system/delimiter", KEY_VALUE, ";", KEY_END), KS_END); KeySet * ks = ksNew (0, KS_END); PLUGIN_OPEN ("csvstorage"); succeed_if (plugin->kdbGet (plugin, ks, parentKey) > 0, "call to kdbGet was not successful"); succeed_if (!output_warnings (parentKey), "no warnings in kdbGet"); keySetString (parentKey, elektraFilename ()); succeed_if (plugin->kdbSet (plugin, ks, parentKey) == (-1), "error: wrote invalid data"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }
void test_hostLensRead(char *fileName) { Key *parentKey = keyNew ("user/tests/augeas-hosts", KEY_VALUE, srcdir_file (fileName), KEY_END); KeySet *conf = ksNew (20, keyNew ("system/lens", KEY_VALUE, "Hosts.lns", KEY_END), KS_END); PLUGIN_OPEN("augeas"); KeySet *ks = ksNew(0, KS_END); succeed_if(plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbGet was not successful"); succeed_if(output_error (parentKey), "error in kdbGet"); succeed_if(output_warnings (parentKey), "warnings in kdbGet"); Key *key = ksLookupByName (ks, "user/tests/augeas-hosts/1/ipaddr", 0); exit_if_fail(key, "ip address of localhost not found"); succeed_if(strcmp ("127.0.0.1", keyValue (key)) == 0, "address of localhost not correct"); key = ksLookupByName (ks, "user/tests/augeas-hosts/1/canonical", 0); exit_if_fail(key, "name of localhost not found"); succeed_if(strcmp ("localhost", keyValue (key)) == 0, "name of localhost not correct"); key = ksLookupByName (ks, "user/tests/augeas-hosts/2/ipaddr", 0); exit_if_fail(key, "ip address of host1 not found"); succeed_if(strcmp ("192.168.0.1", keyValue (key)) == 0, "address of host1 not correct"); key = ksLookupByName (ks, "user/tests/augeas-hosts/2/canonical", 0); exit_if_fail(key, "name of host1 not found"); succeed_if(strcmp ("host1", keyValue (key)) == 0, "name of host1 not correct"); key = ksLookupByName (ks, "user/tests/augeas-hosts/2/alias[1]", 0); exit_if_fail(key, "alias1 of host1 not found"); succeed_if(strcmp ("alias1", keyValue (key)) == 0, "name of alias1 of host1 not correct"); key = ksLookupByName (ks, "user/tests/augeas-hosts/2/alias[2]", 0); exit_if_fail(key, "alias2 of host1 not found"); succeed_if(strcmp ("alias2", keyValue (key)) == 0, "name of alias2 of host1 not correct"); PLUGIN_CLOSE(); ksDel (ks); keyDel(parentKey); }
static void test_formatNotAccepted (const char * format) { Key * parentKey = keyNew ("user/tests/simpleini", KEY_VALUE, elektraFilename (), KEY_END); KeySet * conf = ksNew (1, keyNew ("system/format", KEY_VALUE, format, KEY_END), KS_END); PLUGIN_OPEN ("simpleini"); KeySet * ks = ksNew (0, KS_END); succeed_if (plugin->kdbGet (plugin, ks, parentKey) != 1, "kdbGet was successful for an invalid format"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }
void test_onlyFirstMatchIsApplied (void) { Key * parentKey = keyNew ("user/tests/glob", KEY_END); // clang-format off KeySet * conf = ksNew (20, keyNew ("user/glob/#1", KEY_VALUE, "user/tests/glob/test1*", KEY_META, "testmetakey1", "testvalue1", KEY_END), keyNew ("user/glob/#2", KEY_VALUE, "user/tests/glob/*", KEY_META, "testmetakey2", "testvalue2", KEY_END), /* disable all flags */ keyNew ("user/glob/#1/flags", KEY_VALUE, "", KEY_END), keyNew ("user/glob/#2/flags", KEY_VALUE, "", KEY_END), KS_END); // clang-format on PLUGIN_OPEN ("glob"); KeySet * ks = createKeys (); succeed_if (plugin->kdbGet (plugin, ks, parentKey) >= 1, "call to kdbSet was not successful"); succeed_if (output_error (parentKey), "error in kdbSet"); succeed_if (output_warnings (parentKey), "warnings in kdbSet"); Key * key = ksLookupByName (ks, "user/tests/glob/test1", 0); exit_if_fail (key, "key user/tests/glob/test1 not found"); const Key * firstMatchKey = keyGetMeta (key, "testmetakey1"); exit_if_fail (firstMatchKey, "testmetakey1 not found"); const Key * secondMatchKey = keyGetMeta (key, "testmetakey2"); exit_if_fail (!secondMatchKey, "testmetakey2 was applied to testmetakey1 although another match was already applied") key = ksLookupByName (ks, "user/tests/glob/test2/subtest1", 0); exit_if_fail (key, "user/tests/glob/test2/subtest1 not found"); exit_if_fail (keyGetMeta (key, "testmetakey2"), "testmetakey2 not found"); key = ksLookupByName (ks, "user/tests/glob/test3", 0); exit_if_fail (key, "user/tests/glob/test3 not found"); exit_if_fail (keyGetMeta (key, "testmetakey2"), "testmetakey2 not found"); ksDel (ks); keyDel (parentKey); PLUGIN_CLOSE (); }