Exemple #1
0
class TestSubUnitTags(unittest.TestCase):
    def setUp(self):
        self.original = StringIO()
        self.filtered = StringIO()

    def test_add_tag(self):
        self.original.write("tags: foo\n")
        self.original.write("test: test\n")
        self.original.write("tags: bar -quux\n")
        self.original.write("success: test\n")
        self.original.seek(0)
        result = subunit.tag_stream(self.original, self.filtered, ["quux"])
        self.assertEqual(
            ["tags: quux", "tags: foo", "test: test", "tags: bar", "success: test"],
            self.filtered.getvalue().splitlines(),
        )

    def test_remove_tag(self):
        self.original.write("tags: foo\n")
        self.original.write("test: test\n")
        self.original.write("tags: bar -quux\n")
        self.original.write("success: test\n")
        self.original.seek(0)
        result = subunit.tag_stream(self.original, self.filtered, ["-bar"])
        self.assertEqual(
            ["tags: -bar", "tags: foo", "test: test", "tags: -quux", "success: test"],
            self.filtered.getvalue().splitlines(),
        )
class TestSubUnitTags(unittest.TestCase):
    def setUp(self):
        self.original = StringIO()
        self.filtered = StringIO()

    def test_add_tag(self):
        self.original.write("tags: foo\n")
        self.original.write("test: test\n")
        self.original.write("tags: bar -quux\n")
        self.original.write("success: test\n")
        self.original.seek(0)
        result = subunit.tag_stream(self.original, self.filtered, ["quux"])
        self.assertEqual([
            "tags: quux",
            "tags: foo",
            "test: test",
            "tags: bar",
            "success: test",
        ],
                         self.filtered.getvalue().splitlines())

    def test_remove_tag(self):
        self.original.write("tags: foo\n")
        self.original.write("test: test\n")
        self.original.write("tags: bar -quux\n")
        self.original.write("success: test\n")
        self.original.seek(0)
        result = subunit.tag_stream(self.original, self.filtered, ["-bar"])
        self.assertEqual([
            "tags: -bar",
            "tags: foo",
            "test: test",
            "tags: -quux",
            "success: test",
        ],
                         self.filtered.getvalue().splitlines())
class TestTAP2SubUnit(unittest.TestCase):
    """Tests for TAP2SubUnit.

    These tests test TAP string data in, and subunit string data out.
    This is ok because the subunit protocol is intended to be stable,
    but it might be easier/pithier to write tests against TAP string in,
    parsed subunit objects out (by hooking the subunit stream to a subunit
    protocol server.
    """

    def setUp(self):
        self.tap = StringIO()
        self.subunit = StringIO()

    def test_skip_entire_file(self):
        # A file
        # 1..- # Skipped: comment
        # results in a single skipped test.
        self.tap.write("1..0 # Skipped: entire file skipped\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test file skip",
            "skip file skip [",
            "Skipped: entire file skipped",
            "]",
            ],
            self.subunit.getvalue().splitlines())

    def test_ok_test_pass(self):
        # A file
        # ok
        # results in a passed test with name 'test 1' (a synthetic name as tap
        # does not require named fixtures - it is the first test in the tap
        # stream).
        self.tap.write("ok\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1",
            "success test 1",
            ],
            self.subunit.getvalue().splitlines())

    def test_ok_test_number_pass(self):
        # A file
        # ok 1
        # results in a passed test with name 'test 1'
        self.tap.write("ok 1\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1",
            "success test 1",
            ],
            self.subunit.getvalue().splitlines())

    def test_ok_test_number_description_pass(self):
        # A file
        # ok 1 - There is a description
        # results in a passed test with name 'test 1 - There is a description'
        self.tap.write("ok 1 - There is a description\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1 - There is a description",
            "success test 1 - There is a description",
            ],
            self.subunit.getvalue().splitlines())

    def test_ok_test_description_pass(self):
        # A file
        # ok There is a description
        # results in a passed test with name 'test 1 There is a description'
        self.tap.write("ok There is a description\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1 There is a description",
            "success test 1 There is a description",
            ],
            self.subunit.getvalue().splitlines())

    def test_ok_SKIP_skip(self):
        # A file
        # ok # SKIP
        # results in a skkip test with name 'test 1'
        self.tap.write("ok # SKIP\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1",
            "skip test 1",
            ],
            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
        # results in a skip test with name 'test 1 foo' and a log of
        # Not done yet
        self.tap.write("ok 1 foo  # SKIP Not done yet\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1 foo",
            "skip test 1 foo [",
            "Not done yet",
            "]",
            ],
            self.subunit.getvalue().splitlines())

    def test_ok_SKIP_skip_comment(self):
        # A file
        # ok # SKIP Not done yet
        # results in a skip test with name 'test 1' and a log of Not done yet
        self.tap.write("ok # SKIP Not done yet\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1",
            "skip test 1 [",
            "Not done yet",
            "]",
            ],
            self.subunit.getvalue().splitlines())

    def test_ok_TODO_xfail(self):
        # A file
        # ok # TODO
        # results in a xfail test with name 'test 1'
        self.tap.write("ok # TODO\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1",
            "xfail test 1",
            ],
            self.subunit.getvalue().splitlines())

    def test_ok_TODO_xfail_comment(self):
        # A file
        # ok # TODO Not done yet
        # results in a xfail test with name 'test 1' and a log of Not done yet
        self.tap.write("ok # TODO Not done yet\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1",
            "xfail test 1 [",
            "Not done yet",
            "]",
            ],
            self.subunit.getvalue().splitlines())

    def test_bail_out_errors(self):
        # A file with line in it
        # Bail out! COMMENT
        # is treated as an error
        self.tap.write("ok 1 foo\n")
        self.tap.write("Bail out! Lifejacket engaged\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            "test test 1 foo",
            "success test 1 foo",
            "test Bail out! Lifejacket engaged",
            "error Bail out! Lifejacket engaged",
            ],
            self.subunit.getvalue().splitlines())

    def test_missing_test_at_end_with_plan_adds_error(self):
        # A file
        # 1..3
        # ok first test
        # not ok third test
        # results in three tests, with the third being created
        self.tap.write('1..3\n')
        self.tap.write('ok first test\n')
        self.tap.write('not ok second test\n')
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1 first test',
            'success test 1 first test',
            'test test 2 second test',
            'failure test 2 second test',
            'test test 3',
            'error test 3 [',
            'test missing from TAP output',
            ']',
            ],
            self.subunit.getvalue().splitlines())

    def test_missing_test_with_plan_adds_error(self):
        # A file
        # 1..3
        # ok first test
        # not ok 3 third test
        # results in three tests, with the second being created
        self.tap.write('1..3\n')
        self.tap.write('ok first test\n')
        self.tap.write('not ok 3 third test\n')
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1 first test',
            'success test 1 first test',
            'test test 2',
            'error test 2 [',
            'test missing from TAP output',
            ']',
            'test test 3 third test',
            'failure test 3 third test',
            ],
            self.subunit.getvalue().splitlines())

    def test_missing_test_no_plan_adds_error(self):
        # A file
        # ok first test
        # not ok 3 third test
        # results in three tests, with the second being created
        self.tap.write('ok first test\n')
        self.tap.write('not ok 3 third test\n')
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1 first test',
            'success test 1 first test',
            'test test 2',
            'error test 2 [',
            'test missing from TAP output',
            ']',
            'test test 3 third test',
            'failure test 3 third test',
            ],
            self.subunit.getvalue().splitlines())

    def test_four_tests_in_a_row_trailing_plan(self):
        # A file
        # ok 1 - first test in a script with no plan at all
        # not ok 2 - second
        # ok 3 - third
        # not ok 4 - fourth
        # 1..4
        # results in four tests numbered and named
        self.tap.write('ok 1 - first test in a script with trailing plan\n')
        self.tap.write('not ok 2 - second\n')
        self.tap.write('ok 3 - third\n')
        self.tap.write('not ok 4 - fourth\n')
        self.tap.write('1..4\n')
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1 - first test in a script with trailing plan',
            'success test 1 - first test in a script with trailing plan',
            'test test 2 - second',
            'failure test 2 - second',
            'test test 3 - third',
            'success test 3 - third',
            'test test 4 - fourth',
            'failure test 4 - fourth'
            ],
            self.subunit.getvalue().splitlines())

    def test_four_tests_in_a_row_with_plan(self):
        # A file
        # 1..4
        # ok 1 - first test in a script with no plan at all
        # not ok 2 - second
        # ok 3 - third
        # not ok 4 - fourth
        # results in four tests numbered and named
        self.tap.write('1..4\n')
        self.tap.write('ok 1 - first test in a script with a plan\n')
        self.tap.write('not ok 2 - second\n')
        self.tap.write('ok 3 - third\n')
        self.tap.write('not ok 4 - fourth\n')
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1 - first test in a script with a plan',
            'success test 1 - first test in a script with a plan',
            'test test 2 - second',
            'failure test 2 - second',
            'test test 3 - third',
            'success test 3 - third',
            'test test 4 - fourth',
            'failure test 4 - fourth'
            ],
            self.subunit.getvalue().splitlines())

    def test_four_tests_in_a_row_no_plan(self):
        # A file
        # ok 1 - first test in a script with no plan at all
        # not ok 2 - second
        # ok 3 - third
        # not ok 4 - fourth
        # results in four tests numbered and named
        self.tap.write('ok 1 - first test in a script with no plan at all\n')
        self.tap.write('not ok 2 - second\n')
        self.tap.write('ok 3 - third\n')
        self.tap.write('not ok 4 - fourth\n')
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1 - first test in a script with no plan at all',
            'success test 1 - first test in a script with no plan at all',
            'test test 2 - second',
            'failure test 2 - second',
            'test test 3 - third',
            'success test 3 - third',
            'test test 4 - fourth',
            'failure test 4 - fourth'
            ],
            self.subunit.getvalue().splitlines())

    def test_todo_and_skip(self):
        # A file
        # not ok 1 - a fail but # TODO but is TODO
        # not ok 2 - another fail # SKIP instead
        # results in two tests, numbered and commented.
        self.tap.write("not ok 1 - a fail but # TODO but is TODO\n")
        self.tap.write("not ok 2 - another fail # SKIP instead\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1 - a fail but',
            'xfail test 1 - a fail but [',
            'but is TODO',
            ']',
            'test test 2 - another fail',
            'skip test 2 - another fail [',
            'instead',
            ']',
            ],
            self.subunit.getvalue().splitlines())

    def test_leading_comments_add_to_next_test_log(self):
        # A file
        # # comment
        # ok 
        # ok
        # results in a single test with the comment included
        # in the first test and not the second.
        self.tap.write("# comment\n")
        self.tap.write("ok\n")
        self.tap.write("ok\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1',
            'success test 1 [',
            '# comment',
            ']',
            'test test 2',
            'success test 2',
            ],
            self.subunit.getvalue().splitlines())
    
    def test_trailing_comments_are_included_in_last_test_log(self):
        # A file
        # ok foo
        # ok foo
        # # comment
        # results in a two tests, with the second having the comment
        # attached to its log.
        self.tap.write("ok\n")
        self.tap.write("ok\n")
        self.tap.write("# comment\n")
        self.tap.seek(0)
        result = subunit.TAP2SubUnit(self.tap, self.subunit)
        self.assertEqual(0, result)
        self.assertEqual([
            'test test 1',
            'success test 1',
            'test test 2',
            'success test 2 [',
            '# comment',
            ']',
            ],
            self.subunit.getvalue().splitlines())