Report the first failure, not the last one

If test_fail is called multiple times in the same test case, report
the location of the first failure, not the last one.

With this change, you no longer need to take care in tests that use
auxiliary functions not to fail in the main function if the auxiliary
function has failed.

Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
This commit is contained in:
Gilles Peskine 2020-08-31 10:21:58 +02:00
parent 934fe1ef18
commit d4c9fd1e0a

View File

@ -165,6 +165,12 @@ test_info;
void test_fail( const char *test, int line_no, const char* filename )
{
if( test_info.failed )
{
/* We've already recorded the test as having failed. Don't
* overwrite any previous information about the failure. */
return;
}
test_info.failed = 1;
test_info.test = test;
test_info.line_no = line_no;