diff --git a/alembic_postgresql_enum/operations/sync_enum_values.py b/alembic_postgresql_enum/operations/sync_enum_values.py index 714fe9f..6380b13 100644 --- a/alembic_postgresql_enum/operations/sync_enum_values.py +++ b/alembic_postgresql_enum/operations/sync_enum_values.py @@ -204,11 +204,11 @@ def is_column_type_import_needed(self) -> bool: @alembic.autogenerate.render.renderers.dispatch_for(SyncEnumValuesOp) def render_sync_enum_value_op(autogen_context: AutogenContext, op: SyncEnumValuesOp): if op.is_column_type_import_needed: - autogen_context.imports.add("from alembic_postgresql_enum import ColumnType") - autogen_context.imports.add("from alembic_postgresql_enum import TableReference") + autogen_context.imports.add("from alembic_postgresql_enum import ColumnType # type: ignore[attr-defined]") + autogen_context.imports.add("from alembic_postgresql_enum import TableReference # type: ignore[attr-defined]") return ( - f"op.sync_enum_values({op.schema!r}, {op.name!r}, {op.new_values!r},\n" + f"op.sync_enum_values({op.schema!r}, {op.name!r}, {op.new_values!r}, # type: ignore[attr-defined]\n" f" {op.affected_columns!r},\n" f" enum_values_to_rename=[])" ) diff --git a/pyproject.toml b/pyproject.toml index 258e1f5..2bb7c12 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "alembic-postgresql-enum" -version = "1.3.0" +version = "1.3.1" description = "Alembic autogenerate support for creation, alteration and deletion of enums" authors = ["RustyGuard"] license = "MIT" diff --git a/tests/sync_enum_values/test_array_column.py b/tests/sync_enum_values/test_array_column.py index 82c43f8..0c6b87a 100644 --- a/tests/sync_enum_values/test_array_column.py +++ b/tests/sync_enum_values/test_array_column.py @@ -39,13 +39,14 @@ def test_add_new_enum_value_render_with_array(connection: "Connection"): autogenerate._render_migration_diffs(context, template_args) assert template_args["imports"] == ( - "from alembic_postgresql_enum import ColumnType" "\nfrom alembic_postgresql_enum import TableReference" + "from alembic_postgresql_enum import ColumnType # type: ignore[attr-defined]" + "\nfrom alembic_postgresql_enum import TableReference # type: ignore[attr-defined]" ) assert ( template_args["upgrades"] == f"""# ### commands auto generated by Alembic - please adjust! ### - op.sync_enum_values('{DEFAULT_SCHEMA}', '{CAR_COLORS_ENUM_NAME}', [{', '.join(map(repr, new_enum_variants))}], + op.sync_enum_values('{DEFAULT_SCHEMA}', '{CAR_COLORS_ENUM_NAME}', [{', '.join(map(repr, new_enum_variants))}], # type: ignore[attr-defined] [TableReference(table_schema='{DEFAULT_SCHEMA}', table_name='{CAR_TABLE_NAME}', column_name='{CAR_COLORS_COLUMN_NAME}', column_type=ColumnType.ARRAY)], enum_values_to_rename=[]) # ### end Alembic commands ###""" @@ -53,7 +54,7 @@ def test_add_new_enum_value_render_with_array(connection: "Connection"): assert ( template_args["downgrades"] == f"""# ### commands auto generated by Alembic - please adjust! ### - op.sync_enum_values('{DEFAULT_SCHEMA}', '{CAR_COLORS_ENUM_NAME}', [{', '.join(map(repr, old_enum_variants))}], + op.sync_enum_values('{DEFAULT_SCHEMA}', '{CAR_COLORS_ENUM_NAME}', [{', '.join(map(repr, old_enum_variants))}], # type: ignore[attr-defined] [TableReference(table_schema='{DEFAULT_SCHEMA}', table_name='{CAR_TABLE_NAME}', column_name='{CAR_COLORS_COLUMN_NAME}', column_type=ColumnType.ARRAY)], enum_values_to_rename=[]) # ### end Alembic commands ###""" diff --git a/tests/sync_enum_values/test_render.py b/tests/sync_enum_values/test_render.py index f100cae..3acf069 100644 --- a/tests/sync_enum_values/test_render.py +++ b/tests/sync_enum_values/test_render.py @@ -45,7 +45,7 @@ def test_add_new_enum_value_render(connection: "Connection"): assert ( template_args["upgrades"] == f"""# ### commands auto generated by Alembic - please adjust! ### - op.sync_enum_values('{DEFAULT_SCHEMA}', '{USER_STATUS_ENUM_NAME}', [{', '.join(map(repr, new_enum_variants))}], + op.sync_enum_values('{DEFAULT_SCHEMA}', '{USER_STATUS_ENUM_NAME}', [{', '.join(map(repr, new_enum_variants))}], # type: ignore[attr-defined] [TableReference(table_schema='{DEFAULT_SCHEMA}', table_name='{USER_TABLE_NAME}', column_name='{USER_STATUS_COLUMN_NAME}')], enum_values_to_rename=[]) # ### end Alembic commands ###""" @@ -53,7 +53,7 @@ def test_add_new_enum_value_render(connection: "Connection"): assert ( template_args["downgrades"] == f"""# ### commands auto generated by Alembic - please adjust! ### - op.sync_enum_values('{DEFAULT_SCHEMA}', '{USER_STATUS_ENUM_NAME}', [{', '.join(map(repr, old_enum_variants))}], + op.sync_enum_values('{DEFAULT_SCHEMA}', '{USER_STATUS_ENUM_NAME}', [{', '.join(map(repr, old_enum_variants))}], # type: ignore[attr-defined] [TableReference(table_schema='{DEFAULT_SCHEMA}', table_name='{USER_TABLE_NAME}', column_name='{USER_STATUS_COLUMN_NAME}')], enum_values_to_rename=[]) # ### end Alembic commands ###""" @@ -207,7 +207,7 @@ class ExampleTable(Base): def get_expected_upgrade(self) -> str: return """ # ### commands auto generated by Alembic - please adjust! ### - op.sync_enum_values('public', 'my_enum', ['one', 'two', 'three', 'four'], + op.sync_enum_values('public', 'my_enum', ['one', 'two', 'three', 'four'], # type: ignore[attr-defined] [TableReference(table_schema='public', table_name='example_table', column_name='enum_field', existing_server_default="'one'::my_enum")], enum_values_to_rename=[]) # ### end Alembic commands ### @@ -216,7 +216,7 @@ def get_expected_upgrade(self) -> str: def get_expected_downgrade(self) -> str: return """ # ### commands auto generated by Alembic - please adjust! ### - op.sync_enum_values('public', 'my_enum', ['one', 'two', 'three'], + op.sync_enum_values('public', 'my_enum', ['one', 'two', 'three'], # type: ignore[attr-defined] [TableReference(table_schema='public', table_name='example_table', column_name='enum_field', existing_server_default="'one'::my_enum")], enum_values_to_rename=[]) # ### end Alembic commands ### diff --git a/tests/sync_enum_values/test_run_array_new_column.py b/tests/sync_enum_values/test_run_array_new_column.py index 26d5451..00f2aa3 100644 --- a/tests/sync_enum_values/test_run_array_new_column.py +++ b/tests/sync_enum_values/test_run_array_new_column.py @@ -63,7 +63,7 @@ def get_expected_upgrade(self) -> str: return """ # ### commands auto generated by Alembic - please adjust! ### op.add_column('a', sa.Column('value', postgresql.ARRAY(postgresql.ENUM('A', 'B', 'C', name='my_enum', create_type=False)), server_default=sa.text("ARRAY['A', 'B']::my_enum[]"), nullable=True)) - op.sync_enum_values('public', 'my_enum', ['A', 'B', 'C'], + op.sync_enum_values('public', 'my_enum', ['A', 'B', 'C'], # type: ignore[attr-defined] [TableReference(table_schema='public', table_name='a', column_name='value', column_type=ColumnType.ARRAY, existing_server_default="ARRAY['A', 'B']::my_enum[]"), TableReference(table_schema='public', table_name='b', column_name='value', column_type=ColumnType.ARRAY, existing_server_default="ARRAY['A'::my_enum, 'B'::my_enum]")], enum_values_to_rename=[]) # ### end Alembic commands ### @@ -72,7 +72,7 @@ def get_expected_upgrade(self) -> str: def get_expected_downgrade(self) -> str: return """ # ### commands auto generated by Alembic - please adjust! ### - op.sync_enum_values('public', 'my_enum', ['A', 'B'], + op.sync_enum_values('public', 'my_enum', ['A', 'B'], # type: ignore[attr-defined] [TableReference(table_schema='public', table_name='a', column_name='value', column_type=ColumnType.ARRAY, existing_server_default="ARRAY['A', 'B']::my_enum[]"), TableReference(table_schema='public', table_name='b', column_name='value', column_type=ColumnType.ARRAY, existing_server_default="ARRAY['A'::my_enum, 'B'::my_enum]")], enum_values_to_rename=[]) op.drop_column('a', 'value')