From 5d0694f9941e22f92c9c641b8fb3a7ce376ee5cd Mon Sep 17 00:00:00 2001 From: Jelmer Vernooij Date: Sun, 11 Apr 2010 20:56:02 +0200 Subject: subunit: Cope with lowercase test results in tap2subunit. Also submitted upstream. --- lib/subunit/python/subunit/__init__.py | 6 +++--- lib/subunit/python/subunit/tests/test_tap2subunit.py | 15 +++++++++++++-- 2 files changed, 16 insertions(+), 5 deletions(-) (limited to 'lib/subunit') diff --git a/lib/subunit/python/subunit/__init__.py b/lib/subunit/python/subunit/__init__.py index 6b65ae42dc..4b25ca3a39 100644 --- a/lib/subunit/python/subunit/__init__.py +++ b/lib/subunit/python/subunit/__init__.py @@ -913,7 +913,7 @@ def TAP2SubUnit(tap, subunit): subunit.write("]\n") continue # not a plan line, or have seen one before - match = re.match("(ok|not ok)(?:\s+(\d+)?)?(?:\s+([^#]*[^#\s]+)\s*)?(?:\s+#\s+(TODO|SKIP)(?:\s+(.*))?)?\n", line) + match = re.match("(ok|not ok)(?:\s+(\d+)?)?(?:\s+([^#]*[^#\s]+)\s*)?(?:\s+#\s+(TODO|SKIP|skip|todo)(?:\s+(.*))?)?\n", line) if match: # new test, emit current one. _emit_test() @@ -927,9 +927,9 @@ def TAP2SubUnit(tap, subunit): else: description = ' ' + description if directive is not None: - if directive == 'TODO': + if directive.upper() == 'TODO': result = 'xfail' - elif directive == 'SKIP': + elif directive.upper() == 'SKIP': result = 'skip' if directive_comment is not None: log.append(directive_comment) diff --git a/lib/subunit/python/subunit/tests/test_tap2subunit.py b/lib/subunit/python/subunit/tests/test_tap2subunit.py index febfe9d441..c4ca4cdb3a 100644 --- a/lib/subunit/python/subunit/tests/test_tap2subunit.py +++ b/lib/subunit/python/subunit/tests/test_tap2subunit.py @@ -18,9 +18,7 @@ import unittest from StringIO import StringIO -import os import subunit -import sys class TestTAP2SubUnit(unittest.TestCase): @@ -125,6 +123,19 @@ class TestTAP2SubUnit(unittest.TestCase): ], self.subunit.getvalue().splitlines()) + def test_ok_skip_number_comment_lowercase(self): + self.tap.write("ok 1 # skip no samba environment available, skipping compilation\n") + self.tap.seek(0) + result = subunit.TAP2SubUnit(self.tap, self.subunit) + self.assertEqual(0, result) + self.assertEqual([ + "test test 1", + "skip test 1 [", + "no samba environment available, skipping compilation", + "]" + ], + self.subunit.getvalue().splitlines()) + def test_ok_number_description_SKIP_skip_comment(self): # A file # ok 1 foo # SKIP Not done yet -- cgit