diff options
| -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 | |||
