| 
									
										
										
										
											2001-01-13 03:04:02 +00:00
										 |  |  | """
 | 
					
						
							|  |  |  | Create and delete FILES_PER_THREAD temp files (via tempfile.TemporaryFile) | 
					
						
							|  |  |  | in each of NUM_THREADS threads, recording the number of successes and | 
					
						
							|  |  |  | failures.  A failure is a bug in tempfile, and may be due to: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + Trying to create more than one tempfile with the same name. | 
					
						
							|  |  |  | + Trying to delete a tempfile that doesn't still exist. | 
					
						
							|  |  |  | + Something we've never seen before. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | By default, NUM_THREADS == 20 and FILES_PER_THREAD == 50.  This is enough to | 
					
						
							|  |  |  | create about 150 failures per run under Win98SE in 2.0, and runs pretty | 
					
						
							|  |  |  | quickly. Guido reports needing to boost FILES_PER_THREAD to 500 before | 
					
						
							|  |  |  | provoking a 2.0 failure under Linux.  Run the test alone to boost either | 
					
						
							|  |  |  | via cmdline switches: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | -f  FILES_PER_THREAD (int) | 
					
						
							|  |  |  | -t  NUM_THREADS (int) | 
					
						
							|  |  |  | """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | NUM_THREADS = 20        # change w/ -t option | 
					
						
							|  |  |  | FILES_PER_THREAD = 50   # change w/ -f option | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-14 14:35:43 +00:00
										 |  |  | import thread # If this fails, we can't test this module | 
					
						
							| 
									
										
										
										
											2001-01-13 03:04:02 +00:00
										 |  |  | import threading | 
					
						
							| 
									
										
										
										
											2002-07-23 19:04:11 +00:00
										 |  |  | from test.test_support import TestFailed | 
					
						
							| 
									
										
										
										
											2001-01-13 03:04:02 +00:00
										 |  |  | import StringIO | 
					
						
							|  |  |  | from traceback import print_exc | 
					
						
							| 
									
										
										
										
											2002-09-25 20:32:28 +00:00
										 |  |  | import tempfile | 
					
						
							| 
									
										
										
										
											2001-01-13 03:04:02 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | startEvent = threading.Event() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class TempFileGreedy(threading.Thread): | 
					
						
							|  |  |  |     error_count = 0 | 
					
						
							|  |  |  |     ok_count = 0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def run(self): | 
					
						
							|  |  |  |         self.errors = StringIO.StringIO() | 
					
						
							|  |  |  |         startEvent.wait() | 
					
						
							|  |  |  |         for i in range(FILES_PER_THREAD): | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 f = tempfile.TemporaryFile("w+b") | 
					
						
							|  |  |  |                 f.close() | 
					
						
							|  |  |  |             except: | 
					
						
							|  |  |  |                 self.error_count += 1 | 
					
						
							|  |  |  |                 print_exc(file=self.errors) | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 self.ok_count += 1 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-09-25 20:32:28 +00:00
										 |  |  | def test_main(): | 
					
						
							| 
									
										
										
										
											2001-01-13 03:04:02 +00:00
										 |  |  |     threads = [] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     print "Creating" | 
					
						
							|  |  |  |     for i in range(NUM_THREADS): | 
					
						
							|  |  |  |         t = TempFileGreedy() | 
					
						
							|  |  |  |         threads.append(t) | 
					
						
							|  |  |  |         t.start() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     print "Starting" | 
					
						
							|  |  |  |     startEvent.set() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     print "Reaping" | 
					
						
							|  |  |  |     ok = errors = 0 | 
					
						
							|  |  |  |     for t in threads: | 
					
						
							|  |  |  |         t.join() | 
					
						
							|  |  |  |         ok += t.ok_count | 
					
						
							|  |  |  |         errors += t.error_count | 
					
						
							|  |  |  |         if t.error_count: | 
					
						
							|  |  |  |             print '%s errors:\n%s' % (t.getName(), t.errors.getvalue()) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     msg = "Done: errors %d ok %d" % (errors, ok) | 
					
						
							|  |  |  |     print msg | 
					
						
							|  |  |  |     if errors: | 
					
						
							|  |  |  |         raise TestFailed(msg) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-09-25 20:32:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-01-13 03:04:02 +00:00
										 |  |  | if __name__ == "__main__": | 
					
						
							|  |  |  |     import sys, getopt | 
					
						
							|  |  |  |     opts, args = getopt.getopt(sys.argv[1:], "t:f:") | 
					
						
							|  |  |  |     for o, v in opts: | 
					
						
							|  |  |  |         if o == "-f": | 
					
						
							|  |  |  |             FILES_PER_THREAD = int(v) | 
					
						
							|  |  |  |         elif o == "-t": | 
					
						
							|  |  |  |             NUM_THREADS = int(v) | 
					
						
							| 
									
										
										
										
											2002-09-25 20:32:28 +00:00
										 |  |  |     test_main() |