2014-04-08 15:44:40 +01:00
/*
* viralloctest . c : Test memory allocation APIs
*
* Copyright ( C ) 2014 Red Hat , Inc .
*
* 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
* License along with this library . If not , see
* < http : //www.gnu.org/licenses/>.
*
*/
# include <config.h>
# include <viralloc.h>
# include "testutils.h"
# define VIR_FROM_THIS VIR_FROM_NONE
typedef struct testDummyStruct {
int a ;
int b ;
} testDummyStruct ;
static int
testCheckNonNull ( void * t )
{
if ( t = = NULL ) {
fprintf ( stderr , " Allocation succeeded but pointer is NULL \n " ) ;
return - 1 ;
}
return 0 ;
}
static int
2019-10-14 14:45:03 +02:00
testReallocArray ( const void * opaque G_GNUC_UNUSED )
2014-04-08 15:44:40 +01:00
{
testDummyStruct * t ;
size_t nt = 10 , i ;
int ret = - 1 ;
2020-10-08 13:49:50 +02:00
t = g_new0 ( testDummyStruct , nt ) ;
2014-04-08 15:44:40 +01:00
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < nt ; i + + ) {
t [ i ] . a = 10 ;
t [ i ] . b = 20 ;
}
if ( VIR_REALLOC_N ( t , nt + 5 ) < 0 )
goto cleanup ;
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < nt ; i + + ) {
if ( t [ i ] . a ! = 10 | |
t [ i ] . b ! = 20 ) {
fprintf ( stderr , " Reallocated ram block %zu lost data \n " , i ) ;
goto cleanup ;
}
}
if ( VIR_REALLOC_N ( t , nt ) < 0 )
goto cleanup ;
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < nt ; i + + ) {
if ( t [ i ] . a ! = 10 | |
t [ i ] . b ! = 20 ) {
fprintf ( stderr , " Reallocated ram block %zu lost data \n " , i ) ;
goto cleanup ;
}
}
if ( VIR_REALLOC_N ( t , nt - 5 ) < 0 )
goto cleanup ;
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < ( nt - 5 ) ; i + + ) {
if ( t [ i ] . a ! = 10 | |
t [ i ] . b ! = 20 ) {
fprintf ( stderr , " Reallocated ram block %zu lost data \n " , i ) ;
goto cleanup ;
}
}
VIR_FREE ( t ) ;
if ( t ! = NULL ) {
fprintf ( stderr , " Pointer is still set after free \n " ) ;
goto cleanup ;
}
ret = 0 ;
cleanup :
VIR_FREE ( t ) ;
return ret ;
}
static int
2019-10-14 14:45:03 +02:00
testExpandArray ( const void * opaque G_GNUC_UNUSED )
2014-04-08 15:44:40 +01:00
{
testDummyStruct * t ;
size_t nt = 10 , i ;
int ret = - 1 ;
2020-10-08 13:49:50 +02:00
t = g_new0 ( testDummyStruct , nt ) ;
2014-04-08 15:44:40 +01:00
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < nt ; i + + ) {
t [ i ] . a = 10 ;
t [ i ] . b = 20 ;
}
if ( VIR_EXPAND_N ( t , nt , 5 ) < 0 )
goto cleanup ;
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < ( nt - 5 ) ; i + + ) {
if ( t [ i ] . a ! = 10 | |
t [ i ] . b ! = 20 ) {
fprintf ( stderr , " Reallocated ram block %zu lost data \n " , i ) ;
goto cleanup ;
}
}
for ( i = ( nt - 5 ) ; i < nt ; i + + ) {
if ( t [ i ] . a ! = 0 | |
t [ i ] . b ! = 0 ) {
fprintf ( stderr , " New ram block %zu was not zerod \n " , i ) ;
goto cleanup ;
}
}
VIR_SHRINK_N ( t , nt , 5 ) ;
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < nt ; i + + ) {
if ( t [ i ] . a ! = 10 | |
t [ i ] . b ! = 20 ) {
fprintf ( stderr , " Reallocated ram block %zu lost data \n " , i ) ;
goto cleanup ;
}
}
VIR_SHRINK_N ( t , nt , 5 ) ;
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < nt ; i + + ) {
if ( t [ i ] . a ! = 10 | |
t [ i ] . b ! = 20 ) {
fprintf ( stderr , " Reallocated ram block %zu lost data \n " , i ) ;
goto cleanup ;
}
}
VIR_FREE ( t ) ;
if ( t ! = NULL ) {
fprintf ( stderr , " Pointer is still set after free \n " ) ;
goto cleanup ;
}
ret = 0 ;
cleanup :
VIR_FREE ( t ) ;
return ret ;
}
static int
2019-10-14 14:45:03 +02:00
testResizeArray ( const void * opaque G_GNUC_UNUSED )
2014-04-08 15:44:40 +01:00
{
testDummyStruct * t ;
size_t nt = 10 , at , i ;
int ret = - 1 ;
2020-10-08 13:49:50 +02:00
t = g_new0 ( testDummyStruct , nt ) ;
2014-04-08 15:44:40 +01:00
at = nt ;
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < nt ; i + + ) {
t [ i ] . a = 10 ;
t [ i ] . b = 20 ;
}
if ( VIR_RESIZE_N ( t , at , nt , 8 ) < 0 )
goto cleanup ;
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
if ( at ! = 18 ) {
fprintf ( stderr , " Expected allocation of 16 not %zu \n " , at ) ;
goto cleanup ;
}
for ( i = 0 ; i < at ; i + + ) {
if ( i > = nt ) {
if ( t [ i ] . a ! = 0 | |
t [ i ] . b ! = 0 ) {
fprintf ( stderr , " New ram block %zu was not zerod \n " , i ) ;
goto cleanup ;
}
} else {
if ( t [ i ] . a ! = 10 | |
t [ i ] . b ! = 20 ) {
fprintf ( stderr , " Reallocated ram block %zu lost data \n " , i ) ;
goto cleanup ;
}
}
}
VIR_FREE ( t ) ;
if ( t ! = NULL ) {
fprintf ( stderr , " Pointer is still set after free \n " ) ;
goto cleanup ;
}
ret = 0 ;
cleanup :
VIR_FREE ( t ) ;
return ret ;
}
static int
2019-10-14 14:45:03 +02:00
testInsertArray ( const void * opaque G_GNUC_UNUSED )
2014-04-08 15:44:40 +01:00
{
testDummyStruct * * t ;
size_t nt = 10 , i ;
int ret = - 1 ;
testDummyStruct * n = ( void * ) 0xff ;
2020-10-08 13:50:00 +02:00
t = g_new0 ( testDummyStruct * , nt ) ;
2014-04-08 15:44:40 +01:00
if ( testCheckNonNull ( t ) < 0 )
goto cleanup ;
for ( i = 0 ; i < nt ; i + + )
t [ i ] = ( void * ) 0x50 ;
if ( VIR_INSERT_ELEMENT ( t , 3 , nt , n ) < 0 ) {
if ( nt ! = 10 ) {
fprintf ( stderr , " Expecting array size 10 after OOM not %zu \n " , nt ) ;
goto cleanup ;
}
goto cleanup ;
}
if ( nt ! = 11 ) {
fprintf ( stderr , " Expecting array size 11 not %zu \n " , nt ) ;
goto cleanup ;
}
if ( n ! = NULL ) {
fprintf ( stderr , " Expecting element to be set to NULL \n " ) ;
goto cleanup ;
}
for ( i = 0 ; i < nt ; i + + ) {
void * expect = i = = 3 ? ( void * ) 0xff : ( void * ) 0x50 ;
if ( t [ i ] ! = expect ) {
fprintf ( stderr , " Expecting %p at offset %zu not %p \n " ,
expect , i , t [ i ] ) ;
goto cleanup ;
}
}
VIR_FREE ( t ) ;
if ( t ! = NULL ) {
fprintf ( stderr , " Pointer is still set after free \n " ) ;
goto cleanup ;
}
ret = 0 ;
cleanup :
VIR_FREE ( t ) ;
return ret ;
}
2016-05-13 14:59:01 +02:00
static int
2019-10-14 14:45:03 +02:00
testDispose ( const void * opaque G_GNUC_UNUSED )
2016-05-13 14:59:01 +02:00
{
int * num = NULL ;
int * nums = NULL ;
size_t nnums = 0 ;
char * str = NULL ;
VIR_DISPOSE ( num ) ;
VIR_DISPOSE_N ( nums , nnums ) ;
VIR_DISPOSE_STRING ( str ) ;
nnums = 10 ;
VIR_DISPOSE_N ( nums , nnums ) ;
2020-10-08 13:49:50 +02:00
num = g_new0 ( int , 1 ) ;
2016-05-13 14:59:01 +02:00
VIR_DISPOSE ( num ) ;
nnums = 10 ;
2020-10-08 13:49:50 +02:00
nums = g_new0 ( int , nnums ) ;
2016-05-13 14:59:01 +02:00
VIR_DISPOSE_N ( nums , nnums ) ;
2019-10-20 13:49:46 +02:00
str = g_strdup ( " test " ) ;
2016-05-13 14:59:01 +02:00
VIR_DISPOSE_STRING ( str ) ;
return 0 ;
}
2014-04-08 15:44:40 +01:00
static int
mymain ( void )
{
int ret = 0 ;
2016-05-26 17:01:50 +02:00
if ( virTestRun ( " realloc array " , testReallocArray , NULL ) < 0 )
2014-04-08 15:44:40 +01:00
ret = - 1 ;
2016-05-26 17:01:50 +02:00
if ( virTestRun ( " expand array " , testExpandArray , NULL ) < 0 )
2014-04-08 15:44:40 +01:00
ret = - 1 ;
2016-05-26 17:01:50 +02:00
if ( virTestRun ( " resize array " , testResizeArray , NULL ) < 0 )
2014-04-08 15:44:40 +01:00
ret = - 1 ;
2016-05-26 17:01:50 +02:00
if ( virTestRun ( " insert array " , testInsertArray , NULL ) < 0 )
2014-04-08 15:44:40 +01:00
ret = - 1 ;
2016-05-26 17:01:50 +02:00
if ( virTestRun ( " dispose tests " , testDispose , NULL ) < 0 )
2016-05-13 14:59:01 +02:00
ret = - 1 ;
2014-04-08 15:44:40 +01:00
return ret = = 0 ? EXIT_SUCCESS : EXIT_FAILURE ;
}
2017-03-29 16:45:42 +02:00
VIR_TEST_MAIN ( mymain )