blob: b91fe504191230aec383e135e292faed77bd6cce [file] [log] [blame]
Brian Curtin6a4ffd72011-07-05 19:14:16 -05001from test.support import run_unittest
R David Murrayc4b8e052012-10-27 14:55:25 -04002from test.script_helper import assert_python_failure, temp_dir
Brian Curtin6a4ffd72011-07-05 19:14:16 -05003import unittest
4import sys
Brian Curtin6a4ffd72011-07-05 19:14:16 -05005import cgitb
6
7class TestCgitb(unittest.TestCase):
Brian Curtin692e26b2011-07-05 19:16:37 -05008
Brian Curtin6a4ffd72011-07-05 19:14:16 -05009 def test_fonts(self):
10 text = "Hello Robbie!"
11 self.assertEqual(cgitb.small(text), "<small>{}</small>".format(text))
12 self.assertEqual(cgitb.strong(text), "<strong>{}</strong>".format(text))
13 self.assertEqual(cgitb.grey(text),
14 '<font color="#909090">{}</font>'.format(text))
Brian Curtin692e26b2011-07-05 19:16:37 -050015
Brian Curtin6a4ffd72011-07-05 19:14:16 -050016 def test_blanks(self):
17 self.assertEqual(cgitb.small(""), "")
18 self.assertEqual(cgitb.strong(""), "")
19 self.assertEqual(cgitb.grey(""), "")
Brian Curtin692e26b2011-07-05 19:16:37 -050020
Brian Curtin6a4ffd72011-07-05 19:14:16 -050021 def test_html(self):
22 try:
23 raise ValueError("Hello World")
24 except ValueError as err:
25 # If the html was templated we could do a bit more here.
26 # At least check that we get details on what we just raised.
27 html = cgitb.html(sys.exc_info())
28 self.assertIn("ValueError", html)
29 self.assertIn(str(err), html)
30
31 def test_text(self):
32 try:
33 raise ValueError("Hello World")
34 except ValueError as err:
35 text = cgitb.text(sys.exc_info())
36 self.assertIn("ValueError", text)
37 self.assertIn("Hello World", text)
Brian Curtin692e26b2011-07-05 19:16:37 -050038
R David Murray74076cb2012-10-27 17:39:25 -040039 @unittest.skipIf(sys.platform=='win32', "test fails on windows, see issue 12890")
R David Murrayc4b8e052012-10-27 14:55:25 -040040 def test_syshook_no_logdir_default_format(self):
41 with temp_dir() as tracedir:
42 rc, out, err = assert_python_failure(
43 '-c',
44 ('import cgitb; cgitb.enable(logdir="%s"); '
45 'raise ValueError("Hello World")') % tracedir)
46 out = out.decode(sys.getfilesystemencoding())
Brian Curtin6a4ffd72011-07-05 19:14:16 -050047 self.assertIn("ValueError", out)
48 self.assertIn("Hello World", out)
R David Murrayc4b8e052012-10-27 14:55:25 -040049 # By default we emit HTML markup.
50 self.assertIn('<p>', out)
51 self.assertIn('</p>', out)
52
R David Murray74076cb2012-10-27 17:39:25 -040053 @unittest.skipIf(sys.platform=='win32', "test fails on windows, see issue 12890")
R David Murrayc4b8e052012-10-27 14:55:25 -040054 def test_syshook_no_logdir_text_format(self):
55 # Issue 12890: we were emitting the <p> tag in text mode.
56 with temp_dir() as tracedir:
57 rc, out, err = assert_python_failure(
58 '-c',
59 ('import cgitb; cgitb.enable(format="text", logdir="%s"); '
60 'raise ValueError("Hello World")') % tracedir)
61 out = out.decode(sys.getfilesystemencoding())
62 self.assertIn("ValueError", out)
63 self.assertIn("Hello World", out)
64 self.assertNotIn('<p>', out)
65 self.assertNotIn('</p>', out)
Brian Curtin6a4ffd72011-07-05 19:14:16 -050066
67
68def test_main():
69 run_unittest(TestCgitb)
Brian Curtin692e26b2011-07-05 19:16:37 -050070
Brian Curtin6a4ffd72011-07-05 19:14:16 -050071if __name__ == "__main__":
72 test_main()