More detailed hydra test results
This commit is contained in:
parent
f3c6b647c0
commit
54e388a375
2 changed files with 30 additions and 3 deletions
|
@ -194,8 +194,10 @@ void CB2_TestRunner(void)
|
||||||
default: result = "UNKNOWN"; break;
|
default: result = "UNKNOWN"; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (gTestRunnerState.expectedResult == gTestRunnerState.result)
|
if (gTestRunnerState.result == TEST_RESULT_PASS)
|
||||||
MgbaPrintf_(":P%s%s\e[0m", color, result);
|
MgbaPrintf_(":P%s%s\e[0m", color, result);
|
||||||
|
else if (gTestRunnerState.expectedResult == gTestRunnerState.result)
|
||||||
|
MgbaPrintf_(":K%s%s\e[0m", color, result);
|
||||||
else
|
else
|
||||||
MgbaPrintf_(":F%s%s\e[0m", color, result);
|
MgbaPrintf_(":F%s%s\e[0m", color, result);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,11 @@
|
||||||
* COMMANDS
|
* COMMANDS
|
||||||
* N: Sets the test name to the remainder of the line.
|
* N: Sets the test name to the remainder of the line.
|
||||||
* R: Sets the result to the remainder of the line, and flushes any
|
* R: Sets the result to the remainder of the line, and flushes any
|
||||||
* output buffered since the previous R. */
|
* output buffered since the previous R.
|
||||||
|
*
|
||||||
|
* //Missing P, F and K documentation, please tell me what to put here lol
|
||||||
|
*
|
||||||
|
*/
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <poll.h>
|
#include <poll.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
|
@ -39,6 +43,7 @@ struct Runner
|
||||||
size_t output_buffer_capacity;
|
size_t output_buffer_capacity;
|
||||||
char *output_buffer;
|
char *output_buffer;
|
||||||
int passes;
|
int passes;
|
||||||
|
int knownFails;
|
||||||
int results;
|
int results;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -76,8 +81,11 @@ static void handle_read(struct Runner *runner)
|
||||||
|
|
||||||
case 'P':
|
case 'P':
|
||||||
case 'F':
|
case 'F':
|
||||||
|
case 'K':
|
||||||
if (soc[1] == 'P')
|
if (soc[1] == 'P')
|
||||||
runner->passes++;
|
runner->passes++;
|
||||||
|
else if (soc[1] == 'K')
|
||||||
|
runner->knownFails++;
|
||||||
runner->results++;
|
runner->results++;
|
||||||
soc += 2;
|
soc += 2;
|
||||||
fprintf(stdout, "%s: ", runner->test_name);
|
fprintf(stdout, "%s: ", runner->test_name);
|
||||||
|
@ -411,6 +419,7 @@ int main(int argc, char *argv[])
|
||||||
// Reap test runners and collate exit codes.
|
// Reap test runners and collate exit codes.
|
||||||
int exit_code = 0;
|
int exit_code = 0;
|
||||||
int passes = 0;
|
int passes = 0;
|
||||||
|
int knownFails = 0;
|
||||||
int results = 0;
|
int results = 0;
|
||||||
for (int i = 0; i < nrunners; i++)
|
for (int i = 0; i < nrunners; i++)
|
||||||
{
|
{
|
||||||
|
@ -425,9 +434,25 @@ int main(int argc, char *argv[])
|
||||||
if (WIFEXITED(wstatus) && WEXITSTATUS(wstatus) > exit_code)
|
if (WIFEXITED(wstatus) && WEXITSTATUS(wstatus) > exit_code)
|
||||||
exit_code = WEXITSTATUS(wstatus);
|
exit_code = WEXITSTATUS(wstatus);
|
||||||
passes += runners[i].passes;
|
passes += runners[i].passes;
|
||||||
|
knownFails += runners[i].knownFails;
|
||||||
results += runners[i].results;
|
results += runners[i].results;
|
||||||
}
|
}
|
||||||
fprintf(stdout, "%d/%d \e[32mPASS\e[0med\n", passes, results);
|
|
||||||
|
if (results == 0)
|
||||||
|
{
|
||||||
|
fprintf(stdout, "\nNo tests found.\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fprintf(stdout, "\n- Tests TOTAL: %d\n", results);
|
||||||
|
fprintf(stdout, "- Tests \e[32mPASSED: \e[0m %d\n", passes);
|
||||||
|
if (knownFails > 0)
|
||||||
|
fprintf(stdout, "- Tests \e[33mKNOWN_FAILING:\e[0m %d\n", knownFails);
|
||||||
|
if (passes + knownFails < results)
|
||||||
|
fprintf(stdout, "- Tests \e[31mFAILED: \e[0m %d\n", results - passes - knownFails);
|
||||||
|
}
|
||||||
|
fprintf(stdout, "\n");
|
||||||
|
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
return exit_code;
|
return exit_code;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue