RISC-V: Make compliance tests more verbose (#366)
Currently the RISC-V compliance test suite doesn't output the test is currently runs before it succeeds. It also uses the same message for many tests. This makes it very hard to find out which test fails. This commit makes things slightly easier by printing the test that's being executed before it actually runs, and by adding the source code line where the test is located, making it easier to look up the test in the source code. New output looks like this: Info : Executing test 149 (riscv-013.c:3800): Regular calls must return ERROR_OK Info : PASSED
This commit is contained in:
parent
45b5178b1a
commit
44f595b2b8
|
@ -3687,14 +3687,22 @@ void riscv013_clear_abstract_error(struct target *target)
|
||||||
dmi_write(target, DMI_ABSTRACTCS, abstractcs & DMI_ABSTRACTCS_CMDERR);
|
dmi_write(target, DMI_ABSTRACTCS, abstractcs & DMI_ABSTRACTCS_CMDERR);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
#define FILE_SEP '\\'
|
||||||
|
#else
|
||||||
|
#define FILE_SEP '/'
|
||||||
|
#endif
|
||||||
#define COMPLIANCE_TEST(b, message) \
|
#define COMPLIANCE_TEST(b, message) \
|
||||||
{ \
|
{ \
|
||||||
|
const char *last_sep = strrchr(__FILE__, FILE_SEP); \
|
||||||
|
const char *fname = (last_sep == NULL ? __FILE__ : last_sep + 1); \
|
||||||
|
LOG_INFO("Executing test %d (%s:%d): %s", total_tests, fname, __LINE__, message); \
|
||||||
int pass = 0; \
|
int pass = 0; \
|
||||||
if (b) { \
|
if (b) { \
|
||||||
pass = 1; \
|
pass = 1; \
|
||||||
passed_tests++; \
|
passed_tests++; \
|
||||||
} \
|
} \
|
||||||
LOG_INFO("%s test %d (%s)\n", (pass) ? "PASSED" : "FAILED", total_tests, message); \
|
LOG_INFO(" %s", (pass) ? "PASSED" : "FAILED"); \
|
||||||
assert(pass); \
|
assert(pass); \
|
||||||
total_tests++; \
|
total_tests++; \
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue