-
Notifications
You must be signed in to change notification settings - Fork 5.6k
/
Copy pathtest_simple_report.py
111 lines (96 loc) · 3.95 KB
/
test_simple_report.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
"""Simple_report test."""
import os
import random
import sys
import textwrap
import unittest
from unittest.mock import mock_open, patch
from click.testing import CliRunner
import buildscripts.simple_report
def ns(name): # pylint: disable=invalid-name
return f"buildscripts.simple_report.{name}"
def fix_newlines(string: str) -> str:
# These need to be CRLF newlines on Windows, so we split and rejoin
# on os.linesep to fix that
return os.linesep.join(string.splitlines())
class TestSimpleReport(unittest.TestCase):
def __init__(self, *args, **kwargs):
super(TestSimpleReport, self).__init__(*args, **kwargs)
self.seed = random.randrange(sys.maxsize)
self.rng = random.Random(self.seed)
def test_trivial_report(self):
"""Run test 100x with randomly generated error codes."""
print(f"TestSimpleReport.test_trivial_report seed: {self.seed}")
for _ in range(0, 100):
self._test_trivial_report() # pylint: disable=no-value-for-parameter
@patch(ns("try_combine_reports"))
@patch(ns("_clean_log_file"))
@patch(ns("put_report"))
def _test_trivial_report(self, mock_put_report, mock_clean_log_file, _mock_try_combine_reports):
exit_code = self.rng.randint(0, 254)
print(f"Trying exit code: {exit_code}")
mock_clean_log_file.return_value = "I'm a little test log, short and stdout."
runner = CliRunner()
result = runner.invoke(
buildscripts.simple_report.main,
["--test-name", "potato", "--log-file", "test.log", "--exit-code", str(exit_code)],
)
report = mock_put_report.call_args[0][0]
results = mock_put_report.call_args[0][0]["results"]
if exit_code == 0:
self.assertEqual(results[0]["status"], "pass")
self.assertEqual(report["failures"], 0)
else:
self.assertEqual(results[0]["status"], "fail")
self.assertEqual(report["failures"], 1)
self.assertEqual(result.exit_code, 0)
@patch(ns("try_combine_reports"))
@patch(ns("put_report"))
def test_truncate_scons(self, mock_put_report, _mock_try_combine_reports):
exit_code = 0
data = fix_newlines(
textwrap.dedent("""\
TO BE TRUNCATED
TO BE TRUNCATED
TO BE TRUNCATED
TO BE TRUNCATED
scons: done reading SConscript files.
scons: Building targets ...
interesting part""")
)
with patch("builtins.open", mock_open(read_data=data)) as _mock_file:
runner = CliRunner()
result = runner.invoke(
buildscripts.simple_report.main,
["--test-name", "potato", "--log-file", "test.log", "--exit-code", str(exit_code)],
)
report = mock_put_report.call_args[0][0]
results = mock_put_report.call_args[0][0]["results"]
self.assertEqual(results[0]["status"], "pass")
self.assertEqual(results[0]["log_raw"], "interesting part")
self.assertEqual(report["failures"], 0)
self.assertEqual(result.exit_code, 0)
@patch(ns("try_combine_reports"))
@patch(ns("put_report"))
def test_non_scons_log(self, mock_put_report, _mock_try_combine_reports):
exit_code = 0
data = fix_newlines(
textwrap.dedent("""\
*NOT* TO BE TRUNCATED
*NOT* TO BE TRUNCATED
*NOT* TO BE TRUNCATED
*NOT* TO BE TRUNCATED
interesting part""")
)
with patch("builtins.open", mock_open(read_data=data)) as _mock_file:
runner = CliRunner()
result = runner.invoke(
buildscripts.simple_report.main,
["--test-name", "potato", "--log-file", "test.log", "--exit-code", str(exit_code)],
)
report = mock_put_report.call_args[0][0]
results = mock_put_report.call_args[0][0]["results"]
self.assertEqual(results[0]["status"], "pass")
self.assertEqual(results[0]["log_raw"], data)
self.assertEqual(report["failures"], 0)
self.assertEqual(result.exit_code, 0)