From c66dc0b195c25ac726c43c54fa642ec8cfd8a971 Mon Sep 17 00:00:00 2001 From: Kevin Liu Date: Tue, 7 Jan 2025 20:39:36 -0800 Subject: [PATCH] UpdateSchema does not respect transaction abort --- tests/integration/test_rest_schema.py | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/tests/integration/test_rest_schema.py b/tests/integration/test_rest_schema.py index 6a704839e2..d4c76e8a79 100644 --- a/tests/integration/test_rest_schema.py +++ b/tests/integration/test_rest_schema.py @@ -96,6 +96,22 @@ def test_add_already_exists(catalog: Catalog, table_schema_nested: Schema) -> No assert "already exists: location.latitude" in str(exc_info.value) +# @pytest.mark.integration +def test_abort_transaction(catalog: Catalog, table_schema_nested: Schema) -> None: + table = _create_table_with_schema(catalog, table_schema_nested) + old_schema = table.schema() + + with pytest.raises(ValueError) as exc_info: + with table.update_schema() as update: + update.add_column("123", IntegerType()) # "123" can be added succesfully + update.add_column("foo", IntegerType()) + assert "already exists: foo" in str(exc_info.value) + # transaction raised, but "123" column is still added + print(f"Original Schema: {old_schema}") + print(f"New Schema: {table.schema()}") + assert old_schema == table.schema() + + @pytest.mark.integration def test_add_to_non_struct_type(catalog: Catalog, table_schema_simple: Schema) -> None: table = _create_table_with_schema(catalog, table_schema_simple)