diff options
Diffstat (limited to 'selftest')
-rwxr-xr-x | selftest/selftest.py | 25 | ||||
-rw-r--r-- | selftest/testlist.py | 33 | ||||
-rw-r--r-- | selftest/tests/test_testlist.py | 46 |
3 files changed, 87 insertions, 17 deletions
diff --git a/selftest/selftest.py b/selftest/selftest.py index 9ca1e45c1d..26c409af45 100755 --- a/selftest/selftest.py +++ b/selftest/selftest.py @@ -344,25 +344,16 @@ else: os.environ["SELFTEST_MAXTIME"] = str(torture_maxtime) -def open_file_or_pipe(path, mode): - if path.endswith("|"): - return os.popen(path[:-1], mode) - return open(path, mode) - available = [] for fn in opts.testlist: - inf = open_file_or_pipe(fn, 'r') - try: - for testsuite in testlist.read_testlist(inf, sys.stdout): - if not testlist.should_run_test(tests, testsuite): - continue - name = testsuite[0] - if (includes is not None and - testlist.find_in_list(includes, name) is not None): - continue - available.append(testsuite) - finally: - inf.close() + for testsuite in testlist.read_testlist_file(fn): + if not testlist.should_run_test(tests, testsuite): + continue + name = testsuite[0] + if (includes is not None and + testlist.find_in_list(includes, name) is not None): + continue + available.append(testsuite) if opts.load_list: restricted_mgr = testlist.RestrictedTestManager.from_path(opts.load_list) diff --git a/selftest/testlist.py b/selftest/testlist.py index 441dda7cbb..5102f4288b 100644 --- a/selftest/testlist.py +++ b/selftest/testlist.py @@ -21,7 +21,9 @@ __all__ = ['find_in_list', 'read_test_regexes', 'read_testlist'] +import os import re +import sys def find_in_list(list, fullname): """Find test in list. @@ -133,3 +135,34 @@ class RestrictedTestManager(object): :return: Iterator over test list entries that were not used. """ return iter(self.unused) + + +def open_file_or_pipe(path, mode): + """Open a file or pipe. + + :param path: Path to open; if it ends with | it is assumed to be a + command to run + :param mode: Mode with which to open it + :return: File-like object + """ + if path.endswith("|"): + return os.popen(path[:-1], mode) + return open(path, mode) + + +def read_testlist_file(fn, outf=None): + """Read testlist file. + + :param fn: Path to read (assumed to be a command to run if it ends with |) + :param outf: File-like object to pass non-test data through to + (defaults to stdout) + :return: Iterator over test suites (see read_testlist) + """ + if outf is None: + outf = sys.stdout + inf = open_file_or_pipe(fn, 'r') + try: + for testsuite in read_testlist(inf, outf): + yield testsuite + finally: + inf.close() diff --git a/selftest/tests/test_testlist.py b/selftest/tests/test_testlist.py index cd44d46238..4474d0aa07 100644 --- a/selftest/tests/test_testlist.py +++ b/selftest/tests/test_testlist.py @@ -19,13 +19,18 @@ """Tests for selftest.testlist.""" +import os +import tempfile + from selftest.tests import TestCase from selftest.testlist import ( RestrictedTestManager, find_in_list, + open_file_or_pipe, read_test_regexes, read_testlist, + read_testlist_file, ) from cStringIO import StringIO @@ -100,3 +105,44 @@ class RestrictedTestManagerTests(TestCase): def test_run_nomatch(self): mgr = RestrictedTestManager(["foo.bar"]) self.assertEquals([], mgr.should_run_testsuite("foo.blie.bla")) + + +class OpenFileOrPipeTests(TestCase): + + def test_regular_file(self): + (fd, p) = tempfile.mkstemp() + self.addCleanup(os.remove, p) + f = os.fdopen(fd, 'w') + try: + f.write('data\nbla\n') + finally: + f.close() + f = open_file_or_pipe(p, 'r') + try: + self.assertEquals("data\nbla\n", f.read()) + finally: + f.close() + + def test_pipe(self): + f = open_file_or_pipe('echo foo|', 'r') + try: + self.assertEquals("foo\n", f.read()) + finally: + f.close() + + +class ReadTestListFileTests(TestCase): + + def test_regular_file(self): + (fd, p) = tempfile.mkstemp() + self.addCleanup(os.remove, p) + f = os.fdopen(fd, 'w') + try: + f.write('noise\n-- TEST --\ndata\nenv\ncmd\n') + finally: + f.close() + outf = StringIO() + self.assertEquals( + [('data', 'env', 'cmd', False, False)], + list(read_testlist_file(p, outf))) + self.assertEquals("noise\n", outf.getvalue()) |