From f3a1e104fa68969c3bd083af519467d0c81b7969 Mon Sep 17 00:00:00 2001 From: zhangliang Date: Mon, 16 Dec 2024 19:26:33 +0800 Subject: [PATCH 1/3] Add ShardingSphereDatabaseDataTest --- .../ShardingSphereDatabaseData.java | 28 ++++----- .../ShardingSphereDatabaseDataTest.java | 58 +++++++++++++++++++ .../ShardingSphereDataPersistService.java | 2 +- 3 files changed, 73 insertions(+), 15 deletions(-) create mode 100644 infra/common/src/test/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseDataTest.java diff --git a/infra/common/src/main/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseData.java b/infra/common/src/main/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseData.java index 4aaa32a97a691..19cdb2cf2f455 100644 --- a/infra/common/src/main/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseData.java +++ b/infra/common/src/main/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseData.java @@ -30,42 +30,42 @@ public final class ShardingSphereDatabaseData { private final Map schemaData = new CaseInsensitiveMap<>(); + /** + * Judge whether to contains schema. + * + * @param schemaName schema name + * @return contains schema or not + */ + public boolean containsSchema(final String schemaName) { + return schemaData.containsKey(schemaName); + } + /** * Get ShardingSphere schema data. * * @param schemaName schema name - * @return ShardingSphere schema data + * @return schema data */ public ShardingSphereSchemaData getSchema(final String schemaName) { return schemaData.get(schemaName); } /** - * Put ShardingSphere schema data. + * Put schema data. * * @param schemaName schema name - * @param schema ShardingSphere schema data + * @param schema schema data */ public void putSchema(final String schemaName, final ShardingSphereSchemaData schema) { schemaData.put(schemaName, schema); } /** - * Remove ShardingSphere schema data. + * Remove schema data. * * @param schemaName schema name */ public void removeSchema(final String schemaName) { schemaData.remove(schemaName); } - - /** - * Judge contains ShardingSphere schema from ShardingSphere database or not. - * - * @param schemaName schema name - * @return Contains schema from database or not - */ - public boolean containsSchema(final String schemaName) { - return schemaData.containsKey(schemaName); - } } diff --git a/infra/common/src/test/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseDataTest.java b/infra/common/src/test/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseDataTest.java new file mode 100644 index 0000000000000..101544e2e17ef --- /dev/null +++ b/infra/common/src/test/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseDataTest.java @@ -0,0 +1,58 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.apache.shardingsphere.infra.metadata.statistics; + +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertFalse; +import static org.junit.jupiter.api.Assertions.assertNull; +import static org.junit.jupiter.api.Assertions.assertTrue; + +class ShardingSphereDatabaseDataTest { + + private final ShardingSphereDatabaseData databaseData = new ShardingSphereDatabaseData(); + + @BeforeEach + void setUp() { + databaseData.putSchema("foo_schema", new ShardingSphereSchemaData()); + } + + @Test + void assertContainsSchema() { + assertTrue(databaseData.containsSchema("foo_schema")); + assertFalse(databaseData.containsSchema("bar_schema")); + } + + @Test + void assertGetSchema() { + assertTrue(databaseData.getSchema("foo_schema").getTableData().isEmpty()); + assertNull(databaseData.getSchema("bar_schema")); + } + @Test + void assertPutSchema() { + databaseData.putSchema("bar_schema", new ShardingSphereSchemaData()); + assertTrue(databaseData.containsSchema("bar_schema")); + } + + @Test + void assertRemoveSchema() { + databaseData.removeSchema("foo_schema"); + assertFalse(databaseData.containsSchema("foo_schema")); + } +} diff --git a/kernel/metadata/core/src/main/java/org/apache/shardingsphere/metadata/persist/data/ShardingSphereDataPersistService.java b/kernel/metadata/core/src/main/java/org/apache/shardingsphere/metadata/persist/data/ShardingSphereDataPersistService.java index a09d909e55302..f61da68b54ec1 100644 --- a/kernel/metadata/core/src/main/java/org/apache/shardingsphere/metadata/persist/data/ShardingSphereDataPersistService.java +++ b/kernel/metadata/core/src/main/java/org/apache/shardingsphere/metadata/persist/data/ShardingSphereDataPersistService.java @@ -69,7 +69,7 @@ public Optional load(final ShardingSphereMetaData meta private ShardingSphereDatabaseData load(final String databaseName, final ShardingSphereDatabase database) { ShardingSphereDatabaseData result = new ShardingSphereDatabaseData(); for (String each : repository.getChildrenKeys(ShardingSphereDataNode.getSchemasPath(databaseName)).stream().filter(database::containsSchema).collect(Collectors.toList())) { - result.getSchemaData().put(each, load(databaseName, each, database.getSchema(each))); + result.putSchema(each, load(databaseName, each, database.getSchema(each))); } return result; } From e86c9b7f7289e0e9a026d6cddeb42d3f21b3ed0b Mon Sep 17 00:00:00 2001 From: zhangliang Date: Mon, 16 Dec 2024 19:29:40 +0800 Subject: [PATCH 2/3] Add ShardingSphereDatabaseDataTest --- .../metadata/statistics/ShardingSphereDatabaseDataTest.java | 1 + 1 file changed, 1 insertion(+) diff --git a/infra/common/src/test/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseDataTest.java b/infra/common/src/test/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseDataTest.java index 101544e2e17ef..a8696badf14c1 100644 --- a/infra/common/src/test/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseDataTest.java +++ b/infra/common/src/test/java/org/apache/shardingsphere/infra/metadata/statistics/ShardingSphereDatabaseDataTest.java @@ -44,6 +44,7 @@ void assertGetSchema() { assertTrue(databaseData.getSchema("foo_schema").getTableData().isEmpty()); assertNull(databaseData.getSchema("bar_schema")); } + @Test void assertPutSchema() { databaseData.putSchema("bar_schema", new ShardingSphereSchemaData()); From 198646ff70b5436a9759e83b771446b710ce7edc Mon Sep 17 00:00:00 2001 From: zhangliang Date: Mon, 16 Dec 2024 19:38:45 +0800 Subject: [PATCH 3/3] Remove useless field on ShardingInsertSupportedCheckerTest --- .../checker/sql/ddl/ShardingInsertSupportedCheckerTest.java | 4 ---- 1 file changed, 4 deletions(-) diff --git a/features/sharding/core/src/test/java/org/apache/shardingsphere/sharding/checker/sql/ddl/ShardingInsertSupportedCheckerTest.java b/features/sharding/core/src/test/java/org/apache/shardingsphere/sharding/checker/sql/ddl/ShardingInsertSupportedCheckerTest.java index da9a6cebc883b..8b8df02f57b60 100644 --- a/features/sharding/core/src/test/java/org/apache/shardingsphere/sharding/checker/sql/ddl/ShardingInsertSupportedCheckerTest.java +++ b/features/sharding/core/src/test/java/org/apache/shardingsphere/sharding/checker/sql/ddl/ShardingInsertSupportedCheckerTest.java @@ -19,10 +19,8 @@ import org.apache.shardingsphere.infra.binder.context.segment.table.TablesContext; import org.apache.shardingsphere.infra.binder.context.statement.dml.InsertStatementContext; -import org.apache.shardingsphere.infra.database.core.type.DatabaseType; import org.apache.shardingsphere.infra.metadata.ShardingSphereMetaData; import org.apache.shardingsphere.infra.metadata.database.ShardingSphereDatabase; -import org.apache.shardingsphere.infra.spi.type.typed.TypedSPILoader; import org.apache.shardingsphere.sharding.checker.sql.dml.ShardingInsertSupportedChecker; import org.apache.shardingsphere.sharding.exception.syntax.DMLWithMultipleShardingTablesException; import org.apache.shardingsphere.sharding.exception.syntax.InsertSelectTableViolationException; @@ -62,8 +60,6 @@ @ExtendWith(MockitoExtension.class) class ShardingInsertSupportedCheckerTest { - private final DatabaseType databaseType = TypedSPILoader.getService(DatabaseType.class, "FIXTURE"); - @Mock private ShardingRule rule;