2011-12-11 19:19:41 +04:00
/*
* 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 ,
2016-01-21 13:49:46 +03:00
* Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
2011-12-11 19:19:41 +04:00
*/
2015-11-27 12:54:57 +03:00
# include "units.h"
2011-12-13 16:08:42 +04:00
2011-12-11 19:19:41 +04:00
static struct dm_pool * mem ;
2011-12-13 16:08:42 +04:00
int config_init ( void ) {
2011-12-11 19:19:41 +04:00
mem = dm_pool_create ( " config test " , 1024 ) ;
return mem = = NULL ;
}
2011-12-13 16:08:42 +04:00
int config_fini ( void ) {
2011-12-11 19:19:41 +04:00
dm_pool_destroy ( mem ) ;
return 0 ;
}
2011-12-11 19:45:14 +04:00
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 " ;
2011-12-19 03:56:36 +04:00
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 " ;
2011-12-13 16:08:42 +04:00
static void test_parse ( void )
2011-12-11 19:19:41 +04:00
{
struct dm_config_tree * tree = dm_config_from_string ( conf ) ;
2011-12-13 16:08:42 +04:00
const struct dm_config_value * value ;
2011-12-11 19:19:41 +04:00
2011-12-13 16:08:42 +04:00
CU_ASSERT ( ( long ) tree ) ;
2011-12-11 19:19:41 +04:00
CU_ASSERT ( dm_config_has_node ( tree - > root , " id " ) ) ;
CU_ASSERT ( dm_config_has_node ( tree - > root , " physical_volumes " ) ) ;
CU_ASSERT ( dm_config_has_node ( tree - > root , " physical_volumes/pv0 " ) ) ;
CU_ASSERT ( dm_config_has_node ( tree - > root , " physical_volumes/pv0/id " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_find_str ( tree - > root , " id " , " foo " ) , " yada-yada " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_find_str ( tree - > root , " idt " , " foo " ) , " foo " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_find_str ( tree - > root , " physical_volumes/pv0/bb " , " foo " ) , " foo " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_find_str ( tree - > root , " physical_volumes/pv0/id " , " foo " ) , " abcd-efgh " ) ) ;
CU_ASSERT ( ! dm_config_get_uint32 ( tree - > root , " id " , NULL ) ) ;
CU_ASSERT ( dm_config_get_uint32 ( tree - > root , " extent_size " , NULL ) ) ;
/* FIXME: Currently everything parses as a list, even if it's not */
// CU_ASSERT(!dm_config_get_list(tree->root, "id", NULL));
// CU_ASSERT(!dm_config_get_list(tree->root, "extent_size", NULL));
CU_ASSERT ( dm_config_get_list ( tree - > root , " flags " , & value ) ) ;
2011-12-11 19:45:14 +04:00
CU_ASSERT ( value - > next = = NULL ) ; /* an empty list */
2011-12-11 19:19:41 +04:00
CU_ASSERT ( dm_config_get_list ( tree - > root , " status " , & value ) ) ;
2011-12-11 19:45:14 +04:00
CU_ASSERT ( value - > next ! = NULL ) ; /* a non-empty list */
2011-12-11 19:19:41 +04:00
dm_config_destroy ( tree ) ;
}
2011-12-13 16:08:42 +04:00
static void test_clone ( void )
2011-12-11 19:45:14 +04:00
{
struct dm_config_tree * tree = dm_config_from_string ( conf ) ;
struct dm_config_node * n = dm_config_clone_node ( tree , tree - > root , 1 ) ;
2011-12-13 16:08:42 +04:00
const struct dm_config_value * value ;
2011-12-11 19:45:14 +04:00
/* Check that the nodes are actually distinct. */
CU_ASSERT ( n ! = tree - > root ) ;
CU_ASSERT ( n - > sib ! = tree - > root - > sib ) ;
CU_ASSERT ( dm_config_find_node ( n , " physical_volumes " ) ! = NULL ) ;
CU_ASSERT ( dm_config_find_node ( tree - > root , " physical_volumes " ) ! = NULL ) ;
CU_ASSERT ( dm_config_find_node ( n , " physical_volumes " ) ! = dm_config_find_node ( tree - > root , " physical_volumes " ) ) ;
CU_ASSERT ( dm_config_has_node ( n , " id " ) ) ;
CU_ASSERT ( dm_config_has_node ( n , " physical_volumes " ) ) ;
CU_ASSERT ( dm_config_has_node ( n , " physical_volumes/pv0 " ) ) ;
CU_ASSERT ( dm_config_has_node ( n , " physical_volumes/pv0/id " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_find_str ( n , " id " , " foo " ) , " yada-yada " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_find_str ( n , " idt " , " foo " ) , " foo " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_find_str ( n , " physical_volumes/pv0/bb " , " foo " ) , " foo " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_find_str ( n , " physical_volumes/pv0/id " , " foo " ) , " abcd-efgh " ) ) ;
CU_ASSERT ( ! dm_config_get_uint32 ( n , " id " , NULL ) ) ;
CU_ASSERT ( dm_config_get_uint32 ( n , " extent_size " , NULL ) ) ;
/* FIXME: Currently everything parses as a list, even if it's not */
// CU_ASSERT(!dm_config_get_list(tree->root, "id", NULL));
// CU_ASSERT(!dm_config_get_list(tree->root, "extent_size", NULL));
CU_ASSERT ( dm_config_get_list ( n , " flags " , & value ) ) ;
CU_ASSERT ( value - > next = = NULL ) ; /* an empty list */
CU_ASSERT ( dm_config_get_list ( n , " status " , & value ) ) ;
CU_ASSERT ( value - > next ! = NULL ) ; /* a non-empty list */
2011-12-13 16:08:42 +04:00
dm_config_destroy ( tree ) ;
2011-12-11 19:45:14 +04:00
}
2012-01-09 16:29:15 +04:00
static void test_cascade ( void )
2011-12-19 03:56:36 +04:00
{
struct dm_config_tree * t1 = dm_config_from_string ( conf ) ,
* t2 = dm_config_from_string ( overlay ) ,
* tree = dm_config_insert_cascaded_tree ( t2 , t1 ) ;
CU_ASSERT ( ! strcmp ( dm_config_tree_find_str ( tree , " id " , " foo " ) , " yoda-soda " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_tree_find_str ( tree , " idt " , " foo " ) , " foo " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_tree_find_str ( tree , " physical_volumes/pv0/bb " , " foo " ) , " foo " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_tree_find_str ( tree , " physical_volumes/pv1/id " , " foo " ) , " hgfe-dcba " ) ) ;
CU_ASSERT ( ! strcmp ( dm_config_tree_find_str ( tree , " physical_volumes/pv3/id " , " foo " ) , " dbcd-efgh " ) ) ;
dm_config_destroy ( t1 ) ;
dm_config_destroy ( t2 ) ;
}
2011-12-11 19:19:41 +04:00
CU_TestInfo config_list [ ] = {
{ ( char * ) " parse " , test_parse } ,
2011-12-11 19:45:14 +04:00
{ ( char * ) " clone " , test_clone } ,
2011-12-19 03:56:36 +04:00
{ ( char * ) " cascade " , test_cascade } ,
2011-12-11 19:19:41 +04:00
CU_TEST_INFO_NULL
} ;