mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 11:14:33 +00:00 
			
		
		
		
	Issue22506: merge from 3.4
This commit is contained in:
		
						commit
						987f3dd161
					
				
					 2 changed files with 18 additions and 1 deletions
				
			
		|  | @ -464,7 +464,12 @@ def __str__(self): | |||
|         return "%s.%s" % (self.__class__.__name__, self._name_) | ||||
| 
 | ||||
|     def __dir__(self): | ||||
|         added_behavior = [m for m in self.__class__.__dict__ if m[0] != '_'] | ||||
|         added_behavior = [ | ||||
|                 m | ||||
|                 for cls in self.__class__.mro() | ||||
|                 for m in cls.__dict__ | ||||
|                 if m[0] != '_' | ||||
|                 ] | ||||
|         return (['__class__', '__doc__', '__module__', 'name', 'value'] + | ||||
|                 added_behavior) | ||||
| 
 | ||||
|  |  | |||
|  | @ -176,6 +176,18 @@ def wowser(self): | |||
|                 set(['__class__', '__doc__', '__module__', 'name', 'value', 'wowser']), | ||||
|                 ) | ||||
| 
 | ||||
|     def test_dir_on_sub_with_behavior_on_super(self): | ||||
|         # see issue22506 | ||||
|         class SuperEnum(Enum): | ||||
|             def invisible(self): | ||||
|                 return "did you see me?" | ||||
|         class SubEnum(SuperEnum): | ||||
|             sample = 5 | ||||
|         self.assertEqual( | ||||
|                 set(dir(SubEnum.sample)), | ||||
|                 set(['__class__', '__doc__', '__module__', 'name', 'value', 'invisible']), | ||||
|                 ) | ||||
| 
 | ||||
|     def test_enum_in_enum_out(self): | ||||
|         Season = self.Season | ||||
|         self.assertIs(Season(Season.WINTER), Season.WINTER) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ethan Furman
						Ethan Furman