|
26 | 26 | import static io.trino.tempto.assertions.QueryAssert.assertThat;
|
27 | 27 | import static io.trino.testing.TestingNames.randomNameSuffix;
|
28 | 28 | import static io.trino.tests.product.TestGroups.DELTA_LAKE_DATABRICKS;
|
| 29 | +import static io.trino.tests.product.TestGroups.DELTA_LAKE_EXCLUDE_104; |
29 | 30 | import static io.trino.tests.product.TestGroups.DELTA_LAKE_EXCLUDE_73;
|
30 | 31 | import static io.trino.tests.product.TestGroups.DELTA_LAKE_EXCLUDE_91;
|
31 | 32 | import static io.trino.tests.product.TestGroups.DELTA_LAKE_OSS;
|
@@ -350,8 +351,6 @@ public void testUnsupportedOperationsColumnMappingModeName(String mode)
|
350 | 351 | .hasMessageContaining("Delta Lake writer version 5 which is not supported");
|
351 | 352 | assertQueryFailure(() -> onTrino().executeQuery("ALTER TABLE default." + tableName + " ADD COLUMN new_col varchar"))
|
352 | 353 | .hasMessageContaining("Delta Lake writer version 5 which is not supported");
|
353 |
| - assertQueryFailure(() -> onTrino().executeQuery("ALTER TABLE default." + tableName + " RENAME COLUMN a_number TO renamed_column")) |
354 |
| - .hasMessageContaining("This connector does not support renaming columns"); |
355 | 354 | assertQueryFailure(() -> onTrino().executeQuery("ALTER TABLE default." + tableName + " DROP COLUMN a_number"))
|
356 | 355 | .hasMessageContaining("This connector does not support dropping columns");
|
357 | 356 | }
|
@@ -391,6 +390,135 @@ public void testSpecialCharacterColumnNamesWithColumnMappingMode(String mode)
|
391 | 390 | }
|
392 | 391 | }
|
393 | 392 |
|
| 393 | + @Test(groups = {DELTA_LAKE_DATABRICKS, DELTA_LAKE_OSS, DELTA_LAKE_EXCLUDE_73, DELTA_LAKE_EXCLUDE_91, DELTA_LAKE_EXCLUDE_104, PROFILE_SPECIFIC_TESTS}, dataProvider = "columnMappingDataProvider") |
| 394 | + @Flaky(issue = DATABRICKS_COMMUNICATION_FAILURE_ISSUE, match = DATABRICKS_COMMUNICATION_FAILURE_MATCH) |
| 395 | + public void testTrinoRenameColumnWithColumnMappingMode(String mode) |
| 396 | + { |
| 397 | + String tableName = "test_rename_column_" + randomNameSuffix(); |
| 398 | + |
| 399 | + onDelta().executeQuery("" + |
| 400 | + "CREATE TABLE default." + tableName + |
| 401 | + " (id INT, data INT, part STRING)" + |
| 402 | + " USING delta " + |
| 403 | + " PARTITIONED BY (part) " + |
| 404 | + " LOCATION 's3://" + bucketName + "/databricks-compatibility-test-" + tableName + "'" + |
| 405 | + " TBLPROPERTIES ('delta.columnMapping.mode' = '" + mode + "')"); |
| 406 | + |
| 407 | + try { |
| 408 | + onDelta().executeQuery("INSERT INTO default." + tableName + " VALUES (1, 10, 'part#1')"); |
| 409 | + |
| 410 | + onTrino().executeQuery("ALTER TABLE delta.default." + tableName + " RENAME COLUMN data TO new_data"); |
| 411 | + onTrino().executeQuery("ALTER TABLE delta.default." + tableName + " RENAME COLUMN part TO new_part"); |
| 412 | + |
| 413 | + assertThat(onTrino().executeQuery("DESCRIBE delta.default." + tableName)) |
| 414 | + .containsOnly( |
| 415 | + row("id", "integer", "", ""), |
| 416 | + row("new_data", "integer", "", ""), |
| 417 | + row("new_part", "varchar", "", "")); |
| 418 | + |
| 419 | + assertThat(onTrino().executeQuery("SELECT * FROM delta.default." + tableName)) |
| 420 | + .containsOnly(row(1, 10, "part#1")); |
| 421 | + assertThat(onDelta().executeQuery("SELECT * FROM default." + tableName)) |
| 422 | + .containsOnly(row(1, 10, "part#1")); |
| 423 | + |
| 424 | + // Ensure renaming to the dropped column doesn't restore the old data |
| 425 | + // TODO: Drop a column in Trino once the connector supports the syntax |
| 426 | + assertQueryFailure(() -> onTrino().executeQuery("ALTER TABLE delta.default." + tableName + " DROP COLUMN id")) |
| 427 | + .hasMessageContaining("This connector does not support dropping columns"); |
| 428 | + onDelta().executeQuery("ALTER TABLE default." + tableName + " DROP COLUMN id"); |
| 429 | + onDelta().executeQuery("ALTER TABLE default." + tableName + " RENAME COLUMN new_data TO id"); |
| 430 | + |
| 431 | + assertThat(onTrino().executeQuery("SELECT id, new_part FROM delta.default." + tableName)) |
| 432 | + .containsOnly(row(10, "part#1")); |
| 433 | + assertThat(onDelta().executeQuery("SELECT id, new_part FROM default." + tableName)) |
| 434 | + .containsOnly(row(10, "part#1")); |
| 435 | + } |
| 436 | + finally { |
| 437 | + onDelta().executeQuery("DROP TABLE default." + tableName); |
| 438 | + } |
| 439 | + } |
| 440 | + |
| 441 | + @Test(groups = {DELTA_LAKE_DATABRICKS, DELTA_LAKE_OSS, DELTA_LAKE_EXCLUDE_73, DELTA_LAKE_EXCLUDE_91, DELTA_LAKE_EXCLUDE_104, PROFILE_SPECIFIC_TESTS}, dataProvider = "columnMappingDataProvider") |
| 442 | + @Flaky(issue = DATABRICKS_COMMUNICATION_FAILURE_ISSUE, match = DATABRICKS_COMMUNICATION_FAILURE_MATCH) |
| 443 | + public void testSparkRenameColumnWithColumnMappingMode(String mode) |
| 444 | + { |
| 445 | + String tableName = "test_spark_rename_column_" + randomNameSuffix(); |
| 446 | + |
| 447 | + onDelta().executeQuery("" + |
| 448 | + "CREATE TABLE default." + tableName + |
| 449 | + " (id INT, data INT, part STRING)" + |
| 450 | + " USING delta " + |
| 451 | + " PARTITIONED BY (part) " + |
| 452 | + " LOCATION 's3://" + bucketName + "/databricks-compatibility-test-" + tableName + "'" + |
| 453 | + " TBLPROPERTIES ('delta.columnMapping.mode' = '" + mode + "')"); |
| 454 | + |
| 455 | + try { |
| 456 | + onDelta().executeQuery("INSERT INTO default." + tableName + " VALUES (1, 10, 'part#1')"); |
| 457 | + |
| 458 | + onDelta().executeQuery("ALTER TABLE default." + tableName + " RENAME COLUMN data TO new_data"); |
| 459 | + onDelta().executeQuery("ALTER TABLE default." + tableName + " RENAME COLUMN part TO new_part"); |
| 460 | + |
| 461 | + assertThat(onTrino().executeQuery("DESCRIBE delta.default." + tableName)) |
| 462 | + .containsOnly( |
| 463 | + row("id", "integer", "", ""), |
| 464 | + row("new_data", "integer", "", ""), |
| 465 | + row("new_part", "varchar", "", "")); |
| 466 | + |
| 467 | + assertThat(onTrino().executeQuery("SELECT * FROM delta.default." + tableName)) |
| 468 | + .containsOnly(row(1, 10, "part#1")); |
| 469 | + assertThat(onDelta().executeQuery("SELECT * FROM default." + tableName)) |
| 470 | + .containsOnly(row(1, 10, "part#1")); |
| 471 | + |
| 472 | + // Ensure renaming to the dropped column doesn't restore the old data |
| 473 | + onDelta().executeQuery("ALTER TABLE default." + tableName + " DROP COLUMN id"); |
| 474 | + onDelta().executeQuery("ALTER TABLE default." + tableName + " RENAME COLUMN new_data TO id"); |
| 475 | + |
| 476 | + assertThat(onTrino().executeQuery("SELECT id, new_part FROM delta.default." + tableName)) |
| 477 | + .containsOnly(row(10, "part#1")); |
| 478 | + assertThat(onDelta().executeQuery("SELECT id, new_part FROM default." + tableName)) |
| 479 | + .containsOnly(row(10, "part#1")); |
| 480 | + } |
| 481 | + finally { |
| 482 | + onDelta().executeQuery("DROP TABLE default." + tableName); |
| 483 | + } |
| 484 | + } |
| 485 | + |
| 486 | + @Test(groups = {DELTA_LAKE_DATABRICKS, DELTA_LAKE_OSS, DELTA_LAKE_EXCLUDE_73, DELTA_LAKE_EXCLUDE_91, DELTA_LAKE_EXCLUDE_104, PROFILE_SPECIFIC_TESTS}) |
| 487 | + @Flaky(issue = DATABRICKS_COMMUNICATION_FAILURE_ISSUE, match = DATABRICKS_COMMUNICATION_FAILURE_MATCH) |
| 488 | + public void testUnsupportedRenameColumnWithColumnMappingModeNone() |
| 489 | + { |
| 490 | + String tableName = "test_unsupported_rename_column_" + randomNameSuffix(); |
| 491 | + |
| 492 | + onDelta().executeQuery("" + |
| 493 | + "CREATE TABLE default." + tableName + |
| 494 | + " (id INT, data INT)" + |
| 495 | + " USING delta " + |
| 496 | + " LOCATION 's3://" + bucketName + "/databricks-compatibility-test-" + tableName + "'" + |
| 497 | + " TBLPROPERTIES ('delta.columnMapping.mode' = 'none')"); |
| 498 | + |
| 499 | + try { |
| 500 | + onDelta().executeQuery("INSERT INTO default." + tableName + " VALUES (1, 10)"); |
| 501 | + |
| 502 | + assertQueryFailure(() -> onTrino().executeQuery("ALTER TABLE delta.default." + tableName + " RENAME COLUMN data TO new_data")) |
| 503 | + .hasMessageContaining("Cannot rename column with the column mapping: NONE"); |
| 504 | + assertQueryFailure(() -> onDelta().executeQuery("ALTER TABLE default." + tableName + " RENAME COLUMN data TO new_data")) |
| 505 | + .hasMessageContaining(" Column rename is not supported for your Delta table"); |
| 506 | + |
| 507 | + assertThat(onTrino().executeQuery("DESCRIBE delta.default." + tableName)) |
| 508 | + .containsOnly( |
| 509 | + row("id", "integer", "", ""), |
| 510 | + row("data", "integer", "", "")); |
| 511 | + |
| 512 | + assertThat(onTrino().executeQuery("SELECT * FROM delta.default." + tableName)) |
| 513 | + .containsOnly(row(1, 10)); |
| 514 | + assertThat(onDelta().executeQuery("SELECT * FROM default." + tableName)) |
| 515 | + .containsOnly(row(1, 10)); |
| 516 | + } |
| 517 | + finally { |
| 518 | + onDelta().executeQuery("DROP TABLE default." + tableName); |
| 519 | + } |
| 520 | + } |
| 521 | + |
394 | 522 | @DataProvider
|
395 | 523 | public Object[][] columnMappingDataProvider()
|
396 | 524 | {
|
|
0 commit comments