diff --git a/tests/__init__.py b/tests/__init__.py index c682229..c2f320b 100644 --- a/tests/__init__.py +++ b/tests/__init__.py @@ -172,3 +172,11 @@ class TestBase(unittest.TestCase): excuses = f.read() return (excuses, out) + + def create_hint(self, username, content): + '''Create a hint file for the given username and content''' + + hints_path = os.path.join( + self.data.path, 'data', self.data.series + '-proposed', 'Hints', username) + with open(hints_path, 'w') as fd: + fd.write(content) diff --git a/tests/test_autopkgtest.py b/tests/test_autopkgtest.py index 8cf626c..0b7c9f3 100644 --- a/tests/test_autopkgtest.py +++ b/tests/test_autopkgtest.py @@ -345,6 +345,84 @@ lightgreen 1 i386 green 2 # not expecting any failures to retrieve from swift self.assertNotIn('Failure', out, out) + def test_hint_force_badtest(self): + '''force-badtest hint''' + + self.swift.set_results({'autopkgtest-series': { + 'series/i386/d/darkgreen/20150101_100000@': (0, 'darkgreen 1'), + 'series/amd64/d/darkgreen/20150101_100000@': (0, 'darkgreen 1'), + 'series/i386/l/lightgreen/20150101_100100@': (0, 'lightgreen 1'), + 'series/i386/l/lightgreen/20150101_100101@': (4, 'lightgreen 1'), + 'series/amd64/l/lightgreen/20150101_100100@': (0, 'lightgreen 1'), + 'series/amd64/l/lightgreen/20150101_100101@': (4, 'lightgreen 1'), + 'series/i386/g/green/20150101_100200@': (0, 'green 2'), + 'series/amd64/g/green/20150101_100200@': (0, 'green 2'), + }}) + + self.create_hint('pitti', 'force-badtest lightgreen/1') + + self.do_test( + [('libgreen1', {'Version': '2', 'Source': 'green', 'Depends': 'libc6'}, 'autopkgtest')], + VALID_CANDIDATE, + [r'\bgreen\b.*>1 to .*>2<', + r'autopkgtest for green 2: .*amd64.*Pass.*i386.*Pass', + r'autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*Regression', + r'autopkgtest for darkgreen 1: .*amd64.*Pass.*i386.*Pass', + r'Should wait for lightgreen 1 test, but forced by pitti']) + + def test_hint_force_badtest_different_version(self): + '''force-badtest hint with non-matching version''' + + self.swift.set_results({'autopkgtest-series': { + 'series/i386/d/darkgreen/20150101_100000@': (0, 'darkgreen 1'), + 'series/amd64/d/darkgreen/20150101_100000@': (0, 'darkgreen 1'), + 'series/i386/l/lightgreen/20150101_100100@': (0, 'lightgreen 1'), + 'series/i386/l/lightgreen/20150101_100101@': (4, 'lightgreen 1'), + 'series/amd64/l/lightgreen/20150101_100100@': (0, 'lightgreen 1'), + 'series/amd64/l/lightgreen/20150101_100101@': (4, 'lightgreen 1'), + 'series/i386/g/green/20150101_100200@': (0, 'green 2'), + 'series/amd64/g/green/20150101_100200@': (0, 'green 2'), + }}) + + self.create_hint('pitti', 'force-badtest lightgreen/0.1') + + self.do_test( + [('libgreen1', {'Version': '2', 'Source': 'green', 'Depends': 'libc6'}, 'autopkgtest')], + NOT_CONSIDERED, + [r'\bgreen\b.*>1 to .*>2<', + r'autopkgtest for green 2: .*amd64.*Pass.*i386.*Pass', + r'autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*Regression', + r'autopkgtest for darkgreen 1: .*amd64.*Pass.*i386.*Pass'], + ['Should wait']) + + def test_hint_force_skiptest(self): + '''force-skiptest hint''' + + self.create_hint('pitti', 'force-skiptest green/2') + + self.do_test( + [('libgreen1', {'Version': '2', 'Source': 'green', 'Depends': 'libc6'}, 'autopkgtest')], + VALID_CANDIDATE, + [r'\bgreen\b.*>1 to .*>2<', + r'autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress', + r'autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress', + r'autopkgtest for darkgreen 1: .*amd64.*in progress.*i386.*in progress', + r'Should wait for.*tests.*green 2.*forced by pitti']) + + def test_hint_force_skiptest_different_version(self): + '''force-skiptest hint with non-matching version''' + + self.create_hint('pitti', 'force-skiptest green/1') + + self.do_test( + [('libgreen1', {'Version': '2', 'Source': 'green', 'Depends': 'libc6'}, 'autopkgtest')], + NOT_CONSIDERED, + [r'\bgreen\b.*>1 to .*>2<', + r'autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress', + r'autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress', + r'autopkgtest for darkgreen 1: .*amd64.*in progress.*i386.*in progress'], + ['Should wait']) + def test_package_pair_running(self): '''Two packages in unstable that need to go in together (running)''' diff --git a/tests/test_boottest.py b/tests/test_boottest.py index 3d48f72..6452fbb 100644 --- a/tests/test_boottest.py +++ b/tests/test_boottest.py @@ -331,14 +331,6 @@ args.func() r'
  • Boottest result: UNKNOWN STATUS \(Jenkins: .*\)', '
  • Not considered']) - def create_hint(self, username, content): - """Populates a hint file for the given 'username' with 'content'.""" - hints_path = os.path.join( - self.data.path, - 'data/{}-proposed/Hints/{}'.format(self.data.series, username)) - with open(hints_path, 'w') as fd: - fd.write(content) - def test_skipped_by_hints(self): # `Britney` allows boottests to be skipped by hinting the # corresponding source with 'force-skiptest'. The boottest