Skip to content

Commit

Permalink
[hotfix] CloneAction throw more clear exception when no table in sour…
Browse files Browse the repository at this point in the history
…ce catalog (apache#4682)
  • Loading branch information
yuzelin authored Dec 10, 2024
1 parent 2eeed7d commit 6010e61
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
import java.util.Map;

import static org.apache.paimon.utils.Preconditions.checkArgument;
import static org.apache.paimon.utils.Preconditions.checkState;

/**
* Pick the tables to be cloned based on the user input parameters. The record type of the build
Expand Down Expand Up @@ -114,6 +115,8 @@ private DataStream<Tuple2<String, String>> build(Catalog sourceCatalog) throws E
database + "." + tableName, targetDatabase + "." + targetTableName));
}

checkState(!result.isEmpty(), "Didn't find any table in source catalog.");

if (LOG.isDebugEnabled()) {
LOG.debug("The clone identifiers of source table and target table are: {}", result);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@
import org.apache.flink.table.api.config.TableConfigOptions;
import org.apache.flink.types.Row;
import org.apache.flink.util.CloseableIterator;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.Timeout;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.ValueSource;
Expand All @@ -44,8 +45,10 @@
import java.util.stream.Collectors;
import java.util.stream.IntStream;

import static org.apache.paimon.testutils.assertj.PaimonAssertions.anyCauseMatches;
import static org.apache.paimon.utils.Preconditions.checkState;
import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatThrownBy;

/** IT cases for {@link CloneAction}. */
public class CloneActionITCase extends ActionITCaseBase {
Expand Down Expand Up @@ -640,6 +643,46 @@ public void testCloneTableWithExpiration(String invoker) throws Exception {
.isEqualTo(Collections.singletonList("+I[1]"));
}

// ------------------------------------------------------------------------
// Negative Tests
// ------------------------------------------------------------------------

@Test
public void testEmptySourceCatalog() {
String sourceWarehouse = getTempDirPath("source-ware");

TableEnvironment tEnv = tableEnvironmentBuilder().batchMode().parallelism(1).build();
tEnv.executeSql(
"CREATE CATALOG sourcecat WITH (\n"
+ " 'type' = 'paimon',\n"
+ String.format(" 'warehouse' = '%s'\n", sourceWarehouse)
+ ")");

String targetWarehouse = getTempDirPath("target-ware");

String[] args =
new String[] {
"clone",
"--warehouse",
sourceWarehouse,
"--target_warehouse",
targetWarehouse,
"--parallelism",
"1"
};
CloneAction action = (CloneAction) ActionFactory.createAction(args).get();

StreamExecutionEnvironment env =
streamExecutionEnvironmentBuilder().streamingMode().allowRestart().build();
action.withStreamExecutionEnvironment(env);

assertThatThrownBy(action::run)
.satisfies(
anyCauseMatches(
IllegalStateException.class,
"Didn't find any table in source catalog."));
}

// ------------------------------------------------------------------------
// Utils
// ------------------------------------------------------------------------
Expand Down

0 comments on commit 6010e61

Please sign in to comment.