2012-07-18 20:06:58 +01:00
/*
* storagebackendsheepdogtest . c : storage backend for Sheepdog handling
*
* Copyright ( C ) 2012 Sebastian Wiedenroth
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 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
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
2012-09-20 16:30:55 -06:00
* License along with this library . If not , see
2012-07-21 18:06:23 +08:00
* < http : //www.gnu.org/licenses/>.
2012-07-18 20:06:58 +01:00
*
* Author : Sebastian Wiedenroth < sebastian . wiedenroth @ skylime . net >
*/
# include <config.h>
# include <stdio.h>
# include <stdlib.h>
# include <unistd.h>
# include <string.h>
# include <fcntl.h>
# include "internal.h"
# include "testutils.h"
# include "storage/storage_backend_sheepdog.h"
typedef struct {
const char * output ;
int expected_return ;
uint64_t expected_capacity ;
uint64_t expected_allocation ;
} collie_test ;
static int
test_node_info_parser ( collie_test test , char * poolxml )
{
int ret = - 1 ;
char * output = NULL ;
char * poolXmlData = NULL ;
virStoragePoolDefPtr pool = NULL ;
if ( virtTestLoadFile ( poolxml , & poolXmlData ) < 0 )
goto cleanup ;
if ( ! ( pool = virStoragePoolDefParseString ( poolXmlData ) ) )
goto cleanup ;
output = strdup ( test . output ) ;
if ( ! output )
goto cleanup ;
if ( virStorageBackendSheepdogParseNodeInfo ( pool , output ) ! =
test . expected_return )
goto cleanup ;
if ( test . expected_return ) {
ret = 0 ;
goto cleanup ;
}
if ( pool - > capacity = = test . expected_capacity & &
pool - > allocation = = test . expected_allocation )
ret = 0 ;
cleanup :
VIR_FREE ( output ) ;
VIR_FREE ( poolXmlData ) ;
virStoragePoolDefFree ( pool ) ;
return ret ;
}
static int
test_vdi_list_parser ( collie_test test , char * poolxml , char * volxml )
{
int ret = - 1 ;
char * poolXmlData = NULL ;
char * volXmlData = NULL ;
char * output = NULL ;
virStoragePoolDefPtr pool = NULL ;
virStorageVolDefPtr vol = NULL ;
if ( virtTestLoadFile ( poolxml , & poolXmlData ) < 0 )
goto cleanup ;
if ( virtTestLoadFile ( volxml , & volXmlData ) < 0 )
goto cleanup ;
if ( ! ( pool = virStoragePoolDefParseString ( poolXmlData ) ) )
goto cleanup ;
if ( ! ( vol = virStorageVolDefParseString ( pool , volXmlData ) ) )
goto cleanup ;
output = strdup ( test . output ) ;
if ( ! output )
goto cleanup ;
if ( virStorageBackendSheepdogParseVdiList ( vol , output ) ! =
test . expected_return )
goto cleanup ;
if ( test . expected_return ) {
ret = 0 ;
goto cleanup ;
}
if ( vol - > capacity = = test . expected_capacity & &
vol - > allocation = = test . expected_allocation )
ret = 0 ;
cleanup :
VIR_FREE ( output ) ;
VIR_FREE ( poolXmlData ) ;
VIR_FREE ( volXmlData ) ;
virStoragePoolDefFree ( pool ) ;
virStorageVolDefFree ( vol ) ;
return ret ;
}
static int
mymain ( void )
{
int ret = - 1 ;
char * poolxml = NULL ;
char * volxml = NULL ;
collie_test node_info_tests [ ] = {
{ " " , - 1 , 0 , 0 } ,
{ " Total 15245667872 117571104 0% 20972341 \n " , 0 , 15245667872 , 117571104 } ,
{ " To " , - 1 , 0 , 0 } ,
{ " asdf \n asdf " , - 1 , 0 , 0 } ,
{ " Total " , - 1 , 0 , 0 } ,
{ " Total 1 " , - 1 , 0 , 0 } ,
{ " Total 1 \n " , - 1 , 0 , 0 } ,
{ " Total 1 " , - 1 , 0 , 0 } ,
{ " Total 1 2 " , - 1 , 0 , 0 } ,
{ " Total 1 2 " , - 1 , 0 , 0 } ,
{ " Total 1 2 \n " , 0 , 1 , 2 } ,
{ " Total 1 2 \n " , 0 , 1 , 2 } ,
{ " Total a 2 \n " , - 1 , 0 , 0 } ,
{ " Total 1 b \n " , - 1 , 0 , 0 } ,
{ " Total a b \n " , - 1 , 0 , 0 } ,
{ " stuff \n Total 1 2 \n " , 0 , 1 , 2 } ,
{ " 0 1 2 3 \n Total 1 2 \n " , 0 , 1 , 2 } ,
{ NULL , 0 , 0 , 0 }
} ;
collie_test vdi_list_tests [ ] = {
{ " " , - 1 , 0 , 0 } ,
{ " = test 3 10 20 0 1336557216 7c2b27 \n " , 0 , 10 , 20 } ,
{ " = test \\ with \\ spaces 3 10 20 0 1336557216 7c2b27 \n " , 0 , 10 , 20 } ,
{ " = backslashattheend \\ \\ 3 10 20 0 1336557216 7c2b27 \n " , 0 , 10 , 20 } ,
{ " s test 1 10 20 0 1336556634 7c2b25 \n = test 3 50 60 0 1336557216 7c2b27 \n " , 0 , 50 , 60 } ,
{ " = " , - 1 , 0 , 0 } ,
{ " = test " , - 1 , 0 , 0 } ,
{ " = test " , - 1 , 0 , 0 } ,
{ " = test 1 " , - 1 , 0 , 0 } ,
{ " = test 1 " , - 1 , 0 , 0 } ,
{ " = test 1 2 " , - 1 , 0 , 0 } ,
{ " = test 1 2 " , - 1 , 0 , 0 } ,
{ " = test 1 2 3 " , - 1 , 0 , 0 } ,
{ NULL , 0 , 0 , 0 }
} ;
collie_test * test = node_info_tests ;
if ( virAsprintf ( & poolxml , " %s/storagepoolxml2xmlin/pool-sheepdog.xml " ,
abs_srcdir ) < 0 )
goto cleanup ;
if ( virAsprintf ( & volxml , " %s/storagevolxml2xmlin/vol-sheepdog.xml " ,
abs_srcdir ) < 0 )
goto cleanup ;
while ( test - > output ! = NULL ) {
ret = test_node_info_parser ( * test , poolxml ) ;
virtTestResult ( " node_info_parser " , ret , NULL ) ;
+ + test ;
if ( ret < 0 )
return EXIT_FAILURE ;
}
test = vdi_list_tests ;
while ( test - > output ! = NULL ) {
ret = test_vdi_list_parser ( * test , poolxml , volxml ) ;
virtTestResult ( " vdi_list_parser " , ret , NULL ) ;
+ + test ;
if ( ret < 0 )
return EXIT_FAILURE ;
}
ret = 0 ;
cleanup :
VIR_FREE ( poolxml ) ;
VIR_FREE ( volxml ) ;
return ret = = 0 ? EXIT_SUCCESS : EXIT_FAILURE ;
}
VIRT_TEST_MAIN ( mymain )