|
15 | 15 | * See the License for the specific language governing permissions and
|
16 | 16 | * limitations under the License.
|
17 | 17 | */
|
| 18 | +/* |
| 19 | + * Copyright (C) 2024 ScyllaDB |
| 20 | + * |
| 21 | + * Modified by ScyllaDB |
| 22 | + */ |
18 | 23 | package com.datastax.oss.driver.internal.core.metadata.schema.queries;
|
19 | 24 |
|
20 | 25 | import static com.datastax.oss.driver.Assertions.assertThat;
|
|
28 | 33 | import com.datastax.oss.driver.internal.core.adminrequest.AdminResult;
|
29 | 34 | import com.datastax.oss.driver.internal.core.channel.DriverChannel;
|
30 | 35 | import com.datastax.oss.driver.shaded.guava.common.collect.ImmutableList;
|
| 36 | +import java.time.Duration; |
31 | 37 | import java.util.Collections;
|
32 | 38 | import java.util.Queue;
|
33 | 39 | import java.util.concurrent.CompletionStage;
|
@@ -63,52 +69,72 @@ public void should_query_with_keyspace_filter() {
|
63 | 69 | should_query_with_where_clause(" WHERE keyspace_name IN ('ks1','ks2')");
|
64 | 70 | }
|
65 | 71 |
|
| 72 | + @Test |
| 73 | + public void should_query_with_using_clause() { |
| 74 | + when(config.getDuration(DefaultDriverOption.METADATA_SCHEMA_REQUEST_TIMEOUT)) |
| 75 | + .thenReturn(Duration.ofMillis(100)); |
| 76 | + should_query_with_clauses("", " USING TIMEOUT 100ms"); |
| 77 | + } |
| 78 | + |
66 | 79 | private void should_query_with_where_clause(String whereClause) {
|
| 80 | + should_query_with_clauses(whereClause, ""); |
| 81 | + } |
| 82 | + |
| 83 | + private void should_query_with_clauses(String whereClause, String usingClause) { |
67 | 84 | SchemaQueriesWithMockedChannel queries =
|
68 |
| - new SchemaQueriesWithMockedChannel(driverChannel, node, config, "test"); |
| 85 | + new SchemaQueriesWithMockedChannel( |
| 86 | + driverChannel, node, config, "test", !usingClause.equals("")); |
69 | 87 | CompletionStage<SchemaRows> result = queries.execute();
|
70 | 88 |
|
71 | 89 | // Keyspace
|
72 | 90 | Call call = queries.calls.poll();
|
73 |
| - assertThat(call.query).isEqualTo("SELECT * FROM system_schema.keyspaces" + whereClause); |
| 91 | + assertThat(call.query) |
| 92 | + .isEqualTo("SELECT * FROM system_schema.keyspaces" + whereClause + usingClause); |
74 | 93 | call.result.complete(
|
75 | 94 | mockResult(mockRow("keyspace_name", "ks1"), mockRow("keyspace_name", "ks2")));
|
76 | 95 |
|
77 | 96 | // Types
|
78 | 97 | call = queries.calls.poll();
|
79 |
| - assertThat(call.query).isEqualTo("SELECT * FROM system_schema.types" + whereClause); |
| 98 | + assertThat(call.query) |
| 99 | + .isEqualTo("SELECT * FROM system_schema.types" + whereClause + usingClause); |
80 | 100 | call.result.complete(mockResult(mockRow("keyspace_name", "ks1", "type_name", "type")));
|
81 | 101 |
|
82 | 102 | // Tables
|
83 | 103 | call = queries.calls.poll();
|
84 |
| - assertThat(call.query).isEqualTo("SELECT * FROM system_schema.tables" + whereClause); |
| 104 | + assertThat(call.query) |
| 105 | + .isEqualTo("SELECT * FROM system_schema.tables" + whereClause + usingClause); |
85 | 106 | call.result.complete(mockResult(mockRow("keyspace_name", "ks1", "table_name", "foo")));
|
86 | 107 |
|
87 | 108 | // Columns
|
88 | 109 | call = queries.calls.poll();
|
89 |
| - assertThat(call.query).isEqualTo("SELECT * FROM system_schema.columns" + whereClause); |
| 110 | + assertThat(call.query) |
| 111 | + .isEqualTo("SELECT * FROM system_schema.columns" + whereClause + usingClause); |
90 | 112 | call.result.complete(
|
91 | 113 | mockResult(mockRow("keyspace_name", "ks1", "table_name", "foo", "column_name", "k")));
|
92 | 114 |
|
93 | 115 | // Indexes
|
94 | 116 | call = queries.calls.poll();
|
95 |
| - assertThat(call.query).isEqualTo("SELECT * FROM system_schema.indexes" + whereClause); |
| 117 | + assertThat(call.query) |
| 118 | + .isEqualTo("SELECT * FROM system_schema.indexes" + whereClause + usingClause); |
96 | 119 | call.result.complete(
|
97 | 120 | mockResult(mockRow("keyspace_name", "ks1", "table_name", "foo", "index_name", "index")));
|
98 | 121 |
|
99 | 122 | // Views
|
100 | 123 | call = queries.calls.poll();
|
101 |
| - assertThat(call.query).isEqualTo("SELECT * FROM system_schema.views" + whereClause); |
| 124 | + assertThat(call.query) |
| 125 | + .isEqualTo("SELECT * FROM system_schema.views" + whereClause + usingClause); |
102 | 126 | call.result.complete(mockResult(mockRow("keyspace_name", "ks2", "view_name", "foo")));
|
103 | 127 |
|
104 | 128 | // Functions
|
105 | 129 | call = queries.calls.poll();
|
106 |
| - assertThat(call.query).isEqualTo("SELECT * FROM system_schema.functions" + whereClause); |
| 130 | + assertThat(call.query) |
| 131 | + .isEqualTo("SELECT * FROM system_schema.functions" + whereClause + usingClause); |
107 | 132 | call.result.complete(mockResult(mockRow("keyspace_name", "ks2", "function_name", "add")));
|
108 | 133 |
|
109 | 134 | // Aggregates
|
110 | 135 | call = queries.calls.poll();
|
111 |
| - assertThat(call.query).isEqualTo("SELECT * FROM system_schema.aggregates" + whereClause); |
| 136 | + assertThat(call.query) |
| 137 | + .isEqualTo("SELECT * FROM system_schema.aggregates" + whereClause + usingClause); |
112 | 138 | call.result.complete(mockResult(mockRow("keyspace_name", "ks2", "aggregate_name", "add")));
|
113 | 139 |
|
114 | 140 | channel.runPendingTasks();
|
@@ -349,10 +375,26 @@ public void should_abort_if_query_fails() {
|
349 | 375 | static class SchemaQueriesWithMockedChannel extends Cassandra3SchemaQueries {
|
350 | 376 |
|
351 | 377 | final Queue<Call> calls = new LinkedBlockingDeque<>();
|
| 378 | + final boolean shouldApplyUsingTimeout; |
352 | 379 |
|
353 | 380 | SchemaQueriesWithMockedChannel(
|
354 | 381 | DriverChannel channel, Node node, DriverExecutionProfile config, String logPrefix) {
|
| 382 | + this(channel, node, config, logPrefix, false); |
| 383 | + } |
| 384 | + |
| 385 | + SchemaQueriesWithMockedChannel( |
| 386 | + DriverChannel channel, |
| 387 | + Node node, |
| 388 | + DriverExecutionProfile config, |
| 389 | + String logPrefix, |
| 390 | + boolean shouldApplyUsingTimeout) { |
355 | 391 | super(channel, node, config, logPrefix);
|
| 392 | + this.shouldApplyUsingTimeout = shouldApplyUsingTimeout; |
| 393 | + } |
| 394 | + |
| 395 | + @Override |
| 396 | + protected boolean shouldApplyUsingTimeout() { |
| 397 | + return shouldApplyUsingTimeout; |
356 | 398 | }
|
357 | 399 |
|
358 | 400 | @Override
|
|
0 commit comments