test-ref-configs: clarify configuration-related traces

When doing builds with PSA enabled or with debug traces enabled, convey this
in $MBEDTLS_TEST_CONFIGURATION and in the terminal logs.

This fixes a bug that the outcome file did not distinguish entries from
test cases run in a reference configuration with or without PSA.

Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
This commit is contained in:
Gilles Peskine 2022-03-14 19:05:48 +01:00
parent 20e25b9012
commit def0e147ab

View file

@ -97,25 +97,27 @@ if (!-e "tests/seedfile" || -s "tests/seedfile" < 64) {
} }
sub perform_test { sub perform_test {
my $conf = $_[0]; my $conf_file = $_[0];
my $data = $_[1]; my $data = $_[1];
my $test_with_psa = $_[2]; my $test_with_psa = $_[2];
my $conf_name = $conf_file;
if ( $test_with_psa )
{
$conf_name .= "+PSA";
}
system( "cp $config_h.bak $config_h" ) and die; system( "cp $config_h.bak $config_h" ) and die;
system( "make clean" ) and die; system( "make clean" ) and die;
print "\n******************************************\n"; print "\n******************************************\n";
print "* Testing configuration: $conf\n"; print "* Testing configuration: $conf_name\n";
if ( $test_with_psa )
{
print "* ENABLING MBEDTLS_PSA_CRYPTO_C and MBEDTLS_USE_PSA_CRYPTO \n";
}
print "******************************************\n"; print "******************************************\n";
$ENV{MBEDTLS_TEST_CONFIGURATION} = $conf; $ENV{MBEDTLS_TEST_CONFIGURATION} = $conf_name;
system( "cp configs/$conf $config_h" ) system( "cp configs/$conf_file $config_h" )
and abort "Failed to activate $conf\n"; and abort "Failed to activate $conf_file\n";
if ( $test_with_psa ) if ( $test_with_psa )
{ {
@ -123,19 +125,19 @@ sub perform_test {
system( "scripts/config.py set MBEDTLS_USE_PSA_CRYPTO" ); system( "scripts/config.py set MBEDTLS_USE_PSA_CRYPTO" );
} }
system( "CFLAGS='-Os -Werror -Wall -Wextra' make" ) and abort "Failed to build: $conf\n"; system( "CFLAGS='-Os -Werror -Wall -Wextra' make" ) and abort "Failed to build: $conf_name\n";
system( "make test" ) and abort "Failed test suite: $conf\n"; system( "make test" ) and abort "Failed test suite: $conf_name\n";
my $compat = $data->{'compat'}; my $compat = $data->{'compat'};
if( $compat ) if( $compat )
{ {
print "\nrunning compat.sh $compat\n"; print "\nrunning compat.sh $compat ($conf_name)\n";
system( "tests/compat.sh $compat" ) system( "tests/compat.sh $compat" )
and abort "Failed compat.sh: $conf\n"; and abort "Failed compat.sh: $conf_name\n";
} }
else else
{ {
print "\nskipping compat.sh\n"; print "\nskipping compat.sh ($conf_name)\n";
} }
my $opt = $data->{'opt'}; my $opt = $data->{'opt'};
@ -143,20 +145,22 @@ sub perform_test {
{ {
if( $data->{'opt_needs_debug'} ) if( $data->{'opt_needs_debug'} )
{ {
print "\nrebuilding with debug traces for ssl-opt\n"; print "\nrebuilding with debug traces for ssl-opt ($conf_name)\n";
$conf_name .= '+DEBUG';
$ENV{MBEDTLS_TEST_CONFIGURATION} = $conf_name;
system( "make clean" ); system( "make clean" );
system( "scripts/config.py set MBEDTLS_DEBUG_C" ); system( "scripts/config.py set MBEDTLS_DEBUG_C" );
system( "scripts/config.py set MBEDTLS_ERROR_C" ); system( "scripts/config.py set MBEDTLS_ERROR_C" );
system( "CFLAGS='-Os -Werror -Wall -Wextra' make" ) and abort "Failed to build: $conf +debug\n"; system( "CFLAGS='-Os -Werror -Wall -Wextra' make" ) and abort "Failed to build: $conf_name\n";
} }
print "\nrunning ssl-opt.sh $opt\n"; print "\nrunning ssl-opt.sh $opt ($conf_name)\n";
system( "tests/ssl-opt.sh $opt" ) system( "tests/ssl-opt.sh $opt" )
and abort "Failed ssl-opt.sh: $conf\n"; and abort "Failed ssl-opt.sh: $conf_name\n";
} }
else else
{ {
print "\nskipping ssl-opt.sh\n"; print "\nskipping ssl-opt.sh ($conf_name)\n";
} }
} }