-
Notifications
You must be signed in to change notification settings - Fork 330
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Python 3.11 changes behavior how enums are formatted as string #447
Comments
A regression error introduced in a .01 update! Good grief. |
@OrangeTux - I would suggest we go with Solution 1 - in looks cleaner and more logical moving forward with new Python versions; that at some stage, long into the future, the ImportError handling could be removed without refactoring the rest of the code? |
@OrangeTux - Another option may be this, I think this could be non-breaking too (introduced in 3.6)?
===================================================================================================== test session starts ====================================================================================================== test_enum.py . [100%] ====================================================================================================== 1 passed in 0.00s ======================================================================================================= ===================================================================================================== test session starts ====================================================================================================== tests/test_enum.py . [100%] ====================================================================================================== 1 passed in 0.00s ======================================================================================================= |
Related ticket has this same behaviour, see comments in #433 |
That's a clever solution. I didn't knew of this
|
I suggest that we pick Solution #1. |
- [#544](mobilityhouse/ocpp#544) Pass `Call.unique_id` to the `on` and `after` routing handlers. - [#559](mobilityhouse/ocpp#559) Update project dependencies as of 22-12-2023 - [#447](mobilityhouse/ocpp#447) Make formatting of enums in py3.11 consistent with earlier Python versions - [#421](mobilityhouse/ocpp#421) Type of v16.datatypes.SampledValue.context is incorrect
…ith Python 3.11+ (#5397) # Description Fix the following unit test failure when running with Python 3.11+. More background information about this issue is discussed in mobilityhouse/ocpp#447. ``` FAIL: test_create_endpoint_dbt_yaml_with_parent_pipelines (tests.api.endpoints.test_blocks.DBTBlockAPIEndpointTest.test_create_endpoint_dbt_yaml_with_parent_pipelines) ---------------------------------------------------------------------- Traceback (most recent call last): File "/usr/local/Cellar/python@3.12/3.12.5/Frameworks/Python.framework/Versions/3.12/lib/python3.12/unittest/async_case.py", line 90, in _callTestMethod if self._callMaybeAsync(method) is not None: ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/usr/local/Cellar/python@3.12/3.12.5/Frameworks/Python.framework/Versions/3.12/lib/python3.12/unittest/async_case.py", line 112, in _callMaybeAsync return self._asyncioRunner.run( ^^^^^^^^^^^^^^^^^^^^^^^^ File "/usr/local/Cellar/python@3.12/3.12.5/Frameworks/Python.framework/Versions/3.12/lib/python3.12/asyncio/runners.py", line 118, in run return self._loop.run_until_complete(task) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/usr/local/Cellar/python@3.12/3.12.5/Frameworks/Python.framework/Versions/3.12/lib/python3.12/asyncio/base_events.py", line 687, in run_until_complete return future.result() ^^^^^^^^^^^^^^^ File "/Users/hw/workspace/dev/mage-ai/mage_ai/tests/api/endpoints/mixins.py", line 247, in _test_create_endpoint await self.build_test_create_endpoint( File "/Users/hw/workspace/dev/mage-ai/mage_ai/tests/api/endpoints/mixins.py", line 813, in build_test_create_endpoint validation = assert_after_create_count(self) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/Users/hw/workspace/dev/mage-ai/mage_ai/tests/api/endpoints/test_blocks.py", line 154, in __assert_after_create_yaml self.assertEqual({ AssertionError: {'dbt[56 chars]h': 'dbts/dbt_yaml.yaml', 'project_path': 'dbt/test_project'}} != {'dbt[56 chars]h': 'BlockType.DBTs/dbt_yaml.yaml', 'project_p[21 chars]ct'}} {'dbt_project_name': 'dbt/test_project', - 'file_source': {'path': 'dbts/dbt_yaml.yaml', ? ^^^ + 'file_source': {'path': 'BlockType.DBTs/dbt_yaml.yaml', ? ^^^^^^^^^^^^^ 'project_path': 'dbt/test_project'}} ---------------------------------------------------------------------- Ran 27 tests in 2.061s FAILED (failures=1) ``` # How Has This Been Tested? <!-- Please describe the tests that you ran to verify your changes. Provide instructions so we can reproduce. --> - [X] Tested with a local development environment. # Checklist - [ ] The PR is tagged with proper labels (bug, enhancement, feature, documentation) - [X] I have performed a self-review of my own code - [ ] I have added unit tests that prove my fix is effective or that my feature works - [ ] I have commented my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation cc: <!-- Optionally mention someone to let them know about this pull request --> @wangxiaoyou1993
…sions (mobilityhouse#550) Python 3.11 changes the behavior of `enum.Enum.__format__()` slightly. f-strings (and a few other string formatting methods) rely on dunder method `__format___()`. This change makes the formatting of enums as strings consistent among all supported Python versions. Fixes mobilityhouse#447
- [mobilityhouse#544](mobilityhouse#544) Pass `Call.unique_id` to the `on` and `after` routing handlers. - [mobilityhouse#559](mobilityhouse#559) Update project dependencies as of 22-12-2023 - [mobilityhouse#447](mobilityhouse#447) Make formatting of enums in py3.11 consistent with earlier Python versions - [mobilityhouse#421](mobilityhouse#421) Type of v16.datatypes.SampledValue.context is incorrect
@proelke made me aware about a changes to Python 3.11 that introduce subtle changes to all enums that subclass from both
str
andenum.Enum
. Practically all enums defined in this library are subclassed from these 2 classes.Consider the following code:
The underlying cause is that Python 3.11 changes the behavior of
enum.Enum.__format__()
slightly.f-strings
(and a few other string formatting methods) rely on dunder method__format___()
.So far, I considered two solutions.
Solution 1: StrEnum
Python 3.11 introduces
enum.StrEnum
. One could implement a solution as described at https://tomwojcik.com/posts/2023-01-02/python-311-str-enum-breaking-changeManually implement
__format__()
The other solution is to implement
__format__()
manually.See also
The text was updated successfully, but these errors were encountered: