| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | """
 | 
					
						
							|  |  |  | Tests of regrtest.py. | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | Note: test_regrtest cannot be run twice in parallel. | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import argparse | 
					
						
							| 
									
										
										
										
											2015-10-11 10:04:26 +02:00
										 |  |  | import contextlib | 
					
						
							| 
									
										
										
										
											2013-09-08 12:27:33 +02:00
										 |  |  | import faulthandler | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | import getopt | 
					
						
							| 
									
										
										
										
											2015-10-11 10:03:28 +02:00
										 |  |  | import io | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  | import os.path | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | import platform | 
					
						
							|  |  |  | import re | 
					
						
							|  |  |  | import subprocess | 
					
						
							|  |  |  | import sys | 
					
						
							| 
									
										
										
										
											2015-11-22 15:18:54 +01:00
										 |  |  | import sysconfig | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | import textwrap | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | import unittest | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  | from test import libregrtest | 
					
						
							|  |  |  | from test import support | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | Py_DEBUG = hasattr(sys, 'getobjects') | 
					
						
							|  |  |  | ROOT_DIR = os.path.join(os.path.dirname(__file__), '..', '..') | 
					
						
							|  |  |  | ROOT_DIR = os.path.abspath(os.path.normpath(ROOT_DIR)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-11 10:37:25 +02:00
										 |  |  | TEST_INTERRUPTED = textwrap.dedent("""
 | 
					
						
							|  |  |  |     from signal import SIGINT | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         from _testcapi import raise_signal | 
					
						
							|  |  |  |         raise_signal(SIGINT) | 
					
						
							|  |  |  |     except ImportError: | 
					
						
							|  |  |  |         import os | 
					
						
							|  |  |  |         os.kill(os.getpid(), SIGINT) | 
					
						
							|  |  |  |     """)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | class ParseArgsTestCase(unittest.TestCase): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Test regrtest's argument parsing, function _parse_args(). | 
					
						
							|  |  |  |     """
 | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def checkError(self, args, msg): | 
					
						
							|  |  |  |         with support.captured_stderr() as err, self.assertRaises(SystemExit): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |             libregrtest._parse_args(args) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertIn(msg, err.getvalue()) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_help(self): | 
					
						
							|  |  |  |         for opt in '-h', '--help': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							|  |  |  |                 with support.captured_stdout() as out, \ | 
					
						
							|  |  |  |                      self.assertRaises(SystemExit): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                     libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertIn('Run Python regression tests.', out.getvalue()) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-08 12:27:33 +02:00
										 |  |  |     @unittest.skipUnless(hasattr(faulthandler, 'dump_traceback_later'), | 
					
						
							|  |  |  |                          "faulthandler.dump_traceback_later() required") | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_timeout(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--timeout', '4.2']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.timeout, 4.2) | 
					
						
							|  |  |  |         self.checkError(['--timeout'], 'expected one argument') | 
					
						
							|  |  |  |         self.checkError(['--timeout', 'foo'], 'invalid float value') | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_wait(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--wait']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertTrue(ns.wait) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_slaveargs(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--slaveargs', '[[], {}]']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.slaveargs, '[[], {}]') | 
					
						
							|  |  |  |         self.checkError(['--slaveargs'], 'expected one argument') | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_start(self): | 
					
						
							|  |  |  |         for opt in '-S', '--start': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, 'foo']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.start, 'foo') | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_verbose(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['-v']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.verbose, 1) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['-vvv']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.verbose, 3) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--verbose']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.verbose, 1) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--verbose'] * 3) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.verbose, 3) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args([]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.verbose, 0) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_verbose2(self): | 
					
						
							|  |  |  |         for opt in '-w', '--verbose2': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.verbose2) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_verbose3(self): | 
					
						
							|  |  |  |         for opt in '-W', '--verbose3': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.verbose3) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_quiet(self): | 
					
						
							|  |  |  |         for opt in '-q', '--quiet': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.quiet) | 
					
						
							|  |  |  |                 self.assertEqual(ns.verbose, 0) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_slow(self): | 
					
						
							|  |  |  |         for opt in '-o', '--slow': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.print_slow) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_header(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--header']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertTrue(ns.header) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_randomize(self): | 
					
						
							|  |  |  |         for opt in '-r', '--randomize': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.randomize) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_randseed(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--randseed', '12345']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.random_seed, 12345) | 
					
						
							|  |  |  |         self.assertTrue(ns.randomize) | 
					
						
							|  |  |  |         self.checkError(['--randseed'], 'expected one argument') | 
					
						
							|  |  |  |         self.checkError(['--randseed', 'foo'], 'invalid int value') | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_fromfile(self): | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         for opt in '-f', '--fromfile': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, 'foo']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.fromfile, 'foo') | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							|  |  |  |                 self.checkError([opt, 'foo', '-s'], "don't go together") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_exclude(self): | 
					
						
							|  |  |  |         for opt in '-x', '--exclude': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.exclude) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_single(self): | 
					
						
							|  |  |  |         for opt in '-s', '--single': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.single) | 
					
						
							|  |  |  |                 self.checkError([opt, '-f', 'foo'], "don't go together") | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_match(self): | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         for opt in '-m', '--match': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, 'pattern']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.match_tests, 'pattern') | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     def test_failfast(self): | 
					
						
							|  |  |  |         for opt in '-G', '--failfast': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, '-v']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.failfast) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, '-W']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.failfast) | 
					
						
							|  |  |  |                 self.checkError([opt], '-G/--failfast needs either -v or -W') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_use(self): | 
					
						
							|  |  |  |         for opt in '-u', '--use': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, 'gui,network']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.use_resources, ['gui', 'network']) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, 'gui,none,network']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.use_resources, ['network']) | 
					
						
							| 
									
										
										
										
											2015-09-26 09:43:45 +02:00
										 |  |  |                 expected = list(libregrtest.RESOURCE_NAMES) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 expected.remove('gui') | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, 'all,-gui']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.use_resources, expected) | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							|  |  |  |                 self.checkError([opt, 'foo'], 'invalid resource') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_memlimit(self): | 
					
						
							|  |  |  |         for opt in '-M', '--memlimit': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, '4G']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.memlimit, '4G') | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_testdir(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--testdir', 'foo']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.testdir, os.path.join(support.SAVEDCWD, 'foo')) | 
					
						
							|  |  |  |         self.checkError(['--testdir'], 'expected one argument') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-29 15:18:43 -04:00
										 |  |  |     def test_runleaks(self): | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         for opt in '-L', '--runleaks': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.runleaks) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-29 15:18:43 -04:00
										 |  |  |     def test_huntrleaks(self): | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         for opt in '-R', '--huntrleaks': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, ':']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.huntrleaks, (5, 4, 'reflog.txt')) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, '6:']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.huntrleaks, (6, 4, 'reflog.txt')) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, ':3']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.huntrleaks, (5, 3, 'reflog.txt')) | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, '6:3:leaks.log']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.huntrleaks, (6, 3, 'leaks.log')) | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							|  |  |  |                 self.checkError([opt, '6'], | 
					
						
							|  |  |  |                                 'needs 2 or 3 colon-separated arguments') | 
					
						
							|  |  |  |                 self.checkError([opt, 'foo:'], 'invalid huntrleaks value') | 
					
						
							|  |  |  |                 self.checkError([opt, '6:foo'], 'invalid huntrleaks value') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_multiprocess(self): | 
					
						
							|  |  |  |         for opt in '-j', '--multiprocess': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, '2']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.use_mp, 2) | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							|  |  |  |                 self.checkError([opt, 'foo'], 'invalid int value') | 
					
						
							|  |  |  |                 self.checkError([opt, '2', '-T'], "don't go together") | 
					
						
							|  |  |  |                 self.checkError([opt, '2', '-l'], "don't go together") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-29 15:18:43 -04:00
										 |  |  |     def test_coverage(self): | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         for opt in '-T', '--coverage': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.trace) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_coverdir(self): | 
					
						
							|  |  |  |         for opt in '-D', '--coverdir': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, 'foo']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.coverdir, | 
					
						
							|  |  |  |                                  os.path.join(support.SAVEDCWD, 'foo')) | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_nocoverdir(self): | 
					
						
							|  |  |  |         for opt in '-N', '--nocoverdir': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertIsNone(ns.coverdir) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_threshold(self): | 
					
						
							|  |  |  |         for opt in '-t', '--threshold': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt, '1000']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertEqual(ns.threshold, 1000) | 
					
						
							|  |  |  |                 self.checkError([opt], 'expected one argument') | 
					
						
							|  |  |  |                 self.checkError([opt, 'foo'], 'invalid int value') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_nowindows(self): | 
					
						
							|  |  |  |         for opt in '-n', '--nowindows': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-10-11 10:04:26 +02:00
										 |  |  |                 with contextlib.redirect_stderr(io.StringIO()) as stderr: | 
					
						
							|  |  |  |                     ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.nowindows) | 
					
						
							| 
									
										
										
										
											2015-10-11 10:04:26 +02:00
										 |  |  |                 err = stderr.getvalue() | 
					
						
							|  |  |  |                 self.assertIn('the --nowindows (-n) option is deprecated', err) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_forever(self): | 
					
						
							|  |  |  |         for opt in '-F', '--forever': | 
					
						
							|  |  |  |             with self.subTest(opt=opt): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |                 ns = libregrtest._parse_args([opt]) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |                 self.assertTrue(ns.forever) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_unrecognized_argument(self): | 
					
						
							|  |  |  |         self.checkError(['--xxx'], 'usage:') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_long_option__partial(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--qui']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertTrue(ns.quiet) | 
					
						
							|  |  |  |         self.assertEqual(ns.verbose, 0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_two_options(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--quiet', '--exclude']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertTrue(ns.quiet) | 
					
						
							|  |  |  |         self.assertEqual(ns.verbose, 0) | 
					
						
							|  |  |  |         self.assertTrue(ns.exclude) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_option_with_empty_string_value(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--start', '']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.start, '') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_arg(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['foo']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertEqual(ns.args, ['foo']) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_option_and_arg(self): | 
					
						
							| 
									
										
										
										
											2015-09-26 10:38:01 +02:00
										 |  |  |         ns = libregrtest._parse_args(['--quiet', 'foo']) | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |         self.assertTrue(ns.quiet) | 
					
						
							|  |  |  |         self.assertEqual(ns.verbose, 0) | 
					
						
							|  |  |  |         self.assertEqual(ns.args, ['foo']) | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | class BaseTestCase(unittest.TestCase): | 
					
						
							|  |  |  |     TEST_UNIQUE_ID = 1 | 
					
						
							|  |  |  |     TESTNAME_PREFIX = 'test_regrtest_' | 
					
						
							| 
									
										
										
										
											2016-03-23 12:14:10 +01:00
										 |  |  |     TESTNAME_REGEX = r'test_[a-zA-Z0-9_]+' | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def setUp(self): | 
					
						
							| 
									
										
										
										
											2015-11-22 15:18:54 +01:00
										 |  |  |         self.testdir = os.path.realpath(os.path.dirname(__file__)) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # When test_regrtest is interrupted by CTRL+c, it can leave | 
					
						
							|  |  |  |         # temporary test files | 
					
						
							|  |  |  |         remove = [entry.path | 
					
						
							|  |  |  |                   for entry in os.scandir(self.testdir) | 
					
						
							|  |  |  |                   if (entry.name.startswith(self.TESTNAME_PREFIX) | 
					
						
							|  |  |  |                       and entry.name.endswith(".py"))] | 
					
						
							|  |  |  |         for path in remove: | 
					
						
							|  |  |  |             print("WARNING: test_regrtest: remove %s" % path) | 
					
						
							|  |  |  |             support.unlink(path) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def create_test(self, name=None, code=''): | 
					
						
							|  |  |  |         if not name: | 
					
						
							|  |  |  |             name = 'noop%s' % BaseTestCase.TEST_UNIQUE_ID | 
					
						
							|  |  |  |             BaseTestCase.TEST_UNIQUE_ID += 1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # test_regrtest cannot be run twice in parallel because | 
					
						
							|  |  |  |         # of setUp() and create_test() | 
					
						
							|  |  |  |         name = self.TESTNAME_PREFIX + "%s_%s" % (os.getpid(), name) | 
					
						
							|  |  |  |         path = os.path.join(self.testdir, name + '.py') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         self.addCleanup(support.unlink, path) | 
					
						
							|  |  |  |         # Use 'x' mode to ensure that we do not override existing tests | 
					
						
							| 
									
										
										
										
											2015-11-22 15:18:54 +01:00
										 |  |  |         try: | 
					
						
							|  |  |  |             with open(path, 'x', encoding='utf-8') as fp: | 
					
						
							|  |  |  |                 fp.write(code) | 
					
						
							|  |  |  |         except PermissionError as exc: | 
					
						
							|  |  |  |             if not sysconfig.is_python_build(): | 
					
						
							|  |  |  |                 self.skipTest("cannot write %s: %s" % (path, exc)) | 
					
						
							|  |  |  |             raise | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         return name | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def regex_search(self, regex, output): | 
					
						
							|  |  |  |         match = re.search(regex, output, re.MULTILINE) | 
					
						
							|  |  |  |         if not match: | 
					
						
							|  |  |  |             self.fail("%r not found in %r" % (regex, output)) | 
					
						
							|  |  |  |         return match | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def check_line(self, output, regex): | 
					
						
							|  |  |  |         regex = re.compile(r'^' + regex, re.MULTILINE) | 
					
						
							|  |  |  |         self.assertRegex(output, regex) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def parse_executed_tests(self, output): | 
					
						
							| 
									
										
										
										
											2016-03-23 12:14:10 +01:00
										 |  |  |         regex = (r'^[0-9]+:[0-9]+:[0-9]+ \[ *[0-9]+(?:/ *[0-9]+)?\] (%s)' | 
					
						
							|  |  |  |                  % self.TESTNAME_REGEX) | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         parser = re.finditer(regex, output, re.MULTILINE) | 
					
						
							|  |  |  |         return list(match.group(1) for match in parser) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |     def check_executed_tests(self, output, tests, skipped=(), failed=(), | 
					
						
							| 
									
										
										
										
											2015-10-11 10:37:25 +02:00
										 |  |  |                              omitted=(), randomize=False): | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         if isinstance(tests, str): | 
					
						
							|  |  |  |             tests = [tests] | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         if isinstance(skipped, str): | 
					
						
							|  |  |  |             skipped = [skipped] | 
					
						
							|  |  |  |         if isinstance(failed, str): | 
					
						
							|  |  |  |             failed = [failed] | 
					
						
							| 
									
										
										
										
											2015-10-11 10:37:25 +02:00
										 |  |  |         if isinstance(omitted, str): | 
					
						
							|  |  |  |             omitted = [omitted] | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         ntest = len(tests) | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         nskipped = len(skipped) | 
					
						
							|  |  |  |         nfailed = len(failed) | 
					
						
							| 
									
										
										
										
											2015-10-11 10:37:25 +02:00
										 |  |  |         nomitted = len(omitted) | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         executed = self.parse_executed_tests(output) | 
					
						
							|  |  |  |         if randomize: | 
					
						
							|  |  |  |             self.assertEqual(set(executed), set(tests), output) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         else: | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |             self.assertEqual(executed, tests, output) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def plural(count): | 
					
						
							|  |  |  |             return 's' if count != 1 else '' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def list_regex(line_format, tests): | 
					
						
							|  |  |  |             count = len(tests) | 
					
						
							|  |  |  |             names = ' '.join(sorted(tests)) | 
					
						
							|  |  |  |             regex = line_format % (count, plural(count)) | 
					
						
							|  |  |  |             regex = r'%s:\n    %s$' % (regex, names) | 
					
						
							|  |  |  |             return regex | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if skipped: | 
					
						
							|  |  |  |             regex = list_regex('%s test%s skipped', skipped) | 
					
						
							|  |  |  |             self.check_line(output, regex) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if failed: | 
					
						
							|  |  |  |             regex = list_regex('%s test%s failed', failed) | 
					
						
							|  |  |  |             self.check_line(output, regex) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-11 10:37:25 +02:00
										 |  |  |         if omitted: | 
					
						
							|  |  |  |             regex = list_regex('%s test%s omitted', omitted) | 
					
						
							|  |  |  |             self.check_line(output, regex) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         good = ntest - nskipped - nfailed - nomitted | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         if good: | 
					
						
							|  |  |  |             regex = r'%s test%s OK\.$' % (good, plural(good)) | 
					
						
							|  |  |  |             if not skipped and not failed and good > 1: | 
					
						
							|  |  |  |                 regex = 'All %s' % regex | 
					
						
							|  |  |  |             self.check_line(output, regex) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def parse_random_seed(self, output): | 
					
						
							|  |  |  |         match = self.regex_search(r'Using random seed ([0-9]+)', output) | 
					
						
							|  |  |  |         randseed = int(match.group(1)) | 
					
						
							|  |  |  |         self.assertTrue(0 <= randseed <= 10000000, randseed) | 
					
						
							|  |  |  |         return randseed | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-03 00:20:56 +02:00
										 |  |  |     def run_command(self, args, input=None, exitcode=0, **kw): | 
					
						
							| 
									
										
										
										
											2015-09-29 14:17:09 +02:00
										 |  |  |         if not input: | 
					
						
							|  |  |  |             input = '' | 
					
						
							| 
									
										
										
										
											2015-10-03 00:20:56 +02:00
										 |  |  |         if 'stderr' not in kw: | 
					
						
							|  |  |  |             kw['stderr'] = subprocess.PIPE | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         proc = subprocess.run(args, | 
					
						
							|  |  |  |                               universal_newlines=True, | 
					
						
							|  |  |  |                               input=input, | 
					
						
							|  |  |  |                               stdout=subprocess.PIPE, | 
					
						
							| 
									
										
										
										
											2015-10-03 00:20:56 +02:00
										 |  |  |                               **kw) | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         if proc.returncode != exitcode: | 
					
						
							| 
									
										
										
										
											2015-10-03 00:20:56 +02:00
										 |  |  |             msg = ("Command %s failed with exit code %s\n" | 
					
						
							|  |  |  |                    "\n" | 
					
						
							|  |  |  |                    "stdout:\n" | 
					
						
							|  |  |  |                    "---\n" | 
					
						
							|  |  |  |                    "%s\n" | 
					
						
							|  |  |  |                    "---\n" | 
					
						
							|  |  |  |                    % (str(args), proc.returncode, proc.stdout)) | 
					
						
							|  |  |  |             if proc.stderr: | 
					
						
							|  |  |  |                 msg += ("\n" | 
					
						
							|  |  |  |                         "stderr:\n" | 
					
						
							|  |  |  |                         "---\n" | 
					
						
							|  |  |  |                         "%s" | 
					
						
							|  |  |  |                         "---\n" | 
					
						
							|  |  |  |                         % proc.stderr) | 
					
						
							|  |  |  |             self.fail(msg) | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         return proc | 
					
						
							| 
									
										
										
										
											2015-09-29 14:17:09 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def run_python(self, args, **kw): | 
					
						
							|  |  |  |         args = [sys.executable, '-X', 'faulthandler', '-I', *args] | 
					
						
							|  |  |  |         proc = self.run_command(args, **kw) | 
					
						
							|  |  |  |         return proc.stdout | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | class ProgramsTestCase(BaseTestCase): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Test various ways to run the Python test suite. Use options close | 
					
						
							|  |  |  |     to options used on the buildbot. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     NTEST = 4 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def setUp(self): | 
					
						
							|  |  |  |         super().setUp() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # Create NTEST tests doing nothing | 
					
						
							|  |  |  |         self.tests = [self.create_test() for index in range(self.NTEST)] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         self.python_args = ['-Wd', '-E', '-bb'] | 
					
						
							| 
									
										
										
										
											2015-10-11 10:03:28 +02:00
										 |  |  |         self.regrtest_args = ['-uall', '-rwW'] | 
					
						
							|  |  |  |         if hasattr(faulthandler, 'dump_traceback_later'): | 
					
						
							|  |  |  |             self.regrtest_args.extend(('--timeout', '3600', '-j4')) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         if sys.platform == 'win32': | 
					
						
							|  |  |  |             self.regrtest_args.append('-n') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def check_output(self, output): | 
					
						
							|  |  |  |         self.parse_random_seed(output) | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         self.check_executed_tests(output, self.tests, randomize=True) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def run_tests(self, args): | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         output = self.run_python(args) | 
					
						
							|  |  |  |         self.check_output(output) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_script_regrtest(self): | 
					
						
							|  |  |  |         # Lib/test/regrtest.py | 
					
						
							| 
									
										
										
										
											2015-11-22 15:18:54 +01:00
										 |  |  |         script = os.path.join(self.testdir, 'regrtest.py') | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         args = [*self.python_args, script, *self.regrtest_args, *self.tests] | 
					
						
							|  |  |  |         self.run_tests(args) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_module_test(self): | 
					
						
							|  |  |  |         # -m test | 
					
						
							|  |  |  |         args = [*self.python_args, '-m', 'test', | 
					
						
							|  |  |  |                 *self.regrtest_args, *self.tests] | 
					
						
							|  |  |  |         self.run_tests(args) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_module_regrtest(self): | 
					
						
							|  |  |  |         # -m test.regrtest | 
					
						
							|  |  |  |         args = [*self.python_args, '-m', 'test.regrtest', | 
					
						
							|  |  |  |                 *self.regrtest_args, *self.tests] | 
					
						
							|  |  |  |         self.run_tests(args) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_module_autotest(self): | 
					
						
							|  |  |  |         # -m test.autotest | 
					
						
							|  |  |  |         args = [*self.python_args, '-m', 'test.autotest', | 
					
						
							|  |  |  |                 *self.regrtest_args, *self.tests] | 
					
						
							|  |  |  |         self.run_tests(args) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_module_from_test_autotest(self): | 
					
						
							|  |  |  |         # from test import autotest | 
					
						
							|  |  |  |         code = 'from test import autotest' | 
					
						
							|  |  |  |         args = [*self.python_args, '-c', code, | 
					
						
							|  |  |  |                 *self.regrtest_args, *self.tests] | 
					
						
							|  |  |  |         self.run_tests(args) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_script_autotest(self): | 
					
						
							|  |  |  |         # Lib/test/autotest.py | 
					
						
							| 
									
										
										
										
											2015-11-22 15:18:54 +01:00
										 |  |  |         script = os.path.join(self.testdir, 'autotest.py') | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         args = [*self.python_args, script, *self.regrtest_args, *self.tests] | 
					
						
							|  |  |  |         self.run_tests(args) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-22 15:18:54 +01:00
										 |  |  |     @unittest.skipUnless(sysconfig.is_python_build(), | 
					
						
							|  |  |  |                          'run_tests.py script is not installed') | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |     def test_tools_script_run_tests(self): | 
					
						
							|  |  |  |         # Tools/scripts/run_tests.py | 
					
						
							|  |  |  |         script = os.path.join(ROOT_DIR, 'Tools', 'scripts', 'run_tests.py') | 
					
						
							|  |  |  |         self.run_tests([script, *self.tests]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-29 01:02:37 +02:00
										 |  |  |     def run_batch(self, *args): | 
					
						
							| 
									
										
										
										
											2015-09-29 14:17:09 +02:00
										 |  |  |         proc = self.run_command(args) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         self.check_output(proc.stdout) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-22 15:18:54 +01:00
										 |  |  |     @unittest.skipUnless(sysconfig.is_python_build(), | 
					
						
							|  |  |  |                          'test.bat script is not installed') | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |     @unittest.skipUnless(sys.platform == 'win32', 'Windows only') | 
					
						
							|  |  |  |     def test_tools_buildbot_test(self): | 
					
						
							|  |  |  |         # Tools\buildbot\test.bat | 
					
						
							|  |  |  |         script = os.path.join(ROOT_DIR, 'Tools', 'buildbot', 'test.bat') | 
					
						
							| 
									
										
										
										
											2015-09-29 01:02:37 +02:00
										 |  |  |         test_args = [] | 
					
						
							|  |  |  |         if platform.architecture()[0] == '64bit': | 
					
						
							|  |  |  |             test_args.append('-x64')   # 64-bit build | 
					
						
							|  |  |  |         if not Py_DEBUG: | 
					
						
							|  |  |  |             test_args.append('+d')     # Release build, use python.exe | 
					
						
							|  |  |  |         self.run_batch(script, *test_args, *self.tests) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     @unittest.skipUnless(sys.platform == 'win32', 'Windows only') | 
					
						
							|  |  |  |     def test_pcbuild_rt(self): | 
					
						
							|  |  |  |         # PCbuild\rt.bat | 
					
						
							|  |  |  |         script = os.path.join(ROOT_DIR, r'PCbuild\rt.bat') | 
					
						
							| 
									
										
										
										
											2015-09-29 01:02:37 +02:00
										 |  |  |         rt_args = ["-q"]             # Quick, don't run tests twice | 
					
						
							|  |  |  |         if platform.architecture()[0] == '64bit': | 
					
						
							|  |  |  |             rt_args.append('-x64')   # 64-bit build | 
					
						
							|  |  |  |         if Py_DEBUG: | 
					
						
							|  |  |  |             rt_args.append('-d')     # Debug build, use python_d.exe | 
					
						
							|  |  |  |         self.run_batch(script, *rt_args, *self.regrtest_args, *self.tests) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ArgsTestCase(BaseTestCase): | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  |     Test arguments of the Python test suite. | 
					
						
							|  |  |  |     """
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |     def run_tests(self, *args, **kw): | 
					
						
							|  |  |  |         return self.run_python(['-m', 'test', *args], **kw) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_failing_test(self): | 
					
						
							|  |  |  |         # test a failing test | 
					
						
							|  |  |  |         code = textwrap.dedent("""
 | 
					
						
							|  |  |  |             import unittest | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             class FailingTest(unittest.TestCase): | 
					
						
							|  |  |  |                 def test_failing(self): | 
					
						
							|  |  |  |                     self.fail("bug") | 
					
						
							|  |  |  |         """)
 | 
					
						
							|  |  |  |         test_ok = self.create_test() | 
					
						
							|  |  |  |         test_failing = self.create_test(code=code) | 
					
						
							|  |  |  |         tests = [test_ok, test_failing] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         output = self.run_tests(*tests, exitcode=1) | 
					
						
							|  |  |  |         self.check_executed_tests(output, tests, failed=test_failing) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_resources(self): | 
					
						
							|  |  |  |         # test -u command line option | 
					
						
							|  |  |  |         tests = {} | 
					
						
							|  |  |  |         for resource in ('audio', 'network'): | 
					
						
							|  |  |  |             code = 'from test import support\nsupport.requires(%r)' % resource | 
					
						
							|  |  |  |             tests[resource] = self.create_test(resource, code) | 
					
						
							|  |  |  |         test_names = sorted(tests.values()) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # -u all: 2 resources enabled | 
					
						
							|  |  |  |         output = self.run_tests('-u', 'all', *test_names) | 
					
						
							|  |  |  |         self.check_executed_tests(output, test_names) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # -u audio: 1 resource enabled | 
					
						
							|  |  |  |         output = self.run_tests('-uaudio', *test_names) | 
					
						
							|  |  |  |         self.check_executed_tests(output, test_names, | 
					
						
							|  |  |  |                                   skipped=tests['network']) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # no option: 0 resources enabled | 
					
						
							|  |  |  |         output = self.run_tests(*test_names) | 
					
						
							|  |  |  |         self.check_executed_tests(output, test_names, | 
					
						
							|  |  |  |                                   skipped=test_names) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_random(self): | 
					
						
							|  |  |  |         # test -r and --randseed command line option | 
					
						
							|  |  |  |         code = textwrap.dedent("""
 | 
					
						
							|  |  |  |             import random | 
					
						
							|  |  |  |             print("TESTRANDOM: %s" % random.randint(1, 1000)) | 
					
						
							|  |  |  |         """)
 | 
					
						
							|  |  |  |         test = self.create_test('random', code) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # first run to get the output with the random seed | 
					
						
							|  |  |  |         output = self.run_tests('-r', test) | 
					
						
							|  |  |  |         randseed = self.parse_random_seed(output) | 
					
						
							|  |  |  |         match = self.regex_search(r'TESTRANDOM: ([0-9]+)', output) | 
					
						
							|  |  |  |         test_random = int(match.group(1)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # try to reproduce with the random seed | 
					
						
							|  |  |  |         output = self.run_tests('-r', '--randseed=%s' % randseed, test) | 
					
						
							|  |  |  |         randseed2 = self.parse_random_seed(output) | 
					
						
							|  |  |  |         self.assertEqual(randseed2, randseed) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         match = self.regex_search(r'TESTRANDOM: ([0-9]+)', output) | 
					
						
							|  |  |  |         test_random2 = int(match.group(1)) | 
					
						
							|  |  |  |         self.assertEqual(test_random2, test_random) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_fromfile(self): | 
					
						
							|  |  |  |         # test --fromfile | 
					
						
							|  |  |  |         tests = [self.create_test() for index in range(5)] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # Write the list of files using a format similar to regrtest output: | 
					
						
							|  |  |  |         # [1/2] test_1 | 
					
						
							|  |  |  |         # [2/2] test_2 | 
					
						
							|  |  |  |         filename = support.TESTFN | 
					
						
							|  |  |  |         self.addCleanup(support.unlink, filename) | 
					
						
							| 
									
										
										
										
											2016-03-24 09:43:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # test format '0:00:00 [2/7] test_opcodes -- test_grammar took 0 sec' | 
					
						
							|  |  |  |         with open(filename, "w") as fp: | 
					
						
							|  |  |  |             previous = None | 
					
						
							|  |  |  |             for index, name in enumerate(tests, 1): | 
					
						
							|  |  |  |                 line = ("00:00:%02i [%s/%s] %s" | 
					
						
							|  |  |  |                         % (index, index, len(tests), name)) | 
					
						
							|  |  |  |                 if previous: | 
					
						
							|  |  |  |                     line += " -- %s took 0 sec" % previous | 
					
						
							|  |  |  |                 print(line, file=fp) | 
					
						
							|  |  |  |                 previous = name | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         output = self.run_tests('--fromfile', filename) | 
					
						
							|  |  |  |         self.check_executed_tests(output, tests) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # test format '[2/7] test_opcodes' | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         with open(filename, "w") as fp: | 
					
						
							|  |  |  |             for index, name in enumerate(tests, 1): | 
					
						
							|  |  |  |                 print("[%s/%s] %s" % (index, len(tests), name), file=fp) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         output = self.run_tests('--fromfile', filename) | 
					
						
							|  |  |  |         self.check_executed_tests(output, tests) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-24 09:43:00 +01:00
										 |  |  |         # test format 'test_opcodes' | 
					
						
							|  |  |  |         with open(filename, "w") as fp: | 
					
						
							|  |  |  |             for name in tests: | 
					
						
							|  |  |  |                 print(name, file=fp) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         output = self.run_tests('--fromfile', filename) | 
					
						
							|  |  |  |         self.check_executed_tests(output, tests) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-11 10:37:25 +02:00
										 |  |  |     def test_interrupted(self): | 
					
						
							|  |  |  |         code = TEST_INTERRUPTED | 
					
						
							|  |  |  |         test = self.create_test("sigint", code=code) | 
					
						
							|  |  |  |         output = self.run_tests(test, exitcode=1) | 
					
						
							|  |  |  |         self.check_executed_tests(output, test, omitted=test) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |     def test_slow(self): | 
					
						
							|  |  |  |         # test --slow | 
					
						
							|  |  |  |         tests = [self.create_test() for index in range(3)] | 
					
						
							|  |  |  |         output = self.run_tests("--slow", *tests) | 
					
						
							|  |  |  |         self.check_executed_tests(output, tests) | 
					
						
							|  |  |  |         regex = ('10 slowest tests:\n' | 
					
						
							|  |  |  |                  '(?:%s: [0-9]+\.[0-9]+s\n){%s}' | 
					
						
							|  |  |  |                  % (self.TESTNAME_REGEX, len(tests))) | 
					
						
							|  |  |  |         self.check_line(output, regex) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-11 10:37:25 +02:00
										 |  |  |     def test_slow_interrupted(self): | 
					
						
							|  |  |  |         # Issue #25373: test --slow with an interrupted test | 
					
						
							|  |  |  |         code = TEST_INTERRUPTED | 
					
						
							|  |  |  |         test = self.create_test("sigint", code=code) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for multiprocessing in (False, True): | 
					
						
							|  |  |  |             if multiprocessing: | 
					
						
							|  |  |  |                 args = ("--slow", "-j2", test) | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 args = ("--slow", test) | 
					
						
							|  |  |  |             output = self.run_tests(*args, exitcode=1) | 
					
						
							|  |  |  |             self.check_executed_tests(output, test, omitted=test) | 
					
						
							|  |  |  |             regex = ('10 slowest tests:\n') | 
					
						
							|  |  |  |             self.check_line(output, regex) | 
					
						
							|  |  |  |             self.check_line(output, 'Test suite interrupted by signal SIGINT.') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |     def test_coverage(self): | 
					
						
							|  |  |  |         # test --coverage | 
					
						
							|  |  |  |         test = self.create_test() | 
					
						
							|  |  |  |         output = self.run_tests("--coverage", test) | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |         self.check_executed_tests(output, [test]) | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  |         regex = ('lines +cov% +module +\(path\)\n' | 
					
						
							|  |  |  |                  '(?: *[0-9]+ *[0-9]{1,2}% *[^ ]+ +\([^)]+\)+)+') | 
					
						
							|  |  |  |         self.check_line(output, regex) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-29 14:17:09 +02:00
										 |  |  |     def test_wait(self): | 
					
						
							|  |  |  |         # test --wait | 
					
						
							|  |  |  |         test = self.create_test() | 
					
						
							|  |  |  |         output = self.run_tests("--wait", test, input='key') | 
					
						
							|  |  |  |         self.check_line(output, 'Press any key to continue') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-30 13:51:17 +02:00
										 |  |  |     def test_forever(self): | 
					
						
							|  |  |  |         # test --forever | 
					
						
							|  |  |  |         code = textwrap.dedent("""
 | 
					
						
							|  |  |  |             import unittest | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             class ForeverTester(unittest.TestCase): | 
					
						
							|  |  |  |                 RUN = 1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 def test_run(self): | 
					
						
							|  |  |  |                     ForeverTester.RUN += 1 | 
					
						
							|  |  |  |                     if ForeverTester.RUN > 3: | 
					
						
							|  |  |  |                         self.fail("fail at the 3rd runs") | 
					
						
							|  |  |  |         """)
 | 
					
						
							|  |  |  |         test = self.create_test(code=code) | 
					
						
							|  |  |  |         output = self.run_tests('--forever', test, exitcode=1) | 
					
						
							|  |  |  |         self.check_executed_tests(output, [test]*3, failed=test) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-03 02:21:35 +02:00
										 |  |  |     @unittest.skipUnless(Py_DEBUG, 'need a debug build') | 
					
						
							| 
									
										
										
										
											2015-10-03 00:20:56 +02:00
										 |  |  |     def test_huntrleaks_fd_leak(self): | 
					
						
							|  |  |  |         # test --huntrleaks for file descriptor leak | 
					
						
							|  |  |  |         code = textwrap.dedent("""
 | 
					
						
							|  |  |  |             import os | 
					
						
							|  |  |  |             import unittest | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-03 21:40:21 +02:00
										 |  |  |             # Issue #25306: Disable popups and logs to stderr on assertion | 
					
						
							|  |  |  |             # failures in MSCRT | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 import msvcrt | 
					
						
							|  |  |  |                 msvcrt.CrtSetReportMode | 
					
						
							|  |  |  |             except (ImportError, AttributeError): | 
					
						
							|  |  |  |                 # no Windows, o release build | 
					
						
							|  |  |  |                 pass | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 for m in [msvcrt.CRT_WARN, msvcrt.CRT_ERROR, msvcrt.CRT_ASSERT]: | 
					
						
							|  |  |  |                     msvcrt.CrtSetReportMode(m, 0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-03 00:20:56 +02:00
										 |  |  |             class FDLeakTest(unittest.TestCase): | 
					
						
							|  |  |  |                 def test_leak(self): | 
					
						
							|  |  |  |                     fd = os.open(__file__, os.O_RDONLY) | 
					
						
							|  |  |  |                     # bug: never cloes the file descriptor | 
					
						
							|  |  |  |         """)
 | 
					
						
							|  |  |  |         test = self.create_test(code=code) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         filename = 'reflog.txt' | 
					
						
							|  |  |  |         self.addCleanup(support.unlink, filename) | 
					
						
							|  |  |  |         output = self.run_tests('--huntrleaks', '3:3:', test, | 
					
						
							|  |  |  |                                 exitcode=1, | 
					
						
							|  |  |  |                                 stderr=subprocess.STDOUT) | 
					
						
							|  |  |  |         self.check_executed_tests(output, [test], failed=test) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         line = 'beginning 6 repetitions\n123456\n......\n' | 
					
						
							|  |  |  |         self.check_line(output, re.escape(line)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         line2 = '%s leaked [1, 1, 1] file descriptors, sum=3\n' % test | 
					
						
							|  |  |  |         self.check_line(output, re.escape(line2)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         with open(filename) as fp: | 
					
						
							|  |  |  |             reflog = fp.read() | 
					
						
							|  |  |  |             self.assertEqual(reflog, line2) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-03 00:21:12 +02:00
										 |  |  |     def test_list_tests(self): | 
					
						
							|  |  |  |         # test --list-tests | 
					
						
							|  |  |  |         tests = [self.create_test() for i in range(5)] | 
					
						
							|  |  |  |         output = self.run_tests('--list-tests', *tests) | 
					
						
							|  |  |  |         self.assertEqual(output.rstrip().splitlines(), | 
					
						
							|  |  |  |                          tests) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-28 23:16:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-27 18:53:12 -08:00
										 |  |  | if __name__ == '__main__': | 
					
						
							| 
									
										
										
										
											2013-08-29 12:26:23 +03:00
										 |  |  |     unittest.main() |