summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorArkadiusz Hiler <arkadiusz.hiler@intel.com>2020-05-04 14:26:21 +0300
committerArkadiusz Hiler <arkadiusz.hiler@intel.com>2020-05-05 15:29:05 +0300
commit57e041880397a493ace7afe2b0db0427f950950a (patch)
treee98b2f6d6e6ad308efe053d81c76ec16c05e3259 /lib
parente630cb8cd2ec01d6d5358eb2a3f6ea70498b8183 (diff)
lib/igt_core: Make assert on invalid magic blocks nesting more verbose
Instead of ending the execution with cryptic assert let's actually print a message explaining the reason and point towards igt_core's documentation. I am sticking with assert() instead of abort() because of the semi-useful stacktraces it produces. Signed-off-by: Arkadiusz Hiler <arkadiusz.hiler@intel.com> Reviewed-by: Petri Latvala <petri.latvala@intel.com>
Diffstat (limited to 'lib')
-rw-r--r--lib/igt_core.c55
1 files changed, 42 insertions, 13 deletions
diff --git a/lib/igt_core.c b/lib/igt_core.c
index bb8d0177..96af7492 100644
--- a/lib/igt_core.c
+++ b/lib/igt_core.c
@@ -343,6 +343,21 @@ static bool stderr_needs_sentinel = false;
static int _igt_dynamic_tests_executed = -1;
+__attribute__((format(printf, 2, 3)))
+static void internal_assert(bool cond, const char *format, ...)
+{
+ if (!cond) {
+ va_list ap;
+
+ va_start(ap, format);
+ vfprintf(stderr, format, ap);
+ va_end(ap);
+ fprintf(stderr, "please refer to lib/igt_core documentation\n");
+
+ assert(0);
+ }
+}
+
const char *igt_test_name(void)
{
return command_str;
@@ -540,8 +555,12 @@ uint64_t igt_nsec_elapsed(struct timespec *start)
bool __igt_fixture(void)
{
- assert(!in_fixture);
- assert(test_with_subtests);
+ internal_assert(!in_fixture,
+ "nesting multiple igt_fixtures is invalid\n");
+ internal_assert(!in_subtest,
+ "nesting igt_fixture in igt_subtest is invalid\n");
+ internal_assert(test_with_subtests,
+ "igt_fixture in igt_simple_main is invalid\n");
if (igt_only_list_subtests())
return false;
@@ -1202,7 +1221,9 @@ static bool valid_name_for_subtest(const char *subtest_name)
*/
bool __igt_run_subtest(const char *subtest_name, const char *file, const int line)
{
- assert(!igt_can_fail());
+ internal_assert(!igt_can_fail(),
+ "igt_subtest can be nested only in igt_main"
+ " or igt_subtest_group\n");
if (!valid_name_for_subtest(subtest_name)) {
igt_critical("Invalid subtest name \"%s\".\n",
@@ -1257,8 +1278,8 @@ bool __igt_run_subtest(const char *subtest_name, const char *file, const int lin
bool __igt_run_dynamic_subtest(const char *dynamic_subtest_name)
{
- assert(in_subtest);
- assert(_igt_dynamic_tests_executed >= 0);
+ internal_assert(in_subtest && _igt_dynamic_tests_executed >= 0,
+ "igt_dynamic is allowed only inside igt_subtest_with_dynamic\n");
if (!valid_name_for_subtest(dynamic_subtest_name)) {
igt_critical("Invalid dynamic subtest name \"%s\".\n",
@@ -1311,7 +1332,8 @@ bool igt_only_list_subtests(void)
void __igt_subtest_group_save(int *save, int *desc)
{
- assert(test_with_subtests);
+ internal_assert(test_with_subtests,
+ "igt_subtest_group is not allowed in igt_simple_main\n");
if (__current_description[0] != '\0') {
struct description_node *new = calloc(1, sizeof(*new));
@@ -1414,7 +1436,8 @@ void igt_skip(const char *f, ...)
va_list args;
skipped_one = true;
- assert(!test_child);
+ internal_assert(!test_child,
+ "skips are not allowed in forks\n");
if (!igt_only_list_subtests()) {
va_start(args, f);
@@ -1427,7 +1450,9 @@ void igt_skip(const char *f, ...)
exit_subtest("SKIP");
} else if (test_with_subtests) {
skip_subtests_henceforth = SKIP;
- assert(in_fixture);
+ internal_assert(in_fixture,
+ "skipping is allowed only in fixtures, subtests"
+ " or igt_simple_main\n");
__igt_fixture_end();
} else {
igt_exitcode = IGT_EXIT_SKIP;
@@ -1547,7 +1572,8 @@ void igt_fail(int exitcode)
if (in_subtest) {
exit_subtest("FAIL");
} else {
- assert(igt_can_fail());
+ internal_assert(igt_can_fail(), "failing test is only allowed"
+ " in fixtures, subtests and igt_simple_main");
if (in_fixture) {
skip_subtests_henceforth = FAIL;
@@ -1612,8 +1638,9 @@ void igt_describe_f(const char *fmt, ...)
int ret;
va_list args;
- if (in_subtest && _igt_dynamic_tests_executed >= 0)
- assert(!"Documenting dynamic subsubtests is impossible. Document the subtest instead.");
+ internal_assert(!in_subtest || _igt_dynamic_tests_executed < 0,
+ "documenting dynamic subsubtests is impossible,"
+ " document the subtest instead.");
if (!describe_subtests)
return;
@@ -2224,8 +2251,10 @@ static void children_exit_handler(int sig)
bool __igt_fork(void)
{
- assert(!test_with_subtests || in_subtest);
- assert(!test_child);
+ internal_assert(!test_with_subtests || in_subtest,
+ "forking is only allowed in subtests or igt_simple_main\n");
+ internal_assert(!test_child,
+ "forking is not allowed from already forked children\n");
igt_install_exit_handler(children_exit_handler);