Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp4792280pxv; Tue, 29 Jun 2021 16:09:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyBZfD/UT4DzAzeR7HlriV5dsr3BbFyiD/JelN6wdDd00qIma28OwYpcaN+du2yLfjLkFNP X-Received: by 2002:a05:6e02:156a:: with SMTP id k10mr24046500ilu.111.1625008149554; Tue, 29 Jun 2021 16:09:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625008149; cv=none; d=google.com; s=arc-20160816; b=SyQ2o8JpOmCC8mbP5YBt3+8ZySwhtQ/e/TO//s4zc6Eb1bwYfqJfGIWLHdgBHXOJm8 1gvvvOk4QriMY/vlMokYtMowQCfM1DVgp5x7zlajBmeAJ3NHFs1L7p0ag+Wxlzph8I5Z als0Gd5K3rvZRSaNDLVCCev9zC23ClzU+xBhrzJ7+8lzaqso4+t8il/VbvT++nsEupeq /AMdVJX4RvP3azsB/FWSNzjkPiuswIVmMip1CPksnLKecvN2GHuVZ1Afg1c4qgLFh6F0 wCtvGGrDBRJPnL2CldhAiryp1jvZ8xiwK0GXgPvjDbwc83vOEJlrJb6fbacybsGMqOVe rlsA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:mime-version:message-id:date :dkim-signature; bh=/RPrCqh+rOfDnT4G/SOpYmqYgDt2JAlmOPqvnVY5n0w=; b=x2yPkwGExG6C9yA+9iwJXC8CZRW/3DpqnNxT9boNa1js6Zj27sTlD9Fh46mXgiaSAA M5KS5lK/W/xmW1RB2FvG/NVs4ko7fTufm67CZArt6nCzJirqidxiz7B+5hMonjtcUagT scnqjsFPG6tFBPMnrCsZmhuDBVNZptPu4XKADl/mwN0zA6bjLrnXlLFlWhb6QYL3F+Sq vCAJole1nxfWxEsk0aaN6lZ+NYiefSoI/KMU7rVjGH0gBLU4sYhMRutKI8x9a3IDMu0M lK6zIh+puKwpqh2cd6SII/26/DcdI1AYjy+dfbvIuTjUFek8eNQvRsmea6QqrlPc3jDH pLcA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=emGqpWKm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j12si22611041jar.85.2021.06.29.16.08.52; Tue, 29 Jun 2021 16:09:09 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=emGqpWKm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235171AbhF2Wif (ORCPT + 99 others); Tue, 29 Jun 2021 18:38:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41464 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233056AbhF2Wie (ORCPT ); Tue, 29 Jun 2021 18:38:34 -0400 Received: from mail-yb1-xb49.google.com (mail-yb1-xb49.google.com [IPv6:2607:f8b0:4864:20::b49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 51464C061760 for ; Tue, 29 Jun 2021 15:36:06 -0700 (PDT) Received: by mail-yb1-xb49.google.com with SMTP id v17-20020a25c5110000b0290553ebda4e3cso1082905ybe.22 for ; Tue, 29 Jun 2021 15:36:06 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:message-id:mime-version:subject:from:to:cc; bh=/RPrCqh+rOfDnT4G/SOpYmqYgDt2JAlmOPqvnVY5n0w=; b=emGqpWKmsfN3bT/21P0Nhr95ossixYcitudVZ44grSNCtrNDTT9udoWEDUHZO8tFRX 0xf2+NXg2kI0vx2EkB/DHNI6GAYeYwmJQG37XDiHEmqvRxFhY5y8Bt09N4lPrWJUxhpc 7BTlEmYBku8KCZGOy1tNncnud1gSJObQZz2miaq9lBRJpwhLSbjAWx18/8+i0azQqpkX tzY2aQxZbCKPW775ak3WXA0uCwd/4w1DH7NjMHF2rJ2O0CXXRvJzk49DST3mLI1D+wkA oTaPLQ3tNYUfWnmZ4oElLmt2Eba1/nNyevgzn04Oi4oKahIklYKQvsl6WeAP4S8E5M6N VjSw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=/RPrCqh+rOfDnT4G/SOpYmqYgDt2JAlmOPqvnVY5n0w=; b=FvDySkycq+PPEc5j8A3stsaLRRW940gL0n8zJ4JamDDKaERjguvZ+Ly/9isVB+0qP5 uhMpGLw6hYLUZCfyx1P/QxFP09J5f7pGzrdqfcQ2OPpCHNPiZry/G3zFbfz4orq0oAil 4FCsRL0bFmMladW4KX7VLEbYCiEOp/tqEOuF8zbsztryRBoiTrE0OJ/ALpRi9cgN8HUN dHKq2BVMVd40I+Lg6KYqGs7QYrMk4Rj8k0imlM7teaPd2VYmJA9SXjYqGr4a7+mlj4Mt U8qXyIi5ARukba4TIzOKV+A3u0rpXogaY7dysqj/0OnnQ5zPsHam4rkiqDZNzChqRwVj Jn4A== X-Gm-Message-State: AOAM533R8Mc3BBOxug1ts77oxG1ZOvjYUQdYUTZJkak8hdPBbnptMTfm i6XoiZLW5LTikLwKQzAsGxkfFY3gjA== X-Received: from sunrae.c.googlers.com ([fda3:e722:ac3:cc00:7f:e700:c0a8:2814]) (user=rmoar job=sendgmr) by 2002:a05:6902:1546:: with SMTP id r6mr7109291ybu.418.1625006165304; Tue, 29 Jun 2021 15:36:05 -0700 (PDT) Date: Tue, 29 Jun 2021 22:35:41 +0000 Message-Id: <20210629223541.1512296-1-rmoar@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.32.0.93.g670b81a890-goog Subject: [PATCH] kunit: tool: Fix error messages for cases of no tests and wrong TAP header From: Rae Moar To: brendanhiggins@google.com, davidgow@google.com, dlatypov@google.com, shuah@kernel.org Cc: kunit-dev@googlegroups.com, linux-kselftest@vger.kernel.org, linux-kernel@vger.kernel.org, Rae Moar Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In the case of the TAP output having an incorrect header format, the parser used to output an error message of 'no tests run!'. Additionally, in the case of TAP output with the correct header but no tests, the parser used to output an error message of 'could not parse test results!'. This patch corrects the error messages for these two cases by switching the original outputted error messages and correcting the tests in kunit_toot_test.py. Signed-off-by: Rae Moar --- tools/testing/kunit/kunit_parser.py | 6 +- tools/testing/kunit/kunit_tool_test.py | 16 +++- ...is_test_passed-no_tests_run_no_header.log} | 0 ...s_test_passed-no_tests_run_with_header.log | 77 +++++++++++++++++++ 4 files changed, 94 insertions(+), 5 deletions(-) rename tools/testing/kunit/test_data/{test_is_test_passed-no_tests_run.log => test_is_test_passed-no_tests_run_no_header.log} (100%) create mode 100644 tools/testing/kunit/test_data/test_is_test_passed-no_tests_run_with_header.log diff --git a/tools/testing/kunit/kunit_parser.py b/tools/testing/kunit/kunit_parser.py index c3c524b79db8..b88db3f51dc5 100644 --- a/tools/testing/kunit/kunit_parser.py +++ b/tools/testing/kunit/kunit_parser.py @@ -338,9 +338,11 @@ def bubble_up_suite_errors(test_suites: Iterable[TestSuite]) -> TestStatus: def parse_test_result(lines: LineStream) -> TestResult: consume_non_diagnostic(lines) if not lines or not parse_tap_header(lines): - return TestResult(TestStatus.NO_TESTS, [], lines) + return TestResult(TestStatus.FAILURE_TO_PARSE_TESTS, [], lines) expected_test_suite_num = parse_test_plan(lines) - if not expected_test_suite_num: + if expected_test_suite_num == 0: + return TestResult(TestStatus.NO_TESTS, [], lines) + elif expected_test_suite_num is None: return TestResult(TestStatus.FAILURE_TO_PARSE_TESTS, [], lines) test_suites = [] for i in range(1, expected_test_suite_num + 1): diff --git a/tools/testing/kunit/kunit_tool_test.py b/tools/testing/kunit/kunit_tool_test.py index bdae0e5f6197..75045aa0f8a1 100755 --- a/tools/testing/kunit/kunit_tool_test.py +++ b/tools/testing/kunit/kunit_tool_test.py @@ -157,8 +157,18 @@ class KUnitParserTest(unittest.TestCase): kunit_parser.TestStatus.FAILURE, result.status) + def test_no_header(self): + empty_log = test_data_path('test_is_test_passed-no_tests_run_no_header.log') + with open(empty_log) as file: + result = kunit_parser.parse_run_tests( + kunit_parser.extract_tap_lines(file.readlines())) + self.assertEqual(0, len(result.suites)) + self.assertEqual( + kunit_parser.TestStatus.FAILURE_TO_PARSE_TESTS, + result.status) + def test_no_tests(self): - empty_log = test_data_path('test_is_test_passed-no_tests_run.log') + empty_log = test_data_path('test_is_test_passed-no_tests_run_with_header.log') with open(empty_log) as file: result = kunit_parser.parse_run_tests( kunit_parser.extract_tap_lines(file.readlines())) @@ -173,7 +183,7 @@ class KUnitParserTest(unittest.TestCase): with open(crash_log) as file: result = kunit_parser.parse_run_tests( kunit_parser.extract_tap_lines(file.readlines())) - print_mock.assert_any_call(StrContains('no tests run!')) + print_mock.assert_any_call(StrContains('could not parse test results!')) print_mock.stop() file.close() @@ -309,7 +319,7 @@ class KUnitJsonTest(unittest.TestCase): result["sub_groups"][1]["test_cases"][0]) def test_no_tests_json(self): - result = self._json_for('test_is_test_passed-no_tests_run.log') + result = self._json_for('test_is_test_passed-no_tests_run_with_header.log') self.assertEqual(0, len(result['sub_groups'])) class StrContains(str): diff --git a/tools/testing/kunit/test_data/test_is_test_passed-no_tests_run.log b/tools/testing/kunit/test_data/test_is_test_passed-no_tests_run_no_header.log similarity index 100% rename from tools/testing/kunit/test_data/test_is_test_passed-no_tests_run.log rename to tools/testing/kunit/test_data/test_is_test_passed-no_tests_run_no_header.log diff --git a/tools/testing/kunit/test_data/test_is_test_passed-no_tests_run_with_header.log b/tools/testing/kunit/test_data/test_is_test_passed-no_tests_run_with_header.log new file mode 100644 index 000000000000..18215b236783 --- /dev/null +++ b/tools/testing/kunit/test_data/test_is_test_passed-no_tests_run_with_header.log @@ -0,0 +1,77 @@ +Core dump limits : + soft - 0 + hard - NONE +Checking environment variables for a tempdir...none found +Checking if /dev/shm is on tmpfs...OK +Checking PROT_EXEC mmap in /dev/shm...OK +Adding 24743936 bytes to physical memory to account for exec-shield gap +Linux version 4.12.0-rc3-00010-g7319eb35f493-dirty (brendanhiggins@mactruck.svl.corp.google.com) (gcc version 7.3.0 (Debian 7.3.0-5) ) #29 Thu Mar 15 14:57:19 PDT 2018 +Built 1 zonelists in Zone order, mobility grouping on. Total pages: 14038 +Kernel command line: root=98:0 +PID hash table entries: 256 (order: -1, 2048 bytes) +Dentry cache hash table entries: 8192 (order: 4, 65536 bytes) +Inode-cache hash table entries: 4096 (order: 3, 32768 bytes) +Memory: 27868K/56932K available (1681K kernel code, 480K rwdata, 400K rodata, 89K init, 205K bss, 29064K reserved, 0K cma-reserved) +SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=1, Nodes=1 +NR_IRQS:15 +clocksource: timer: mask: 0xffffffffffffffff max_cycles: 0x1cd42e205, max_idle_ns: 881590404426 ns +Calibrating delay loop... 7384.26 BogoMIPS (lpj=36921344) +pid_max: default: 32768 minimum: 301 +Mount-cache hash table entries: 512 (order: 0, 4096 bytes) +Mountpoint-cache hash table entries: 512 (order: 0, 4096 bytes) +Checking that host ptys support output SIGIO...Yes +Checking that host ptys support SIGIO on close...No, enabling workaround +Using 2.6 host AIO +clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns +futex hash table entries: 256 (order: 0, 6144 bytes) +clocksource: Switched to clocksource timer +console [stderr0] disabled +mconsole (version 2) initialized on /usr/local/google/home/brendanhiggins/.uml/6Ijecl/mconsole +Checking host MADV_REMOVE support...OK +workingset: timestamp_bits=62 max_order=13 bucket_order=0 +Block layer SCSI generic (bsg) driver version 0.4 loaded (major 254) +io scheduler noop registered +io scheduler deadline registered +io scheduler cfq registered (default) +io scheduler mq-deadline registered +io scheduler kyber registered +Initialized stdio console driver +Using a channel type which is configured out of UML +setup_one_line failed for device 1 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 2 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 3 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 4 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 5 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 6 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 7 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 8 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 9 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 10 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 11 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 12 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 13 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 14 : Configuration failed +Using a channel type which is configured out of UML +setup_one_line failed for device 15 : Configuration failed +Console initialized on /dev/tty0 +console [tty0] enabled +console [mc-1] enabled +TAP version 14 +1..0 +List of all partitions: +No filesystem could mount root, tried: + +Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(98,0) -- 2.32.0.93.g670b81a890-goog