2012-09-14 15:46:57 +08:00
/*
2013-08-16 12:12:55 +02:00
* virbitmaptest . c : Test the bitmap code
*
2013-02-01 17:33:18 -07:00
* Copyright ( C ) 2013 Red Hat , Inc .
2012-09-14 15:46:57 +08:00
* Copyright ( C ) 2012 Fujitsu .
*
* 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-09-14 15:46:57 +08:00
* < http : //www.gnu.org/licenses/>.
*
*/
# include <config.h>
# include "testutils.h"
2012-12-04 11:56:32 +00:00
# include "virbitmap.h"
2012-09-14 15:46:57 +08:00
2013-08-16 12:12:55 +02:00
static int
test1 ( const void * data ATTRIBUTE_UNUSED )
2012-09-14 15:46:57 +08:00
{
virBitmapPtr bitmap ;
int size ;
int bit ;
bool result ;
2013-01-22 17:09:28 -05:00
int ret = - 1 ;
2012-09-14 15:46:57 +08:00
size = 1024 ;
bit = 100 ;
2013-01-22 17:09:28 -05:00
if ( ! ( bitmap = virBitmapNew ( size ) ) )
goto error ;
2012-09-14 15:46:57 +08:00
if ( virBitmapSetBit ( bitmap , bit ) < 0 )
2013-01-22 17:09:28 -05:00
goto error ;
2012-09-14 15:46:57 +08:00
if ( virBitmapGetBit ( bitmap , bit , & result ) < 0 )
2013-01-22 17:09:28 -05:00
goto error ;
2012-09-14 15:46:57 +08:00
if ( ! result )
2013-01-22 17:09:28 -05:00
goto error ;
2012-09-14 15:46:57 +08:00
if ( virBitmapGetBit ( bitmap , bit + 1 , & result ) < 0 )
2013-01-22 17:09:28 -05:00
goto error ;
2012-09-14 15:46:57 +08:00
if ( result )
2013-01-22 17:09:28 -05:00
goto error ;
2012-09-14 15:46:57 +08:00
2013-01-22 17:09:28 -05:00
ret = 0 ;
2014-03-25 07:53:44 +01:00
error :
2013-01-22 17:09:28 -05:00
virBitmapFree ( bitmap ) ;
return ret ;
2012-09-14 15:46:57 +08:00
}
static int
testBit ( virBitmapPtr bitmap ,
unsigned int start ,
unsigned int end ,
bool expected )
{
Convert 'int i' to 'size_t i' in tests/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
size_t i ;
2012-09-14 15:46:57 +08:00
bool result ;
for ( i = start ; i < = end ; i + + ) {
if ( virBitmapGetBit ( bitmap , i , & result ) < 0 )
return - 1 ;
if ( result = = expected )
return 0 ;
}
return - 1 ;
}
2013-08-16 12:12:55 +02:00
static int
test2 ( const void * data ATTRIBUTE_UNUSED )
2012-09-14 15:46:57 +08:00
{
const char * bitsString1 = " 1-32,50,88-99,1021-1023 " ;
char * bitsString2 = NULL ;
virBitmapPtr bitmap = NULL ;
int ret = - 1 ;
int size = 1025 ;
if ( virBitmapParse ( bitsString1 , 0 , & bitmap , size ) < 0 )
goto error ;
if ( testBit ( bitmap , 1 , 32 , true ) < 0 )
goto error ;
if ( testBit ( bitmap , 50 , 50 , true ) < 0 )
goto error ;
if ( testBit ( bitmap , 88 , 99 , true ) < 0 )
goto error ;
if ( testBit ( bitmap , 1021 , 1023 , true ) < 0 )
goto error ;
if ( testBit ( bitmap , 0 , 0 , false ) < 0 )
goto error ;
if ( testBit ( bitmap , 33 , 49 , false ) < 0 )
goto error ;
if ( testBit ( bitmap , 51 , 87 , false ) < 0 )
goto error ;
if ( testBit ( bitmap , 100 , 1020 , false ) < 0 )
goto error ;
2012-10-24 18:44:27 -06:00
if ( virBitmapCountBits ( bitmap ) ! = 48 )
goto error ;
2013-01-22 17:09:28 -05:00
if ( ! ( bitsString2 = virBitmapFormat ( bitmap ) ) )
goto error ;
2012-09-14 15:46:57 +08:00
if ( strcmp ( bitsString1 , bitsString2 ) )
goto error ;
virBitmapSetAll ( bitmap ) ;
if ( testBit ( bitmap , 0 , size - 1 , true ) < 0 )
goto error ;
2012-10-24 18:44:27 -06:00
if ( virBitmapCountBits ( bitmap ) ! = size )
goto error ;
2012-09-14 15:46:57 +08:00
if ( ! virBitmapIsAllSet ( bitmap ) )
goto error ;
virBitmapClearAll ( bitmap ) ;
2013-04-06 02:06:16 +08:00
if ( ! virBitmapIsAllClear ( bitmap ) )
goto error ;
2012-09-14 15:46:57 +08:00
if ( testBit ( bitmap , 0 , size - 1 , false ) < 0 )
goto error ;
2012-10-24 18:44:27 -06:00
if ( virBitmapCountBits ( bitmap ) ! = 0 )
goto error ;
2012-09-14 15:46:57 +08:00
ret = 0 ;
2014-03-25 07:53:44 +01:00
error :
2012-09-14 15:46:57 +08:00
virBitmapFree ( bitmap ) ;
VIR_FREE ( bitsString2 ) ;
return ret ;
}
2013-08-16 12:12:55 +02:00
static int
test3 ( const void * data ATTRIBUTE_UNUSED )
2012-09-14 15:46:57 +08:00
{
virBitmapPtr bitmap = NULL ;
int ret = - 1 ;
int size = 5 ;
Convert 'int i' to 'size_t i' in tests/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
size_t i ;
2012-09-14 15:46:57 +08:00
if ( ( bitmap = virBitmapNew ( size ) ) = = NULL )
goto error ;
for ( i = 0 ; i < size ; i + + )
ignore_value ( virBitmapSetBit ( bitmap , i ) ) ;
if ( ! virBitmapIsAllSet ( bitmap ) )
goto error ;
2013-04-06 02:06:16 +08:00
virBitmapClearAll ( bitmap ) ;
if ( ! virBitmapIsAllClear ( bitmap ) )
goto error ;
2012-09-14 15:46:57 +08:00
ret = 0 ;
2014-03-25 07:53:44 +01:00
error :
2012-09-14 15:46:57 +08:00
virBitmapFree ( bitmap ) ;
return ret ;
}
2013-02-01 17:33:18 -07:00
/* test for virBitmapNextSetBit, virBitmapNextClearBit */
2013-08-16 12:12:55 +02:00
static int
test4 ( const void * data ATTRIBUTE_UNUSED )
2012-09-14 15:46:57 +08:00
{
const char * bitsString = " 0, 2-4, 6-10, 12, 14-18, 20, 22, 25 " ;
int size = 40 ;
int bitsPos [ ] = {
0 , 2 , 3 , 4 , 6 , 7 , 8 , 9 , 10 , 12 ,
14 , 15 , 16 , 17 , 18 , 20 , 22 , 25
} ;
2013-02-01 17:33:18 -07:00
int bitsPosInv [ ] = {
1 , 5 , 11 , 13 , 19 , 21 , 23 , 24 , 26 , 27 ,
28 , 29 , 30 , 31 , 32 , 33 , 34 , 35 , 36 , 37 , 38 , 39
} ;
2012-09-14 15:46:57 +08:00
virBitmapPtr bitmap = NULL ;
Convert 'int i' to 'size_t i' in tests/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
ssize_t i , j ;
2012-09-14 15:46:57 +08:00
2013-02-01 17:33:18 -07:00
if ( ARRAY_CARDINALITY ( bitsPos ) + ARRAY_CARDINALITY ( bitsPosInv ) ! = size )
goto error ;
2012-09-14 15:46:57 +08:00
/* 1. zero set */
bitmap = virBitmapNew ( size ) ;
if ( ! bitmap )
goto error ;
2013-02-01 17:33:18 -07:00
if ( virBitmapNextSetBit ( bitmap , - 1 ) ! = - 1 )
goto error ;
for ( i = 0 ; i < size ; i + + ) {
if ( virBitmapNextClearBit ( bitmap , i - 1 ) ! = i )
goto error ;
}
if ( virBitmapNextClearBit ( bitmap , i ) ! = - 1 )
2012-09-14 15:46:57 +08:00
goto error ;
2013-04-06 02:06:16 +08:00
if ( ! virBitmapIsAllClear ( bitmap ) )
goto error ;
2012-09-14 15:46:57 +08:00
virBitmapFree ( bitmap ) ;
bitmap = NULL ;
/* 2. partial set */
if ( virBitmapParse ( bitsString , 0 , & bitmap , size ) < 0 )
goto error ;
if ( ! bitmap )
goto error ;
j = 0 ;
i = - 1 ;
2013-02-01 17:33:18 -07:00
while ( j < ARRAY_CARDINALITY ( bitsPos ) ) {
2012-09-14 15:46:57 +08:00
i = virBitmapNextSetBit ( bitmap , i ) ;
if ( i ! = bitsPos [ j + + ] )
goto error ;
}
2013-02-01 17:33:18 -07:00
if ( virBitmapNextSetBit ( bitmap , i ) ! = - 1 )
goto error ;
j = 0 ;
i = - 1 ;
while ( j < ARRAY_CARDINALITY ( bitsPosInv ) ) {
i = virBitmapNextClearBit ( bitmap , i ) ;
if ( i ! = bitsPosInv [ j + + ] )
goto error ;
}
if ( virBitmapNextClearBit ( bitmap , i ) ! = - 1 )
2012-09-14 15:46:57 +08:00
goto error ;
/* 3. full set */
virBitmapSetAll ( bitmap ) ;
2013-02-01 17:33:18 -07:00
for ( i = 0 ; i < size ; i + + ) {
if ( virBitmapNextSetBit ( bitmap , i - 1 ) ! = i )
2012-09-14 15:46:57 +08:00
goto error ;
}
2013-02-01 17:33:18 -07:00
if ( virBitmapNextSetBit ( bitmap , i ) ! = - 1 )
goto error ;
2012-09-14 15:46:57 +08:00
2013-02-01 17:33:18 -07:00
if ( virBitmapNextClearBit ( bitmap , - 1 ) ! = - 1 )
2012-09-14 15:46:57 +08:00
goto error ;
virBitmapFree ( bitmap ) ;
return 0 ;
2014-03-25 07:53:44 +01:00
error :
2012-09-14 15:46:57 +08:00
virBitmapFree ( bitmap ) ;
return - 1 ;
}
/* test for virBitmapNewData/ToData */
2013-08-16 12:12:55 +02:00
static int
test5 ( const void * v ATTRIBUTE_UNUSED )
2012-09-14 15:46:57 +08:00
{
2012-09-18 17:20:03 -06:00
char data [ ] = { 0x01 , 0x02 , 0x00 , 0x00 , 0x04 } ;
2012-09-14 15:46:57 +08:00
unsigned char * data2 = NULL ;
int len2 ;
2012-09-18 17:20:03 -06:00
int bits [ ] = { 0 , 9 , 34 } ;
2012-09-14 15:46:57 +08:00
virBitmapPtr bitmap ;
Convert 'int i' to 'size_t i' in tests/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
size_t i ;
ssize_t j ;
2012-09-14 15:46:57 +08:00
int ret = - 1 ;
2012-09-18 17:20:03 -06:00
bitmap = virBitmapNewData ( data , sizeof ( data ) ) ;
2012-09-14 15:46:57 +08:00
if ( ! bitmap )
goto error ;
i = 0 ;
j = - 1 ;
while ( i < sizeof ( bits ) / sizeof ( int ) & &
( j = virBitmapNextSetBit ( bitmap , j ) ) > = 0 ) {
if ( j ! = bits [ i + + ] )
goto error ;
}
if ( virBitmapNextSetBit ( bitmap , j ) > 0 )
goto error ;
ignore_value ( virBitmapSetBit ( bitmap , 2 ) ) ;
ignore_value ( virBitmapSetBit ( bitmap , 15 ) ) ;
if ( virBitmapToData ( bitmap , & data2 , & len2 ) < 0 )
goto error ;
2012-09-18 17:20:03 -06:00
if ( len2 ! = sizeof ( data ) | |
data2 [ 0 ] ! = 0x05 | |
2012-09-14 15:46:57 +08:00
data2 [ 1 ] ! = 0x82 | |
data2 [ 2 ] ! = 0x00 | |
2012-09-18 17:20:03 -06:00
data2 [ 3 ] ! = 0x00 | |
data2 [ 4 ] ! = 0x04 )
2012-09-14 15:46:57 +08:00
goto error ;
ret = 0 ;
2014-03-25 07:53:44 +01:00
error :
2012-09-14 15:46:57 +08:00
virBitmapFree ( bitmap ) ;
VIR_FREE ( data2 ) ;
return ret ;
}
/* test for virBitmapFormat */
2013-08-16 12:12:55 +02:00
static int
test6 ( const void * v ATTRIBUTE_UNUSED )
2012-09-14 15:46:57 +08:00
{
virBitmapPtr bitmap = NULL ;
char * str = NULL ;
int size = 64 ;
int ret = - 1 ;
bitmap = virBitmapNew ( size ) ;
if ( ! bitmap )
goto error ;
str = virBitmapFormat ( bitmap ) ;
if ( ! str )
goto error ;
if ( ! STREQ ( str , " " ) )
goto error ;
VIR_FREE ( str ) ;
ignore_value ( virBitmapSetBit ( bitmap , 0 ) ) ;
str = virBitmapFormat ( bitmap ) ;
if ( ! str )
goto error ;
if ( ! STREQ ( str , " 0 " ) )
goto error ;
VIR_FREE ( str ) ;
ignore_value ( virBitmapSetBit ( bitmap , 4 ) ) ;
ignore_value ( virBitmapSetBit ( bitmap , 5 ) ) ;
str = virBitmapFormat ( bitmap ) ;
if ( ! str )
goto error ;
if ( ! STREQ ( str , " 0,4-5 " ) )
goto error ;
VIR_FREE ( str ) ;
ignore_value ( virBitmapSetBit ( bitmap , 6 ) ) ;
str = virBitmapFormat ( bitmap ) ;
if ( ! str )
goto error ;
if ( ! STREQ ( str , " 0,4-6 " ) )
goto error ;
VIR_FREE ( str ) ;
ignore_value ( virBitmapSetBit ( bitmap , 13 ) ) ;
ignore_value ( virBitmapSetBit ( bitmap , 14 ) ) ;
ignore_value ( virBitmapSetBit ( bitmap , 15 ) ) ;
ignore_value ( virBitmapSetBit ( bitmap , 16 ) ) ;
str = virBitmapFormat ( bitmap ) ;
if ( ! str )
goto error ;
if ( ! STREQ ( str , " 0,4-6,13-16 " ) )
goto error ;
VIR_FREE ( str ) ;
ignore_value ( virBitmapSetBit ( bitmap , 62 ) ) ;
ignore_value ( virBitmapSetBit ( bitmap , 63 ) ) ;
str = virBitmapFormat ( bitmap ) ;
if ( ! str )
goto error ;
if ( ! STREQ ( str , " 0,4-6,13-16,62-63 " ) )
goto error ;
ret = 0 ;
2014-03-25 07:53:44 +01:00
error :
2012-09-14 15:46:57 +08:00
virBitmapFree ( bitmap ) ;
VIR_FREE ( str ) ;
return ret ;
}
2013-08-16 12:12:55 +02:00
static int
test7 ( const void * v ATTRIBUTE_UNUSED )
2012-11-28 14:15:38 +08:00
{
virBitmapPtr bitmap ;
size_t i ;
size_t maxBit [ ] = {
1 , 8 , 31 , 32 , 63 , 64 , 95 , 96 , 127 , 128 , 159 , 160
} ;
size_t nmaxBit = 12 ;
for ( i = 0 ; i < nmaxBit ; i + + ) {
bitmap = virBitmapNew ( maxBit [ i ] ) ;
if ( ! bitmap )
goto error ;
if ( virBitmapIsAllSet ( bitmap ) )
goto error ;
ignore_value ( virBitmapSetBit ( bitmap , 1 ) ) ;
if ( virBitmapIsAllSet ( bitmap ) )
goto error ;
virBitmapSetAll ( bitmap ) ;
if ( ! virBitmapIsAllSet ( bitmap ) )
goto error ;
2013-04-06 02:06:16 +08:00
virBitmapClearAll ( bitmap ) ;
if ( ! virBitmapIsAllClear ( bitmap ) )
goto error ;
2012-11-28 14:15:38 +08:00
virBitmapFree ( bitmap ) ;
}
return 0 ;
2014-03-25 07:53:44 +01:00
error :
2012-11-28 14:15:38 +08:00
virBitmapFree ( bitmap ) ;
return - 1 ;
}
2013-08-16 12:12:55 +02:00
static int
test8 ( const void * v ATTRIBUTE_UNUSED )
2013-04-06 02:06:16 +08:00
{
virBitmapPtr bitmap = NULL ;
char data [ 108 ] = { 0x00 , } ;
2013-04-15 11:50:59 -04:00
int ret = - 1 ;
2013-04-06 02:06:16 +08:00
bitmap = virBitmapNewData ( data , sizeof ( data ) ) ;
if ( ! bitmap )
2013-04-15 11:50:59 -04:00
goto cleanup ;
2013-04-06 02:06:16 +08:00
if ( ! virBitmapIsAllClear ( bitmap ) )
2013-04-15 11:50:59 -04:00
goto cleanup ;
2013-04-06 02:06:16 +08:00
if ( virBitmapSetBit ( bitmap , 11 ) < 0 )
2013-04-15 11:50:59 -04:00
goto cleanup ;
2013-04-06 02:06:16 +08:00
if ( virBitmapIsAllClear ( bitmap ) )
2013-04-15 11:50:59 -04:00
goto cleanup ;
2013-04-06 02:06:16 +08:00
2013-04-15 11:50:59 -04:00
ret = 0 ;
2014-03-25 07:53:44 +01:00
cleanup :
2013-04-06 02:06:16 +08:00
virBitmapFree ( bitmap ) ;
2013-04-15 11:50:59 -04:00
return ret ;
2013-04-06 02:06:16 +08:00
}
2013-08-16 12:13:27 +02:00
/* test out of bounds conditions on virBitmapParse */
static int
test9 ( const void * opaque ATTRIBUTE_UNUSED )
{
int ret = - 1 ;
2013-08-19 14:02:52 +02:00
virBitmapPtr bitmap = NULL ;
2013-08-16 12:13:27 +02:00
if ( virBitmapParse ( " 100000000 " , 0 , & bitmap , 20 ) ! = - 1 )
goto cleanup ;
if ( bitmap )
goto cleanup ;
if ( virBitmapParse ( " 1-1000000000 " , 0 , & bitmap , 20 ) ! = - 1 )
goto cleanup ;
if ( bitmap )
goto cleanup ;
if ( virBitmapParse ( " 1-10^10000000000 " , 0 , & bitmap , 20 ) ! = - 1 )
goto cleanup ;
if ( bitmap )
goto cleanup ;
ret = 0 ;
2014-03-25 07:53:44 +01:00
cleanup :
2013-08-19 14:02:52 +02:00
virBitmapFree ( bitmap ) ;
2013-08-16 12:13:27 +02:00
return ret ;
}
2012-09-14 15:46:57 +08:00
static int
mymain ( void )
{
int ret = 0 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test1 " , test1 , NULL ) < 0 )
2012-09-14 15:46:57 +08:00
ret = - 1 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test2 " , test2 , NULL ) < 0 )
2012-09-14 15:46:57 +08:00
ret = - 1 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test3 " , test3 , NULL ) < 0 )
2012-09-14 15:46:57 +08:00
ret = - 1 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test4 " , test4 , NULL ) < 0 )
2012-09-14 15:46:57 +08:00
ret = - 1 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test5 " , test5 , NULL ) < 0 )
2012-09-14 15:46:57 +08:00
ret = - 1 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test6 " , test6 , NULL ) < 0 )
2012-09-14 15:46:57 +08:00
ret = - 1 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test7 " , test7 , NULL ) < 0 )
2012-11-28 14:15:38 +08:00
ret = - 1 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test8 " , test8 , NULL ) < 0 )
2013-04-06 02:06:16 +08:00
ret = - 1 ;
2013-09-20 19:13:35 +01:00
if ( virtTestRun ( " test9 " , test9 , NULL ) < 0 )
2013-08-16 12:13:27 +02:00
ret = - 1 ;
2012-09-14 15:46:57 +08:00
return ret ;
}
VIRT_TEST_MAIN ( mymain )