Testing: Fix memory leaks

This commit is contained in:
Shahram Najm 2022-11-07 12:22:49 +00:00
parent 3255222392
commit 59f12626f1
1 changed files with 22 additions and 16 deletions

View File

@ -1584,7 +1584,9 @@ static void test_parse_keyval_string()
int err = 0; int err = 0;
int values_required = 1; int values_required = 1;
int count = 0; int count = 0;
grib_values values[128] = {0,}; grib_values values1[128] = {0,};
grib_values values2[128] = {0,};
grib_values values3[128] = {0,};
const int max_count = 128; const int max_count = 128;
char input1[] = "key1=value1,key2!=value2"; char input1[] = "key1=value1,key2!=value2";
char input2[] = "x=14"; char input2[] = "x=14";
@ -1594,35 +1596,39 @@ static void test_parse_keyval_string()
count = max_count; count = max_count;
err = parse_keyval_string(NULL, input1, err = parse_keyval_string(NULL, input1,
values_required, GRIB_TYPE_UNDEFINED, values, &count); values_required, GRIB_TYPE_UNDEFINED, values1, &count);
Assert( !err ); Assert( !err );
Assert( count == 2 ); Assert( count == 2 );
Assert( strcmp(values[0].name, "key1")==0 ); Assert( strcmp(values1[0].name, "key1")==0 );
Assert( strcmp(values[0].string_value, "value1")==0 ); Assert( strcmp(values1[0].string_value, "value1")==0 );
Assert( values[0].equal == 1 ); Assert( values1[0].equal == 1 );
Assert( strcmp(values[1].name, "key2")==0 ); Assert( strcmp(values1[1].name, "key2")==0 );
Assert( strcmp(values[1].string_value, "value2")==0 ); Assert( strcmp(values1[1].string_value, "value2")==0 );
Assert( values[1].equal == 0 ); Assert( values1[1].equal == 0 );
/* Note how the input is modified by the tokenizer (thanks to strtok_r) */ /* Note how the input is modified by the tokenizer (thanks to strtok_r) */
Assert( strcmp(input1, "key1=value1")==0 ); Assert( strcmp(input1, "key1=value1")==0 );
free( (void*)values1[0].name );
free( (void*)values1[1].name );
free( (void*)values1[0].string_value );
free( (void*)values1[1].string_value );
count = max_count; count = max_count;
err = parse_keyval_string(NULL, input2, err = parse_keyval_string(NULL, input2,
values_required, GRIB_TYPE_LONG, values, &count); values_required, GRIB_TYPE_LONG, values2, &count);
Assert( !err ); Assert( !err );
Assert( count == 1 ); Assert( count == 1 );
Assert( strcmp(values[0].name, "x")==0 ); Assert( strcmp(values2[0].name, "x")==0 );
Assert( values[0].long_value == 14 ); Assert( values2[0].long_value == 14 );
Assert( values[0].equal == 1 ); Assert( values2[0].equal == 1 );
Assert( strcmp(values[1].name, "key2")==0 ); free( (void*)values2[0].name );
count = max_count; count = max_count;
err = parse_keyval_string(NULL, input3, err = parse_keyval_string(NULL, input3,
values_required, GRIB_TYPE_DOUBLE, values, &count); values_required, GRIB_TYPE_DOUBLE, values3, &count);
Assert( !err ); Assert( !err );
Assert( count == 1 ); Assert( count == 1 );
Assert( strcmp(values[0].name, "mars.level")==0 ); Assert( strcmp(values3[0].name, "mars.level")==0 );
free( (void*)values3[0].name );
} }
int main(int argc, char** argv) int main(int argc, char** argv)