mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-18 10:04:20 +03:00
ccc35e2647
The device-mapper directory now holds a copy of libdm source. At the moment this code is identical to libdm. Over time code will migrate out to appropriate places (see doc/refactoring.txt). The libdm directory still exists, and contains the source for the libdevmapper shared library, which we will continue to ship (though not neccessarily update). All code using libdm should now use the version in device-mapper.
168 lines
5.4 KiB
C
168 lines
5.4 KiB
C
/*
|
|
* Copyright (C) 2010 Red Hat, Inc. All rights reserved.
|
|
*
|
|
* This file is part of LVM2.
|
|
*
|
|
* This copyrighted material is made available to anyone wishing to use,
|
|
* modify, copy, or redistribute it subject to the terms and conditions
|
|
* of the GNU General Public License v.2.
|
|
*
|
|
* 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 Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include "units.h"
|
|
#include "device_mapper/libdevmapper.h"
|
|
|
|
static void *_mem_init(void)
|
|
{
|
|
struct dm_pool *mem = dm_pool_create("config test", 1024);
|
|
if (!mem) {
|
|
fprintf(stderr, "out of memory\n");
|
|
exit(1);
|
|
}
|
|
|
|
return mem;
|
|
}
|
|
|
|
static void _mem_exit(void *mem)
|
|
{
|
|
dm_pool_destroy(mem);
|
|
}
|
|
|
|
static const char *conf =
|
|
"id = \"yada-yada\"\n"
|
|
"seqno = 15\n"
|
|
"status = [\"READ\", \"WRITE\"]\n"
|
|
"flags = []\n"
|
|
"extent_size = 8192\n"
|
|
"physical_volumes {\n"
|
|
" pv0 {\n"
|
|
" id = \"abcd-efgh\"\n"
|
|
" }\n"
|
|
" pv1 {\n"
|
|
" id = \"bbcd-efgh\"\n"
|
|
" }\n"
|
|
" pv2 {\n"
|
|
" id = \"cbcd-efgh\"\n"
|
|
" }\n"
|
|
"}\n";
|
|
|
|
static const char *overlay =
|
|
"id = \"yoda-soda\"\n"
|
|
"flags = [\"FOO\"]\n"
|
|
"physical_volumes {\n"
|
|
" pv1 {\n"
|
|
" id = \"hgfe-dcba\"\n"
|
|
" }\n"
|
|
" pv3 {\n"
|
|
" id = \"dbcd-efgh\"\n"
|
|
" }\n"
|
|
"}\n";
|
|
|
|
static void test_parse(void *fixture)
|
|
{
|
|
struct dm_config_tree *tree = dm_config_from_string(conf);
|
|
const struct dm_config_value *value;
|
|
|
|
T_ASSERT((long) tree);
|
|
T_ASSERT(dm_config_has_node(tree->root, "id"));
|
|
T_ASSERT(dm_config_has_node(tree->root, "physical_volumes"));
|
|
T_ASSERT(dm_config_has_node(tree->root, "physical_volumes/pv0"));
|
|
T_ASSERT(dm_config_has_node(tree->root, "physical_volumes/pv0/id"));
|
|
|
|
T_ASSERT(!strcmp(dm_config_find_str(tree->root, "id", "foo"), "yada-yada"));
|
|
T_ASSERT(!strcmp(dm_config_find_str(tree->root, "idt", "foo"), "foo"));
|
|
|
|
T_ASSERT(!strcmp(dm_config_find_str(tree->root, "physical_volumes/pv0/bb", "foo"), "foo"));
|
|
T_ASSERT(!strcmp(dm_config_find_str(tree->root, "physical_volumes/pv0/id", "foo"), "abcd-efgh"));
|
|
|
|
T_ASSERT(!dm_config_get_uint32(tree->root, "id", NULL));
|
|
T_ASSERT(dm_config_get_uint32(tree->root, "extent_size", NULL));
|
|
|
|
/* FIXME: Currently everything parses as a list, even if it's not */
|
|
// T_ASSERT(!dm_config_get_list(tree->root, "id", NULL));
|
|
// T_ASSERT(!dm_config_get_list(tree->root, "extent_size", NULL));
|
|
|
|
T_ASSERT(dm_config_get_list(tree->root, "flags", &value));
|
|
T_ASSERT(value->next == NULL); /* an empty list */
|
|
T_ASSERT(dm_config_get_list(tree->root, "status", &value));
|
|
T_ASSERT(value->next != NULL); /* a non-empty list */
|
|
|
|
dm_config_destroy(tree);
|
|
}
|
|
|
|
static void test_clone(void *fixture)
|
|
{
|
|
struct dm_config_tree *tree = dm_config_from_string(conf);
|
|
struct dm_config_node *n = dm_config_clone_node(tree, tree->root, 1);
|
|
const struct dm_config_value *value;
|
|
|
|
/* Check that the nodes are actually distinct. */
|
|
T_ASSERT(n != tree->root);
|
|
T_ASSERT(n->sib != tree->root->sib);
|
|
T_ASSERT(dm_config_find_node(n, "physical_volumes") != NULL);
|
|
T_ASSERT(dm_config_find_node(tree->root, "physical_volumes") != NULL);
|
|
T_ASSERT(dm_config_find_node(n, "physical_volumes") != dm_config_find_node(tree->root, "physical_volumes"));
|
|
|
|
T_ASSERT(dm_config_has_node(n, "id"));
|
|
T_ASSERT(dm_config_has_node(n, "physical_volumes"));
|
|
T_ASSERT(dm_config_has_node(n, "physical_volumes/pv0"));
|
|
T_ASSERT(dm_config_has_node(n, "physical_volumes/pv0/id"));
|
|
|
|
T_ASSERT(!strcmp(dm_config_find_str(n, "id", "foo"), "yada-yada"));
|
|
T_ASSERT(!strcmp(dm_config_find_str(n, "idt", "foo"), "foo"));
|
|
|
|
T_ASSERT(!strcmp(dm_config_find_str(n, "physical_volumes/pv0/bb", "foo"), "foo"));
|
|
T_ASSERT(!strcmp(dm_config_find_str(n, "physical_volumes/pv0/id", "foo"), "abcd-efgh"));
|
|
|
|
T_ASSERT(!dm_config_get_uint32(n, "id", NULL));
|
|
T_ASSERT(dm_config_get_uint32(n, "extent_size", NULL));
|
|
|
|
/* FIXME: Currently everything parses as a list, even if it's not */
|
|
// T_ASSERT(!dm_config_get_list(tree->root, "id", NULL));
|
|
// T_ASSERT(!dm_config_get_list(tree->root, "extent_size", NULL));
|
|
|
|
T_ASSERT(dm_config_get_list(n, "flags", &value));
|
|
T_ASSERT(value->next == NULL); /* an empty list */
|
|
T_ASSERT(dm_config_get_list(n, "status", &value));
|
|
T_ASSERT(value->next != NULL); /* a non-empty list */
|
|
|
|
dm_config_destroy(tree);
|
|
}
|
|
|
|
static void test_cascade(void *fixture)
|
|
{
|
|
struct dm_config_tree *t1 = dm_config_from_string(conf),
|
|
*t2 = dm_config_from_string(overlay),
|
|
*tree = dm_config_insert_cascaded_tree(t2, t1);
|
|
|
|
T_ASSERT(!strcmp(dm_config_tree_find_str(tree, "id", "foo"), "yoda-soda"));
|
|
T_ASSERT(!strcmp(dm_config_tree_find_str(tree, "idt", "foo"), "foo"));
|
|
|
|
T_ASSERT(!strcmp(dm_config_tree_find_str(tree, "physical_volumes/pv0/bb", "foo"), "foo"));
|
|
T_ASSERT(!strcmp(dm_config_tree_find_str(tree, "physical_volumes/pv1/id", "foo"), "hgfe-dcba"));
|
|
T_ASSERT(!strcmp(dm_config_tree_find_str(tree, "physical_volumes/pv3/id", "foo"), "dbcd-efgh"));
|
|
|
|
dm_config_destroy(t1);
|
|
dm_config_destroy(t2);
|
|
}
|
|
|
|
#define T(path, desc, fn) register_test(ts, "/metadata/config/" path, desc, fn)
|
|
|
|
void config_tests(struct dm_list *all_tests)
|
|
{
|
|
struct test_suite *ts = test_suite_create(_mem_init, _mem_exit);
|
|
if (!ts) {
|
|
fprintf(stderr, "out of memory\n");
|
|
exit(1);
|
|
}
|
|
|
|
T("parse", "parsing various", test_parse);
|
|
T("clone", "duplicating a config tree", test_clone);
|
|
T("cascade", "cascade", test_cascade);
|
|
|
|
dm_list_add(all_tests, &ts->list);
|
|
};
|