Skip to content

Conversation

@lokhandelokeek11
Copy link

@lokhandelokeek11 lokhandelokeek11 commented Jun 16, 2025

This PR fixes issue [#135559]

Previously, dir() on IntFlag instances omitted named aliases (e.g., READ_WRITE = READ | WRITE).
This change updates the dir method in enum.py to include all named members, including aliases, by checking members where name is not None.
Also added a test in test_enum.py to validate the behavior.
I wasn’t able to run the full test suite locally due to build setup issues @ethanfurman, but the logic is isolated and verified through reasoning and test inclusion.

@python-cla-bot
Copy link

python-cla-bot bot commented Jun 16, 2025

All commit authors signed the Contributor License Agreement.

CLA signed

@bedevere-app
Copy link

bedevere-app bot commented Jun 16, 2025

Most changes to Python require a NEWS entry. Add one using the blurb_it web app or the blurb command-line tool.

If this change has little impact on Python users, wait for a maintainer to apply the skip news label instead.

@bedevere-app
Copy link

bedevere-app bot commented Jun 16, 2025

Most changes to Python require a NEWS entry. Add one using the blurb_it web app or the blurb command-line tool.

If this change has little impact on Python users, wait for a maintainer to apply the skip news label instead.

@ZeroIntensity ZeroIntensity changed the title Fix Issue #135559: Include named aliases in dir() for IntFlag instances gh-135559: Include named aliases in dir() for IntFlag instances Jun 16, 2025
class TestIntFlagClass(_EnumTests, _MinimalOutputTests, _FlagTests, unittest.TestCase):
enum_type = IntFlag

def test_dir_includes_named_aliases():
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This won't work :(
Since we use unittest and not pytest. Please, rewrite this test.

WRITE = 2
READ_WRITE = READ | WRITE

assert 'READ_WRITE' in dir(MyFlags.READ_WRITE)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We use self.assert* methods here.
Please, add checks for all related names, not only a single one.

I would propose to add more combitations of values to the test.

@ethanfurman
Copy link
Member

Several weeks have passed with no communications from @lokhandelokeek11 and multiple problems with the PR.

Closing.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants