diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2021-09-10 12:39:44 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2021-09-23 22:13:53 +0100 |
commit | d08c9290e82fb26d958991592ef801d07393f69d (patch) | |
tree | 4caf4522e5c4247188c8513b8c8b2c379110671b | |
parent | 7d0437c4e8063362d9ca127dbd439208fe6ebda4 (diff) | |
download | poky-d08c9290e82fb26d958991592ef801d07393f69d.tar.gz |
oeqa/selftest: Add tests for bitbake shell/python task output
We've seen issues where shell/python tasks lose their log file entries
or output and also where output is duplicated. Add some tests to attempt
to spot regressions in this area in future.
(From OE-Core rev: 414020a9bd656ee61efe2f47db1b31d86b15c1c8)
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta-selftest/recipes-test/logging-test/logging-test.bb | 24 | ||||
-rw-r--r-- | meta/lib/oeqa/selftest/cases/bblogging.py | 104 |
2 files changed, 128 insertions, 0 deletions
diff --git a/meta-selftest/recipes-test/logging-test/logging-test.bb b/meta-selftest/recipes-test/logging-test/logging-test.bb new file mode 100644 index 0000000000..a6100123f9 --- /dev/null +++ b/meta-selftest/recipes-test/logging-test/logging-test.bb | |||
@@ -0,0 +1,24 @@ | |||
1 | SUMMARY = "Destined to fail" | ||
2 | LICENSE = "CLOSED" | ||
3 | |||
4 | deltask do_patch | ||
5 | INHIBIT_DEFAULT_DEPS = "1" | ||
6 | |||
7 | do_shelltest() { | ||
8 | echo "This is shell stdout" | ||
9 | echo "This is shell stderr" >&2 | ||
10 | exit 1 | ||
11 | } | ||
12 | addtask do_shelltest | ||
13 | |||
14 | python do_pythontest_exit () { | ||
15 | print("This is python stdout") | ||
16 | sys.exit(1) | ||
17 | } | ||
18 | addtask do_pythontest_exit | ||
19 | |||
20 | python do_pythontest_fatal () { | ||
21 | print("This is python fatal test stdout") | ||
22 | bb.fatal("This is a fatal error") | ||
23 | } | ||
24 | addtask do_pythontest_fatal | ||
diff --git a/meta/lib/oeqa/selftest/cases/bblogging.py b/meta/lib/oeqa/selftest/cases/bblogging.py new file mode 100644 index 0000000000..ea6c3c8c77 --- /dev/null +++ b/meta/lib/oeqa/selftest/cases/bblogging.py | |||
@@ -0,0 +1,104 @@ | |||
1 | # | ||
2 | # SPDX-License-Identifier: MIT | ||
3 | # | ||
4 | |||
5 | |||
6 | from oeqa.selftest.case import OESelftestTestCase | ||
7 | from oeqa.utils.commands import bitbake | ||
8 | |||
9 | class BitBakeLogging(OESelftestTestCase): | ||
10 | |||
11 | def assertCount(self, item, entry, count): | ||
12 | self.assertEqual(item.count(entry), count, msg="Output:\n'''\n%s\n'''\ndoesn't contain %d copies of:\n'''\n%s\n'''\n" % (item, count, entry)) | ||
13 | |||
14 | def test_shell_logging(self): | ||
15 | # no logs, no verbose | ||
16 | self.write_config('BBINCLUDELOGS = ""') | ||
17 | result = bitbake("logging-test -c shelltest -f", ignore_status = True) | ||
18 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
19 | self.assertNotIn("This is shell stdout", result.output) | ||
20 | self.assertNotIn("This is shell stderr", result.output) | ||
21 | |||
22 | # logs, no verbose | ||
23 | self.write_config('BBINCLUDELOGS = "yes"') | ||
24 | result = bitbake("logging-test -c shelltest -f", ignore_status = True) | ||
25 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
26 | self.assertCount(result.output, "This is shell stdout", 1) | ||
27 | self.assertCount(result.output, "This is shell stderr", 1) | ||
28 | |||
29 | # no logs, verbose | ||
30 | self.write_config('BBINCLUDELOGS = ""') | ||
31 | result = bitbake("logging-test -c shelltest -f -v", ignore_status = True) | ||
32 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
33 | # two copies due to set +x | ||
34 | self.assertCount(result.output, "This is shell stdout", 2) | ||
35 | self.assertCount(result.output, "This is shell stderr", 2) | ||
36 | |||
37 | # logs, verbose | ||
38 | self.write_config('BBINCLUDELOGS = "yes"') | ||
39 | result = bitbake("logging-test -c shelltest -f -v", ignore_status = True) | ||
40 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
41 | # two copies due to set +x | ||
42 | self.assertCount(result.output, "This is shell stdout", 2) | ||
43 | self.assertCount(result.output, "This is shell stderr", 2) | ||
44 | |||
45 | def test_python_exit_logging(self): | ||
46 | # no logs, no verbose | ||
47 | self.write_config('BBINCLUDELOGS = ""') | ||
48 | result = bitbake("logging-test -c pythontest_exit -f", ignore_status = True) | ||
49 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
50 | self.assertNotIn("This is python stdout", result.output) | ||
51 | |||
52 | # logs, no verbose | ||
53 | self.write_config('BBINCLUDELOGS = "yes"') | ||
54 | result = bitbake("logging-test -c pythontest_exit -f", ignore_status = True) | ||
55 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
56 | # A sys.exit() should include the output | ||
57 | self.assertCount(result.output, "This is python stdout", 1) | ||
58 | |||
59 | # no logs, verbose | ||
60 | self.write_config('BBINCLUDELOGS = ""') | ||
61 | result = bitbake("logging-test -c pythontest_exit -f -v", ignore_status = True) | ||
62 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
63 | # python tasks don't log output with -v currently | ||
64 | #self.assertCount(result.output, "This is python stdout", 1) | ||
65 | |||
66 | # logs, verbose | ||
67 | self.write_config('BBINCLUDELOGS = "yes"') | ||
68 | result = bitbake("logging-test -c pythontest_exit -f -v", ignore_status = True) | ||
69 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
70 | # python tasks don't log output with -v currently | ||
71 | #self.assertCount(result.output, "This is python stdout", 1) | ||
72 | |||
73 | def test_python_fatal_logging(self): | ||
74 | # no logs, no verbose | ||
75 | self.write_config('BBINCLUDELOGS = ""') | ||
76 | result = bitbake("logging-test -c pythontest_fatal -f", ignore_status = True) | ||
77 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
78 | self.assertNotIn("This is python fatal test stdout", result.output) | ||
79 | self.assertCount(result.output, "This is a fatal error", 1) | ||
80 | |||
81 | # logs, no verbose | ||
82 | self.write_config('BBINCLUDELOGS = "yes"') | ||
83 | result = bitbake("logging-test -c pythontest_fatal -f", ignore_status = True) | ||
84 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
85 | # A bb.fatal() should not include the output | ||
86 | self.assertNotIn("This is python fatal test stdout", result.output) | ||
87 | self.assertCount(result.output, "This is a fatal error", 1) | ||
88 | |||
89 | # no logs, verbose | ||
90 | self.write_config('BBINCLUDELOGS = ""') | ||
91 | result = bitbake("logging-test -c pythontest_fatal -f -v", ignore_status = True) | ||
92 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
93 | # python tasks don't log output with -v currently | ||
94 | #self.assertCount(result.output, "This is python fatal test stdout", 1) | ||
95 | self.assertCount(result.output, "This is a fatal error", 1) | ||
96 | |||
97 | # logs, verbose | ||
98 | self.write_config('BBINCLUDELOGS = "yes"') | ||
99 | result = bitbake("logging-test -c pythontest_fatal -f -v", ignore_status = True) | ||
100 | self.assertIn("ERROR: Logfile of failure stored in:", result.output) | ||
101 | # python tasks don't log output with -v currently | ||
102 | #self.assertCount(result.output, "This is python fatal test stdout", 1) | ||
103 | self.assertCount(result.output, "This is a fatal error", 1) | ||
104 | |||