This is an automated email from the ASF dual-hosted git repository.
zhangliang pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/shardingsphere.git
The following commit(s) were added to refs/heads/master by this push:
new a795f84f27a Add more test cases on Refactor RouteContextTest (#33145)
a795f84f27a is described below
commit a795f84f27a3b4286000bfe9d78618885345e1f9
Author: Liang Zhang <[email protected]>
AuthorDate: Mon Oct 7 19:05:32 2024 +0800
Add more test cases on Refactor RouteContextTest (#33145)
* Remove useless DistSQLGlobalRuleQueryExecutorTest
* Refactor RouteContextTest
* Refactor RouteContextTest
* Refactor RouteContextTest
---
.../infra/route/context/RouteContext.java | 2 +-
.../infra/route/context/RouteContextTest.java | 84 +++++++++++-----------
2 files changed, 43 insertions(+), 43 deletions(-)
diff --git
a/infra/route/src/main/java/org/apache/shardingsphere/infra/route/context/RouteContext.java
b/infra/route/src/main/java/org/apache/shardingsphere/infra/route/context/RouteContext.java
index 988810e039f..5d415094660 100644
---
a/infra/route/src/main/java/org/apache/shardingsphere/infra/route/context/RouteContext.java
+++
b/infra/route/src/main/java/org/apache/shardingsphere/infra/route/context/RouteContext.java
@@ -60,7 +60,7 @@ public final class RouteContext {
* @return actual data source names
*/
public Collection<String> getActualDataSourceNames() {
- return routeUnits.stream().map(each ->
each.getDataSourceMapper().getActualName()).collect(Collectors.toCollection(()
-> new HashSet<>(routeUnits.size(), 1L)));
+ return routeUnits.stream().map(each ->
each.getDataSourceMapper().getActualName()).collect(Collectors.toSet());
}
/**
diff --git
a/infra/route/src/test/java/org/apache/shardingsphere/infra/route/context/RouteContextTest.java
b/infra/route/src/test/java/org/apache/shardingsphere/infra/route/context/RouteContextTest.java
index 3af87601254..c17baea6807 100644
---
a/infra/route/src/test/java/org/apache/shardingsphere/infra/route/context/RouteContextTest.java
+++
b/infra/route/src/test/java/org/apache/shardingsphere/infra/route/context/RouteContextTest.java
@@ -21,10 +21,9 @@ import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import java.util.Arrays;
-import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;
-import java.util.Iterator;
+import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Optional;
@@ -37,89 +36,90 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
class RouteContextTest {
- private static final String DATASOURCE_NAME_0 = "ds0";
-
- private static final String DATASOURCE_NAME_1 = "ds1";
-
- private static final String LOGIC_TABLE = "table";
-
- private static final String ACTUAL_TABLE = "table_0";
-
- private RouteContext singleRouteContext;
-
private RouteContext multiRouteContext;
private RouteContext notContainsTableShardingRouteContext;
@BeforeEach
void setUp() {
- singleRouteContext = new RouteContext();
multiRouteContext = new RouteContext();
+
multiRouteContext.getRouteUnits().addAll(Arrays.asList(createRouteUnit("foo_ds"),
createRouteUnit("bar_ds")));
notContainsTableShardingRouteContext = new RouteContext();
-
multiRouteContext.getRouteUnits().addAll(Arrays.asList(mockRouteUnit(DATASOURCE_NAME_0),
mockRouteUnit(DATASOURCE_NAME_1)));
-
singleRouteContext.getRouteUnits().add(mockRouteUnit(DATASOURCE_NAME_0));
-
notContainsTableShardingRouteContext.getRouteUnits().addAll(Arrays.asList(mockDatabaseShardingOnlyRouteUnit(DATASOURCE_NAME_0),
mockDatabaseShardingOnlyRouteUnit(DATASOURCE_NAME_1)));
+
notContainsTableShardingRouteContext.getRouteUnits().add(createDatabaseShardingOnlyRouteUnit());
}
- private RouteUnit mockDatabaseShardingOnlyRouteUnit(final String
datasourceName) {
- return new RouteUnit(new RouteMapper(datasourceName, datasourceName),
Collections.singletonList(new RouteMapper(LOGIC_TABLE, LOGIC_TABLE)));
+ private RouteUnit createRouteUnit(final String datasourceName) {
+ return new RouteUnit(new RouteMapper(datasourceName, datasourceName),
Collections.singleton(new RouteMapper("logic_tbl", "actual_tbl")));
}
- private RouteUnit mockRouteUnit(final String datasourceName) {
- return new RouteUnit(new RouteMapper(datasourceName, datasourceName),
Collections.singletonList(new RouteMapper(LOGIC_TABLE, ACTUAL_TABLE)));
+ private RouteUnit createDatabaseShardingOnlyRouteUnit() {
+ return new RouteUnit(new RouteMapper("foo_ds", "foo_ds"),
Collections.singleton(new RouteMapper("logic_tbl", "logic_tbl")));
}
@Test
- void assertIsSingleRouting() {
- assertTrue(singleRouteContext.isSingleRouting());
+ void assertIsNotSingleRouting() {
assertFalse(multiRouteContext.isSingleRouting());
}
+ @Test
+ void assertIsSingleRouting() {
+ assertTrue(notContainsTableShardingRouteContext.isSingleRouting());
+ }
+
@Test
void assertGetActualDataSourceNames() {
- Collection<String> actual =
singleRouteContext.getActualDataSourceNames();
- assertThat(actual.size(), is(1));
- assertThat(actual.iterator().next(), is(DATASOURCE_NAME_0));
- actual = multiRouteContext.getActualDataSourceNames();
- assertThat(actual.size(), is(2));
- Iterator<String> iterator = actual.iterator();
- assertThat(iterator.next(), is(DATASOURCE_NAME_0));
- assertThat(iterator.next(), is(DATASOURCE_NAME_1));
+ assertThat(multiRouteContext.getActualDataSourceNames(), is(new
HashSet<>(Arrays.asList("foo_ds", "bar_ds"))));
}
@Test
void assertGetActualTableNameGroups() {
- List<Set<String>> actual =
multiRouteContext.getActualTableNameGroups(DATASOURCE_NAME_1, new
HashSet<>(Collections.singleton(LOGIC_TABLE)));
- assertThat(actual.size(), is(1));
- assertTrue(actual.get(0).contains(ACTUAL_TABLE));
+ assertThat(multiRouteContext.getActualTableNameGroups("bar_ds",
Collections.singleton("logic_tbl")),
is(Collections.singletonList(Collections.singleton("actual_tbl"))));
}
@Test
void assertGetDataSourceLogicTablesMap() {
- List<String> dataSources = Arrays.asList(DATASOURCE_NAME_0,
DATASOURCE_NAME_1);
+ List<String> dataSources = Arrays.asList("foo_ds", "bar_ds",
"invalid_ds");
Map<String, Set<String>> actual =
multiRouteContext.getDataSourceLogicTablesMap(dataSources);
assertThat(actual.size(), is(2));
- assertThat(actual.get(DATASOURCE_NAME_0).size(), is(1));
- assertThat(actual.get(DATASOURCE_NAME_0).iterator().next(),
is(LOGIC_TABLE));
- assertThat(actual.get(DATASOURCE_NAME_1).size(), is(1));
- assertThat(actual.get(DATASOURCE_NAME_1).iterator().next(),
is(LOGIC_TABLE));
+ assertThat(actual.get("foo_ds").size(), is(1));
+ assertThat(actual.get("foo_ds").iterator().next(), is("logic_tbl"));
+ assertThat(actual.get("bar_ds").size(), is(1));
+ assertThat(actual.get("bar_ds").iterator().next(), is("logic_tbl"));
}
@Test
void assertFindTableMapper() {
- Optional<RouteMapper> actual =
multiRouteContext.findTableMapper(DATASOURCE_NAME_1, ACTUAL_TABLE);
+ Optional<RouteMapper> actual =
multiRouteContext.findTableMapper("foo_ds", "actual_tbl");
assertTrue(actual.isPresent());
- assertThat(actual.get(), is(new RouteMapper(LOGIC_TABLE,
ACTUAL_TABLE)));
+ assertThat(actual.get(), is(new RouteMapper("logic_tbl",
"actual_tbl")));
}
@Test
void assertTableMapperNotFound() {
- assertFalse(singleRouteContext.findTableMapper(DATASOURCE_NAME_1,
ACTUAL_TABLE).isPresent());
+
assertFalse(notContainsTableShardingRouteContext.findTableMapper("bar_ds",
"actual_tbl").isPresent());
+ }
+
+ @Test
+ void assertPutRouteUnitWithExistedDataSourceMapper() {
+ multiRouteContext.putRouteUnit(new RouteMapper("foo_ds", "foo_ds"),
Collections.singleton(new RouteMapper("foo_tbl", "foo_tbl")));
+ assertThat(multiRouteContext.getRouteUnits(),
+ is(new LinkedHashSet<>(Arrays.asList(
+ new RouteUnit(new RouteMapper("foo_ds", "foo_ds"), new
LinkedHashSet<>(Arrays.asList(new RouteMapper("logic_tbl", "actual_tbl"), new
RouteMapper("foo_tbl", "foo_tbl")))),
+ new RouteUnit(new RouteMapper("bar_ds", "bar_ds"),
Collections.singleton(new RouteMapper("logic_tbl", "actual_tbl")))))));
+ }
+
+ @Test
+ void assertPutRouteUnitWithNewDataSourceMapper() {
+ multiRouteContext.putRouteUnit(new RouteMapper("new_ds", "new_ds"),
Collections.singleton(new RouteMapper("new_tbl", "new_tbl")));
+ assertThat(multiRouteContext.getRouteUnits(),
+ is(new LinkedHashSet<>(Arrays.asList(
+ new RouteUnit(new RouteMapper("foo_ds", "foo_ds"),
Collections.singleton(new RouteMapper("logic_tbl", "actual_tbl"))),
+ new RouteUnit(new RouteMapper("bar_ds", "bar_ds"),
Collections.singleton(new RouteMapper("logic_tbl", "actual_tbl"))),
+ new RouteUnit(new RouteMapper("new_ds", "new_ds"),
Collections.singleton(new RouteMapper("new_tbl", "new_tbl")))))));
}
@Test
void assertContainsTableShardingWhenContainsTableSharding() {
- assertTrue(singleRouteContext.containsTableSharding());
assertTrue(multiRouteContext.containsTableSharding());
}