This is an automated email from the ASF dual-hosted git repository.

jianglongtao 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 e4f60815081 Replace `UnusedShardingKeyGeneratorResultSet` with 
`ShowUnusedShardingKeyGeneratorExecutor` (#23866)
e4f60815081 is described below

commit e4f60815081be61f9bf537e1d4560079a53e52d2
Author: Zichao <[email protected]>
AuthorDate: Tue Jan 31 22:14:39 2023 +1300

    Replace `UnusedShardingKeyGeneratorResultSet` with 
`ShowUnusedShardingKeyGeneratorExecutor` (#23866)
---
 ...=> ShowUnusedShardingKeyGeneratorExecutor.java} | 47 ++++++----------------
 ...hardingsphere.distsql.handler.query.RQLExecutor |  1 +
 ...here.distsql.handler.resultset.DistSQLResultSet |  1 -
 ...howUnusedShardingKeyGeneratorExecutorTest.java} | 38 +++++++++++------
 4 files changed, 39 insertions(+), 48 deletions(-)

diff --git 
a/features/sharding/distsql/handler/src/main/java/org/apache/shardingsphere/sharding/distsql/handler/query/UnusedShardingKeyGeneratorResultSet.java
 
b/features/sharding/distsql/handler/src/main/java/org/apache/shardingsphere/sharding/distsql/handler/query/ShowUnusedShardingKeyGeneratorExecutor.java
similarity index 70%
rename from 
features/sharding/distsql/handler/src/main/java/org/apache/shardingsphere/sharding/distsql/handler/query/UnusedShardingKeyGeneratorResultSet.java
rename to 
features/sharding/distsql/handler/src/main/java/org/apache/shardingsphere/sharding/distsql/handler/query/ShowUnusedShardingKeyGeneratorExecutor.java
index 5597f01b7d0..ebbe74a9cd2 100644
--- 
a/features/sharding/distsql/handler/src/main/java/org/apache/shardingsphere/sharding/distsql/handler/query/UnusedShardingKeyGeneratorResultSet.java
+++ 
b/features/sharding/distsql/handler/src/main/java/org/apache/shardingsphere/sharding/distsql/handler/query/ShowUnusedShardingKeyGeneratorExecutor.java
@@ -18,51 +18,46 @@
 package org.apache.shardingsphere.sharding.distsql.handler.query;
 
 import com.google.common.base.Strings;
+import org.apache.shardingsphere.distsql.handler.query.RQLExecutor;
 import org.apache.shardingsphere.infra.config.algorithm.AlgorithmConfiguration;
-import 
org.apache.shardingsphere.distsql.handler.resultset.DatabaseDistSQLResultSet;
+import 
org.apache.shardingsphere.infra.merge.result.impl.local.LocalDataQueryResultRow;
 import 
org.apache.shardingsphere.infra.metadata.database.ShardingSphereDatabase;
 import org.apache.shardingsphere.infra.util.props.PropertiesConverter;
 import org.apache.shardingsphere.sharding.api.config.ShardingRuleConfiguration;
 import 
org.apache.shardingsphere.sharding.api.config.strategy.keygen.KeyGenerateStrategyConfiguration;
 import 
org.apache.shardingsphere.sharding.distsql.parser.statement.ShowUnusedShardingKeyGeneratorsStatement;
 import org.apache.shardingsphere.sharding.rule.ShardingRule;
-import org.apache.shardingsphere.sql.parser.sql.common.statement.SQLStatement;
 
 import java.util.Arrays;
 import java.util.Collection;
 import java.util.Collections;
-import java.util.HashMap;
-import java.util.Iterator;
 import java.util.LinkedHashSet;
 import java.util.LinkedList;
-import java.util.Map;
 import java.util.Map.Entry;
 import java.util.Objects;
 import java.util.Optional;
 import java.util.Properties;
 
 /**
- * Result set for show unused sharding key generator.
+ * Show unused sharding key generator executor.
  */
-public final class UnusedShardingKeyGeneratorResultSet implements 
DatabaseDistSQLResultSet {
-    
-    private Iterator<Entry<String, AlgorithmConfiguration>> data = 
Collections.emptyIterator();
+public final class ShowUnusedShardingKeyGeneratorExecutor implements 
RQLExecutor<ShowUnusedShardingKeyGeneratorsStatement> {
     
     @Override
-    public void init(final ShardingSphereDatabase database, final SQLStatement 
sqlStatement) {
+    public Collection<LocalDataQueryResultRow> getRows(final 
ShardingSphereDatabase database, final ShowUnusedShardingKeyGeneratorsStatement 
sqlStatement) {
         Optional<ShardingRule> rule = 
database.getRuleMetaData().findSingleRule(ShardingRule.class);
-        rule.ifPresent(optional -> 
getUnusedKeyGenerators((ShardingRuleConfiguration) 
optional.getConfiguration()));
-    }
-    
-    private void getUnusedKeyGenerators(final ShardingRuleConfiguration 
shardingRuleConfig) {
+        if (!rule.isPresent()) {
+            return Collections.emptyList();
+        }
+        ShardingRuleConfiguration shardingRuleConfig = 
(ShardingRuleConfiguration) rule.get().getConfiguration();
+        Collection<LocalDataQueryResultRow> result = new LinkedList<>();
         Collection<String> inUsedKeyGenerators = 
getUsedKeyGenerators(shardingRuleConfig);
-        Map<String, AlgorithmConfiguration> map = new HashMap<>();
         for (Entry<String, AlgorithmConfiguration> entry : 
shardingRuleConfig.getKeyGenerators().entrySet()) {
             if (!inUsedKeyGenerators.contains(entry.getKey())) {
-                map.put(entry.getKey(), entry.getValue());
+                result.add(new LocalDataQueryResultRow(entry.getKey(), 
entry.getValue().getType(), buildProps(entry.getValue().getProps())));
             }
         }
-        data = map.entrySet().iterator();
+        return result;
     }
     
     private Collection<String> getUsedKeyGenerators(final 
ShardingRuleConfiguration shardingRuleConfig) {
@@ -81,24 +76,6 @@ public final class UnusedShardingKeyGeneratorResultSet 
implements DatabaseDistSQ
         return Arrays.asList("name", "type", "props");
     }
     
-    @Override
-    public boolean next() {
-        return data.hasNext();
-    }
-    
-    @Override
-    public Collection<Object> getRowData() {
-        return buildTableRowData(data.next());
-    }
-    
-    private Collection<Object> buildTableRowData(final Entry<String, 
AlgorithmConfiguration> data) {
-        Collection<Object> result = new LinkedList<>();
-        result.add(data.getKey());
-        result.add(data.getValue().getType());
-        result.add(buildProps(data.getValue().getProps()));
-        return result;
-    }
-    
     private Object buildProps(final Properties props) {
         return Objects.nonNull(props) ? PropertiesConverter.convert(props) : 
"";
     }
diff --git 
a/features/sharding/distsql/handler/src/main/resources/META-INF/services/org.apache.shardingsphere.distsql.handler.query.RQLExecutor
 
b/features/sharding/distsql/handler/src/main/resources/META-INF/services/org.apache.shardingsphere.distsql.handler.query.RQLExecutor
index d0ef5baad1b..9c1ed65855b 100644
--- 
a/features/sharding/distsql/handler/src/main/resources/META-INF/services/org.apache.shardingsphere.distsql.handler.query.RQLExecutor
+++ 
b/features/sharding/distsql/handler/src/main/resources/META-INF/services/org.apache.shardingsphere.distsql.handler.query.RQLExecutor
@@ -25,3 +25,4 @@ 
org.apache.shardingsphere.sharding.distsql.handler.query.ShowShardingTableRulesU
 
org.apache.shardingsphere.sharding.distsql.handler.query.ShowShardingTableRulesUsedAuditorExecutor
 
org.apache.shardingsphere.sharding.distsql.handler.query.ShowShardingTableNodesExecutor
 
org.apache.shardingsphere.sharding.distsql.handler.query.ShowUnusedShardingAlgorithmsExecutor
+org.apache.shardingsphere.sharding.distsql.handler.query.ShowUnusedShardingKeyGeneratorExecutor
diff --git 
a/features/sharding/distsql/handler/src/main/resources/META-INF/services/org.apache.shardingsphere.distsql.handler.resultset.DistSQLResultSet
 
b/features/sharding/distsql/handler/src/main/resources/META-INF/services/org.apache.shardingsphere.distsql.handler.resultset.DistSQLResultSet
index 51b174a22ca..8dc6f9999dc 100644
--- 
a/features/sharding/distsql/handler/src/main/resources/META-INF/services/org.apache.shardingsphere.distsql.handler.resultset.DistSQLResultSet
+++ 
b/features/sharding/distsql/handler/src/main/resources/META-INF/services/org.apache.shardingsphere.distsql.handler.resultset.DistSQLResultSet
@@ -17,6 +17,5 @@
 
 
org.apache.shardingsphere.sharding.distsql.handler.query.ShardingTableReferenceRuleResultSet
 
org.apache.shardingsphere.sharding.distsql.handler.query.BroadcastTableRuleResultSet
-org.apache.shardingsphere.sharding.distsql.handler.query.UnusedShardingKeyGeneratorResultSet
 
org.apache.shardingsphere.sharding.distsql.handler.query.UnusedShardingAuditorsResultSet
 
org.apache.shardingsphere.sharding.distsql.handler.query.CountShardingRuleResultSet
diff --git 
a/features/sharding/distsql/handler/src/test/java/org/apache/shardingsphere/sharding/distsql/query/UnusedShardingKeyGeneratorResultSetTest.java
 
b/features/sharding/distsql/handler/src/test/java/org/apache/shardingsphere/sharding/distsql/query/ShowUnusedShardingKeyGeneratorExecutorTest.java
similarity index 70%
rename from 
features/sharding/distsql/handler/src/test/java/org/apache/shardingsphere/sharding/distsql/query/UnusedShardingKeyGeneratorResultSetTest.java
rename to 
features/sharding/distsql/handler/src/test/java/org/apache/shardingsphere/sharding/distsql/query/ShowUnusedShardingKeyGeneratorExecutorTest.java
index b8220aa8a43..d86ac61616d 100644
--- 
a/features/sharding/distsql/handler/src/test/java/org/apache/shardingsphere/sharding/distsql/query/UnusedShardingKeyGeneratorResultSetTest.java
+++ 
b/features/sharding/distsql/handler/src/test/java/org/apache/shardingsphere/sharding/distsql/query/ShowUnusedShardingKeyGeneratorExecutorTest.java
@@ -17,21 +17,23 @@
 
 package org.apache.shardingsphere.sharding.distsql.query;
 
+import org.apache.shardingsphere.distsql.handler.query.RQLExecutor;
 import org.apache.shardingsphere.infra.config.algorithm.AlgorithmConfiguration;
 import org.apache.shardingsphere.infra.config.rule.RuleConfiguration;
+import 
org.apache.shardingsphere.infra.merge.result.impl.local.LocalDataQueryResultRow;
 import 
org.apache.shardingsphere.infra.metadata.database.ShardingSphereDatabase;
 import 
org.apache.shardingsphere.infra.metadata.database.rule.ShardingSphereRuleMetaData;
 import org.apache.shardingsphere.sharding.api.config.ShardingRuleConfiguration;
 import 
org.apache.shardingsphere.sharding.api.config.rule.ShardingAutoTableRuleConfiguration;
 import 
org.apache.shardingsphere.sharding.api.config.strategy.keygen.KeyGenerateStrategyConfiguration;
-import 
org.apache.shardingsphere.sharding.distsql.handler.query.UnusedShardingKeyGeneratorResultSet;
-import 
org.apache.shardingsphere.sharding.distsql.parser.statement.ShowShardingAlgorithmsStatement;
+import 
org.apache.shardingsphere.sharding.distsql.handler.query.ShowUnusedShardingKeyGeneratorExecutor;
+import 
org.apache.shardingsphere.sharding.distsql.parser.statement.ShowUnusedShardingKeyGeneratorsStatement;
 import org.apache.shardingsphere.sharding.rule.ShardingRule;
 import org.junit.Test;
 
-import java.util.ArrayList;
+import java.util.Collection;
 import java.util.Collections;
-import java.util.List;
+import java.util.Iterator;
 import java.util.Properties;
 
 import static org.hamcrest.CoreMatchers.is;
@@ -40,17 +42,29 @@ import static org.mockito.Mockito.RETURNS_DEEP_STUBS;
 import static org.mockito.Mockito.mock;
 import static org.mockito.Mockito.when;
 
-public final class UnusedShardingKeyGeneratorResultSetTest {
+public final class ShowUnusedShardingKeyGeneratorExecutorTest {
     
     @Test
     public void assertGetRowData() {
-        UnusedShardingKeyGeneratorResultSet resultSet = new 
UnusedShardingKeyGeneratorResultSet();
-        resultSet.init(mockDatabase(), 
mock(ShowShardingAlgorithmsStatement.class));
-        List<Object> actual = new ArrayList<>(resultSet.getRowData());
-        assertThat(actual.size(), is(3));
-        assertThat(actual.get(0), is("uuid_key_generator"));
-        assertThat(actual.get(1), is("UUID"));
-        assertThat(actual.get(2).toString(), is(""));
+        RQLExecutor<ShowUnusedShardingKeyGeneratorsStatement> executor = new 
ShowUnusedShardingKeyGeneratorExecutor();
+        Collection<LocalDataQueryResultRow> actual = 
executor.getRows(mockDatabase(), 
mock(ShowUnusedShardingKeyGeneratorsStatement.class));
+        assertThat(actual.size(), is(1));
+        Iterator<LocalDataQueryResultRow> iterator = actual.iterator();
+        LocalDataQueryResultRow row = iterator.next();
+        assertThat(row.getCell(1), is("uuid_key_generator"));
+        assertThat(row.getCell(2), is("UUID"));
+        assertThat(row.getCell(3), is(""));
+    }
+    
+    @Test
+    public void assertGetColumnNames() {
+        RQLExecutor<ShowUnusedShardingKeyGeneratorsStatement> executor = new 
ShowUnusedShardingKeyGeneratorExecutor();
+        Collection<String> columns = executor.getColumnNames();
+        assertThat(columns.size(), is(3));
+        Iterator<String> iterator = columns.iterator();
+        assertThat(iterator.next(), is("name"));
+        assertThat(iterator.next(), is("type"));
+        assertThat(iterator.next(), is("props"));
     }
     
     private ShardingSphereDatabase mockDatabase() {

Reply via email to