@@ -377,19 +377,19 @@ def parse_executed_tests(self, output):
377377 return list (match .group (1 ) for match in parser )
378378
379379 def check_executed_tests (self , output , tests , skipped = (), failed = (),
380- omitted = (), randomize = False , interrupted = False ):
380+ env_changed = (), omitted = (),
381+ randomize = False , interrupted = False ,
382+ fail_env_changed = False ):
381383 if isinstance (tests , str ):
382384 tests = [tests ]
383385 if isinstance (skipped , str ):
384386 skipped = [skipped ]
385387 if isinstance (failed , str ):
386388 failed = [failed ]
389+ if isinstance (env_changed , str ):
390+ env_changed = [env_changed ]
387391 if isinstance (omitted , str ):
388392 omitted = [omitted ]
389- ntest = len (tests )
390- nskipped = len (skipped )
391- nfailed = len (failed )
392- nomitted = len (omitted )
393393
394394 executed = self .parse_executed_tests (output )
395395 if randomize :
@@ -415,11 +415,17 @@ def list_regex(line_format, tests):
415415 regex = list_regex ('%s test%s failed' , failed )
416416 self .check_line (output , regex )
417417
418+ if env_changed :
419+ regex = list_regex ('%s test%s altered the execution environment' ,
420+ env_changed )
421+ self .check_line (output , regex )
422+
418423 if omitted :
419424 regex = list_regex ('%s test%s omitted' , omitted )
420425 self .check_line (output , regex )
421426
422- good = ntest - nskipped - nfailed - nomitted
427+ good = (len (tests ) - len (skipped ) - len (failed )
428+ - len (omitted ) - len (env_changed ))
423429 if good :
424430 regex = r'%s test%s OK\.$' % (good , plural (good ))
425431 if not skipped and not failed and good > 1 :
@@ -429,10 +435,12 @@ def list_regex(line_format, tests):
429435 if interrupted :
430436 self .check_line (output , 'Test suite interrupted by signal SIGINT.' )
431437
432- if nfailed :
438+ if failed :
433439 result = 'FAILURE'
434440 elif interrupted :
435441 result = 'INTERRUPTED'
442+ elif fail_env_changed and env_changed :
443+ result = 'ENV CHANGED'
436444 else :
437445 result = 'SUCCESS'
438446 self .check_line (output , 'Tests result: %s' % result )
@@ -604,7 +612,7 @@ def test_failing(self):
604612 test_failing = self .create_test ('failing' , code = code )
605613 tests = [test_ok , test_failing ]
606614
607- output = self .run_tests (* tests , exitcode = 1 )
615+ output = self .run_tests (* tests , exitcode = 2 )
608616 self .check_executed_tests (output , tests , failed = test_failing )
609617
610618 def test_resources (self ):
@@ -703,7 +711,7 @@ def test_fromfile(self):
703711 def test_interrupted (self ):
704712 code = TEST_INTERRUPTED
705713 test = self .create_test ('sigint' , code = code )
706- output = self .run_tests (test , exitcode = 1 )
714+ output = self .run_tests (test , exitcode = 130 )
707715 self .check_executed_tests (output , test , omitted = test ,
708716 interrupted = True )
709717
@@ -732,7 +740,7 @@ def test_slow_interrupted(self):
732740 args = ("--slowest" , "-j2" , test )
733741 else :
734742 args = ("--slowest" , test )
735- output = self .run_tests (* args , exitcode = 1 )
743+ output = self .run_tests (* args , exitcode = 130 )
736744 self .check_executed_tests (output , test ,
737745 omitted = test , interrupted = True )
738746
@@ -772,7 +780,7 @@ def test_run(self):
772780 builtins.__dict__['RUN'] = 1
773781 """ )
774782 test = self .create_test ('forever' , code = code )
775- output = self .run_tests ('--forever' , test , exitcode = 1 )
783+ output = self .run_tests ('--forever' , test , exitcode = 2 )
776784 self .check_executed_tests (output , [test ]* 3 , failed = test )
777785
778786 @unittest .skipUnless (Py_DEBUG , 'need a debug build' )
@@ -804,7 +812,7 @@ def test_leak(self):
804812 filename = 'reflog.txt'
805813 self .addCleanup (support .unlink , filename )
806814 output = self .run_tests ('--huntrleaks' , '3:3:' , test ,
807- exitcode = 1 ,
815+ exitcode = 2 ,
808816 stderr = subprocess .STDOUT )
809817 self .check_executed_tests (output , [test ], failed = test )
810818
@@ -858,7 +866,7 @@ def test_crashed(self):
858866 ok_test = self .create_test (name = "ok" )
859867
860868 tests = [crash_test , ok_test ]
861- output = self .run_tests ("-j2" , * tests , exitcode = 1 )
869+ output = self .run_tests ("-j2" , * tests , exitcode = 2 )
862870 self .check_executed_tests (output , tests , failed = crash_test ,
863871 randomize = True )
864872
@@ -907,6 +915,25 @@ def test_method4(self):
907915 subset = ['test_method1' , 'test_method3' ]
908916 self .assertEqual (methods , subset )
909917
918+ def test_env_changed (self ):
919+ code = textwrap .dedent ("""
920+ import unittest
921+
922+ class Tests(unittest.TestCase):
923+ def test_env_changed(self):
924+ open("env_changed", "w").close()
925+ """ )
926+ testname = self .create_test (code = code )
927+
928+ # don't fail by default
929+ output = self .run_tests (testname )
930+ self .check_executed_tests (output , [testname ], env_changed = testname )
931+
932+ # fail with --fail-env-changed
933+ output = self .run_tests ("--fail-env-changed" , testname , exitcode = 3 )
934+ self .check_executed_tests (output , [testname ], env_changed = testname ,
935+ fail_env_changed = True )
936+
910937
911938if __name__ == '__main__' :
912939 unittest .main ()
0 commit comments