Exemplo n.º 1
0
 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(_u('1..4\n'))
     self.tap.write(_u('ok 1 - first test in a script with a plan\n'))
     self.tap.write(_u('not ok 2 - second\n'))
     self.tap.write(_u('ok 3 - third\n'))
     self.tap.write(_u('not ok 4 - fourth\n'))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([
         ('status', 'test 1 - first test in a script with a plan',
          'success', None, False, None, None, True, None, None, None),
         ('status', 'test 2 - second', 'fail', None, False, None, None,
          True, None, None, None),
         ('status', 'test 3 - third', 'success', None, False, None, None,
          True, None, None, None),
         ('status', 'test 4 - fourth', 'fail', None, False, None, None,
          True, None, None, None)])
Exemplo n.º 2
0
 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())
Exemplo n.º 3
0
 def test_ok_skip_number_comment_lowercase(self):
     self.tap.write(_u("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.check_events([('status', 'test 1', 'skip', None, False, 'tap comment',
         b'no samba environment available, skipping compilation', True,
         'text/plain; charset=UTF8', None, None)])
Exemplo n.º 4
0
 def test_ok_test_number_pass(self):
     # A file
     # ok 1
     # results in a passed test with name 'test 1'
     self.tap.write(_u("ok 1\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([('status', 'test 1', 'success', None, False, None,
         None, True, None, None, None)])
Exemplo n.º 5
0
 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(_u("ok There is a description\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([('status', 'test 1 There is a description',
         'success', None, False, None, None, True, None, None, None)])
Exemplo n.º 6
0
 def test_ok_TODO_xfail(self):
     # A file
     # ok # TODO
     # results in a xfail test with name 'test 1'
     self.tap.write(_u("ok # TODO\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([('status', 'test 1', 'xfail', None, False, None,
         None, True, None, None, None)])
Exemplo n.º 7
0
 def test_ok_SKIP_skip(self):
     # A file
     # ok # SKIP
     # results in a skkip test with name 'test 1'
     self.tap.write(_u("ok # SKIP\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([('status', 'test 1', 'skip', None, False, None,
         None, True, None, None, None)])
Exemplo n.º 8
0
 def test_skip_entire_file(self):
     # A file
     # 1..- # Skipped: comment
     # results in a single skipped test.
     self.tap.write(_u("1..0 # Skipped: entire file skipped\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([('status', 'file skip', 'skip', None, True,
         'tap comment', b'Skipped: entire file skipped', True, None, None,
         None)])
Exemplo n.º 9
0
 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(_u("ok # TODO Not done yet\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([('status', 'test 1', 'xfail', None, False,
         'tap comment', b'Not done yet', True, 'text/plain; charset=UTF8',
         None, None)])
Exemplo n.º 10
0
 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())
Exemplo n.º 11
0
 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(_u("ok 1 foo  # SKIP Not done yet\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([('status', 'test 1 foo', 'skip', None, False,
         'tap comment', b'Not done yet', True, 'text/plain; charset=UTF8',
         None, None)])
Exemplo n.º 12
0
 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(_u("ok\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([('status', 'test 1', 'success', None, False, None,
         None, True, None, None, None)])
Exemplo n.º 13
0
 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())
Exemplo n.º 14
0
 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())
Exemplo n.º 15
0
 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())
Exemplo n.º 16
0
 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())
Exemplo n.º 17
0
 def test_bail_out_errors(self):
     # A file with line in it
     # Bail out! COMMENT
     # is treated as an error
     self.tap.write(_u("ok 1 foo\n"))
     self.tap.write(_u("Bail out! Lifejacket engaged\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([
         ('status', 'test 1 foo', 'success', None, False, None, None, True,
          None, None, None),
         ('status', 'Bail out! Lifejacket engaged', 'fail', None, False,
          None, None, True, None, None, None)])
Exemplo n.º 18
0
 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())
Exemplo n.º 19
0
 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())
Exemplo n.º 20
0
 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())
Exemplo n.º 21
0
 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())
Exemplo n.º 22
0
 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())
Exemplo n.º 23
0
 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(_u("# comment\n"))
     self.tap.write(_u("ok\n"))
     self.tap.write(_u("ok\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([
         ('status', 'test 1', 'success', None, False, 'tap comment',
          b'# comment', True, 'text/plain; charset=UTF8', None, None),
         ('status', 'test 2', 'success', None, False, None, None, True,
          None, None, None)])
Exemplo n.º 24
0
 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(_u('ok first test\n'))
     self.tap.write(_u('not ok 3 third test\n'))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([
         ('status', 'test 1 first test', 'success', None, False, None, None,
          True, None, None, None),
         ('status', 'test 2', 'fail', None, False, 'tap meta',
          b'test missing from TAP output', True, 'text/plain; charset=UTF8',
          None, None),
         ('status', 'test 3 third test', 'fail', None, False, None, None,
          True, None, None, None)])
Exemplo n.º 25
0
 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(_u("ok\n"))
     self.tap.write(_u("ok\n"))
     self.tap.write(_u("# comment\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.check_events([
         ('status', 'test 1', 'success', None, False, None, None, True,
          None, None, None),
         ('status', 'test 2', 'success', None, False, 'tap comment',
          b'# comment', True, 'text/plain; charset=UTF8', None, None)])
Exemplo n.º 26
0
 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(_u("not ok 1 - a fail but # TODO but is TODO\n"))
     self.tap.write(_u("not ok 2 - another fail # SKIP instead\n"))
     self.tap.seek(0)
     result = subunit.TAP2SubUnit(self.tap, self.subunit)
     self.assertEqual(0, result)
     self.subunit.seek(0)
     events = StreamResult()
     subunit.ByteStreamToStreamResult(self.subunit).run(events)
     self.check_events([
         ('status', 'test 1 - a fail but', 'xfail', None, False,
          'tap comment', b'but is TODO', True, 'text/plain; charset=UTF8',
          None, None),
         ('status', 'test 2 - another fail', 'skip', None, False,
          'tap comment', b'instead', True, 'text/plain; charset=UTF8',
          None, None)])
Exemplo n.º 27
0
 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())
Exemplo n.º 28
0
 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())
Exemplo n.º 29
0
 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())
Exemplo n.º 30
0
 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())