| 
									
										
										
										
											1992-01-27 17:00:37 +00:00
										 |  |  | # Python test set -- part 3, built-in operations. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | print '3. Operations' | 
					
						
							| 
									
										
										
										
											2000-08-31 19:48:52 +00:00
										 |  |  | print 'XXX Mostly not yet implemented' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | print '3.1 Dictionary lookups succeed even if __cmp__() raises an exception' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # SourceForge bug #112558: | 
					
						
							|  |  |  | # http://sourceforge.net/bugs/?func=detailbug&bug_id=112558&group_id=5470 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-10-23 17:22:08 +00:00
										 |  |  | class BadDictKey: | 
					
						
							| 
									
										
										
										
											2001-05-29 21:14:32 +00:00
										 |  |  |     already_printed_raising_error = 0 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-10-23 17:22:08 +00:00
										 |  |  |     def __hash__(self): | 
					
						
							|  |  |  |         return hash(self.__class__) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def __cmp__(self, other): | 
					
						
							|  |  |  |         if isinstance(other, self.__class__): | 
					
						
							| 
									
										
										
										
											2001-05-29 21:14:32 +00:00
										 |  |  |             if not BadDictKey.already_printed_raising_error: | 
					
						
							|  |  |  |                 # How many times __cmp__ gets called depends on the hash | 
					
						
							|  |  |  |                 # code and the internals of the dict implementation; we | 
					
						
							|  |  |  |                 # know it will be called at least once, but that's it. | 
					
						
							|  |  |  |                 # already_printed_raising_error makes sure the expected- | 
					
						
							|  |  |  |                 # output file prints the msg at most once. | 
					
						
							|  |  |  |                 BadDictKey.already_printed_raising_error = 1 | 
					
						
							|  |  |  |                 print "raising error" | 
					
						
							| 
									
										
										
										
											2000-10-23 17:22:08 +00:00
										 |  |  |             raise RuntimeError, "gotcha" | 
					
						
							|  |  |  |         return other | 
					
						
							| 
									
										
										
										
											2000-08-31 19:48:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | d = {} | 
					
						
							|  |  |  | x1 = BadDictKey() | 
					
						
							|  |  |  | x2 = BadDictKey() | 
					
						
							|  |  |  | d[x1] = 1 | 
					
						
							|  |  |  | d[x2] = 2 | 
					
						
							|  |  |  | print "No exception passed through." | 
					
						
							| 
									
										
										
										
											2001-05-23 23:33:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Dict resizing bug, found by Jack Jansen in 2.2 CVS development. | 
					
						
							|  |  |  | # This version got an assert failure in debug build, infinite loop in | 
					
						
							|  |  |  | # release build.  Unfortunately, provoking this kind of stuff requires | 
					
						
							|  |  |  | # a mix of inserts and deletes hitting exactly the right hash codes in | 
					
						
							|  |  |  | # exactly the right order, and I can't think of a randomized approach | 
					
						
							|  |  |  | # that would be *likely* to hit a failing case in reasonable time. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | d = {} | 
					
						
							|  |  |  | for i in range(5): | 
					
						
							|  |  |  |     d[i] = i | 
					
						
							|  |  |  | for i in range(5): | 
					
						
							|  |  |  |     del d[i] | 
					
						
							|  |  |  | for i in range(5, 9):  # i==8 was the problem | 
					
						
							|  |  |  |     d[i] = i |