com.scalar.db.api.DistributedStorageSingleClusteringKeyScanIntegrationTestBase Maven / Gradle / Ivy
package com.scalar.db.api;
import static org.assertj.core.api.Assertions.assertThat;
import com.scalar.db.api.Scan.Ordering;
import com.scalar.db.api.Scan.Ordering.Order;
import com.scalar.db.exception.storage.ExecutionException;
import com.scalar.db.io.DataType;
import com.scalar.db.io.Key;
import com.scalar.db.io.Value;
import com.scalar.db.service.StorageFactory;
import com.scalar.db.util.TestUtils;
import edu.umd.cs.findbugs.annotations.Nullable;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Properties;
import java.util.Random;
import java.util.Set;
import java.util.stream.IntStream;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestInstance;
@TestInstance(TestInstance.Lifecycle.PER_CLASS)
public abstract class DistributedStorageSingleClusteringKeyScanIntegrationTestBase {
private enum OrderingType {
SPECIFIED,
REVERSED,
NOTHING,
}
private static final String TEST_NAME = "storage_single_ckey";
private static final String NAMESPACE = "int_test_" + TEST_NAME;
private static final String PARTITION_KEY = "pkey";
private static final String CLUSTERING_KEY = "ckey";
private static final String COL_NAME = "col";
private static final int CLUSTERING_KEY_NUM = 20;
private static final Random random = new Random();
private DistributedStorageAdmin admin;
private DistributedStorage storage;
private String namespace;
private Set clusteringKeyTypes;
private long seed;
@BeforeAll
public void beforeAll() throws Exception {
initialize(TEST_NAME);
StorageFactory factory = StorageFactory.create(getProperties(TEST_NAME));
admin = factory.getAdmin();
namespace = getNamespace();
clusteringKeyTypes = getClusteringKeyTypes();
createTables();
storage = factory.getStorage();
seed = System.currentTimeMillis();
System.out.println(
"The seed used in the single clustering key scan integration test is " + seed);
}
protected void initialize(String testName) throws Exception {}
protected abstract Properties getProperties(String testName);
protected String getNamespace() {
return NAMESPACE;
}
protected Set getClusteringKeyTypes() {
return new HashSet<>(Arrays.asList(DataType.values()));
}
private void createTables() throws ExecutionException {
Map options = getCreationOptions();
admin.createNamespace(namespace, true, options);
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
createTable(clusteringKeyType, clusteringOrder, options);
}
}
}
protected Map getCreationOptions() {
return Collections.emptyMap();
}
private void createTable(
DataType clusteringKeyType, Order clusteringOrder, Map options)
throws ExecutionException {
admin.createTable(
namespace,
getTableName(clusteringKeyType, clusteringOrder),
TableMetadata.newBuilder()
.addColumn(PARTITION_KEY, DataType.INT)
.addColumn(CLUSTERING_KEY, clusteringKeyType)
.addColumn(COL_NAME, DataType.INT)
.addPartitionKey(PARTITION_KEY)
.addClusteringKey(CLUSTERING_KEY, clusteringOrder)
.build(),
true,
options);
}
@AfterAll
public void afterAll() throws ExecutionException {
dropTables();
admin.close();
storage.close();
}
private void dropTables() throws ExecutionException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
admin.dropTable(namespace, getTableName(clusteringKeyType, clusteringOrder));
}
}
admin.dropNamespace(namespace);
}
private void truncateTable(DataType clusteringKeyType, Order clusteringOrder)
throws ExecutionException {
admin.truncateTable(namespace, getTableName(clusteringKeyType, clusteringOrder));
}
private String getTableName(DataType clusteringKeyType, Order clusteringOrder) {
return clusteringKeyType + "_" + clusteringOrder;
}
@Test
public void scan_WithoutClusteringKeyRange_ShouldReturnProperResult()
throws ExecutionException, IOException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
random.setSeed(seed);
truncateTable(clusteringKeyType, clusteringOrder);
List> clusteringKeyValues = prepareRecords(clusteringKeyType, clusteringOrder);
for (OrderingType orderingType : OrderingType.values()) {
for (boolean withLimit : Arrays.asList(false, true)) {
scan_WithoutClusteringKeyRange_ShouldReturnProperResult(
clusteringKeyValues, clusteringKeyType, clusteringOrder, orderingType, withLimit);
}
}
}
}
}
private void scan_WithoutClusteringKeyRange_ShouldReturnProperResult(
List> clusteringKeyValues,
DataType clusteringKeyType,
Order clusteringOrder,
OrderingType orderingType,
boolean withLimit)
throws ExecutionException, IOException {
// Arrange
List> expected =
getExpected(clusteringKeyValues, null, null, null, null, orderingType);
int limit = getLimit(withLimit, expected);
if (limit > 0) {
expected = expected.subList(0, limit);
}
Scan scan =
getScan(clusteringKeyType, clusteringOrder, null, null, null, null, orderingType, limit);
// Act
List actual = scanAll(scan);
// Assert
assertScanResult(
actual,
expected,
description(clusteringKeyType, clusteringOrder, null, null, orderingType, withLimit));
}
@Test
public void scan_WithClusteringKeyRange_ShouldReturnProperResult()
throws ExecutionException, IOException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
random.setSeed(seed);
truncateTable(clusteringKeyType, clusteringOrder);
List> clusteringKeyValues = prepareRecords(clusteringKeyType, clusteringOrder);
for (boolean startInclusive : Arrays.asList(true, false)) {
for (boolean endInclusive : Arrays.asList(true, false)) {
for (OrderingType orderingType : OrderingType.values()) {
for (boolean withLimit : Arrays.asList(false, true)) {
scan_WithClusteringKeyRange_ShouldReturnProperResult(
clusteringKeyValues,
clusteringKeyType,
clusteringOrder,
startInclusive,
endInclusive,
orderingType,
withLimit);
}
}
}
}
}
}
}
private void scan_WithClusteringKeyRange_ShouldReturnProperResult(
List> clusteringKeyValues,
DataType clusteringKeyType,
Order clusteringOrder,
boolean startInclusive,
boolean endInclusive,
OrderingType orderingType,
boolean withLimit)
throws ExecutionException, IOException {
// Arrange
Value> startClusteringKeyValue;
Value> endClusteringKeyValue;
if (clusteringKeyType == DataType.BOOLEAN) {
startClusteringKeyValue = clusteringKeyValues.get(0);
endClusteringKeyValue = clusteringKeyValues.get(1);
} else {
startClusteringKeyValue = clusteringKeyValues.get(4);
endClusteringKeyValue = clusteringKeyValues.get(14);
}
List> expected =
getExpected(
clusteringKeyValues,
startClusteringKeyValue,
startInclusive,
endClusteringKeyValue,
endInclusive,
orderingType);
int limit = getLimit(withLimit, expected);
if (limit > 0) {
expected = expected.subList(0, limit);
}
Scan scan =
getScan(
clusteringKeyType,
clusteringOrder,
startClusteringKeyValue,
startInclusive,
endClusteringKeyValue,
endInclusive,
orderingType,
limit);
// Act
List actual = scanAll(scan);
// Assert
assertScanResult(
actual,
expected,
description(
clusteringKeyType,
clusteringOrder,
startInclusive,
endInclusive,
orderingType,
withLimit));
}
@Test
public void scan_WithClusteringKeyRangeWithSameValues_ShouldReturnProperResult()
throws ExecutionException, IOException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
random.setSeed(seed);
truncateTable(clusteringKeyType, clusteringOrder);
List> clusteringKeyValues = prepareRecords(clusteringKeyType, clusteringOrder);
for (boolean startInclusive : Arrays.asList(true, false)) {
for (boolean endInclusive : Arrays.asList(true, false)) {
for (OrderingType orderingType : OrderingType.values()) {
for (boolean withLimit : Arrays.asList(false, true)) {
scan_WithClusteringKeyRangeWithSameValues_ShouldReturnProperResult(
clusteringKeyValues,
clusteringKeyType,
clusteringOrder,
startInclusive,
endInclusive,
orderingType,
withLimit);
}
}
}
}
}
}
}
private void scan_WithClusteringKeyRangeWithSameValues_ShouldReturnProperResult(
List> clusteringKeyValues,
DataType clusteringKeyType,
Order clusteringOrder,
boolean startInclusive,
boolean endInclusive,
OrderingType orderingType,
boolean withLimit)
throws ExecutionException, IOException {
// Arrange
Value> startAndEndClusteringKeyValue;
if (clusteringKeyType == DataType.BOOLEAN) {
startAndEndClusteringKeyValue = clusteringKeyValues.get(0);
} else {
startAndEndClusteringKeyValue = clusteringKeyValues.get(9);
}
List> expected =
getExpected(
clusteringKeyValues,
startAndEndClusteringKeyValue,
startInclusive,
startAndEndClusteringKeyValue,
endInclusive,
orderingType);
int limit = getLimit(withLimit, expected);
if (limit > 0) {
expected = expected.subList(0, limit);
}
Scan scan =
getScan(
clusteringKeyType,
clusteringOrder,
startAndEndClusteringKeyValue,
startInclusive,
startAndEndClusteringKeyValue,
endInclusive,
orderingType,
limit);
// Act
List actual = scanAll(scan);
// Assert
assertScanResult(
actual,
expected,
description(
clusteringKeyType,
clusteringOrder,
startInclusive,
endInclusive,
orderingType,
withLimit));
}
@Test
public void scan_WithClusteringKeyRangeWithMinAndMaxValue_ShouldReturnProperResult()
throws ExecutionException, IOException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
random.setSeed(seed);
truncateTable(clusteringKeyType, clusteringOrder);
List> clusteringKeyValues = prepareRecords(clusteringKeyType, clusteringOrder);
for (boolean startInclusive : Arrays.asList(true, false)) {
for (boolean endInclusive : Arrays.asList(true, false)) {
for (OrderingType orderingType : OrderingType.values()) {
for (boolean withLimit : Arrays.asList(false, true)) {
scan_WithClusteringKeyRangeWithMinAndMaxValue_ShouldReturnProperResult(
clusteringKeyValues,
clusteringKeyType,
clusteringOrder,
startInclusive,
endInclusive,
orderingType,
withLimit);
}
}
}
}
}
}
}
private void scan_WithClusteringKeyRangeWithMinAndMaxValue_ShouldReturnProperResult(
List> clusteringKeyValues,
DataType clusteringKeyType,
Order clusteringOrder,
boolean startInclusive,
boolean endInclusive,
OrderingType orderingType,
boolean withLimit)
throws ExecutionException, IOException {
// Arrange
Value> startClusteringKeyValue = getMinValue(CLUSTERING_KEY, clusteringKeyType);
Value> endClusteringKeyValue = getMaxValue(CLUSTERING_KEY, clusteringKeyType);
List> expected =
getExpected(
clusteringKeyValues,
startClusteringKeyValue,
startInclusive,
endClusteringKeyValue,
endInclusive,
orderingType);
int limit = getLimit(withLimit, expected);
if (limit > 0) {
expected = expected.subList(0, limit);
}
Scan scan =
getScan(
clusteringKeyType,
clusteringOrder,
startClusteringKeyValue,
startInclusive,
endClusteringKeyValue,
endInclusive,
orderingType,
limit);
// Act
List actual = scanAll(scan);
// Assert
assertScanResult(
actual,
expected,
description(
clusteringKeyType,
clusteringOrder,
startInclusive,
endInclusive,
orderingType,
withLimit));
}
@Test
public void scan_WithClusteringKeyStartRange_ShouldReturnProperResult()
throws ExecutionException, IOException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
random.setSeed(seed);
truncateTable(clusteringKeyType, clusteringOrder);
List> clusteringKeyValues = prepareRecords(clusteringKeyType, clusteringOrder);
for (boolean startInclusive : Arrays.asList(true, false)) {
for (OrderingType orderingType : OrderingType.values()) {
for (boolean withLimit : Arrays.asList(false, true)) {
scan_WithClusteringKeyStartRange_ShouldReturnProperResult(
clusteringKeyValues,
clusteringKeyType,
clusteringOrder,
startInclusive,
orderingType,
withLimit);
}
}
}
}
}
}
private void scan_WithClusteringKeyStartRange_ShouldReturnProperResult(
List> clusteringKeyValues,
DataType clusteringKeyType,
Order clusteringOrder,
boolean startInclusive,
OrderingType orderingType,
boolean withLimit)
throws ExecutionException, IOException {
// Arrange
Value> startClusteringKeyValue;
if (clusteringKeyType == DataType.BOOLEAN) {
startClusteringKeyValue = clusteringKeyValues.get(0);
} else {
startClusteringKeyValue = clusteringKeyValues.get(4);
}
List> expected =
getExpected(
clusteringKeyValues, startClusteringKeyValue, startInclusive, null, null, orderingType);
int limit = getLimit(withLimit, expected);
if (limit > 0) {
expected = expected.subList(0, limit);
}
Scan scan =
getScan(
clusteringKeyType,
clusteringOrder,
startClusteringKeyValue,
startInclusive,
null,
null,
orderingType,
limit);
// Act
List actual = scanAll(scan);
// Assert
assertScanResult(
actual,
expected,
description(
clusteringKeyType, clusteringOrder, startInclusive, null, orderingType, withLimit));
}
@Test
public void scan_WithClusteringKeyStartRangeWithMinValue_ShouldReturnProperResult()
throws ExecutionException, IOException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
random.setSeed(seed);
truncateTable(clusteringKeyType, clusteringOrder);
List> clusteringKeyValues = prepareRecords(clusteringKeyType, clusteringOrder);
for (boolean startInclusive : Arrays.asList(true, false)) {
for (OrderingType orderingType : OrderingType.values()) {
for (boolean withLimit : Arrays.asList(false, true)) {
scan_WithClusteringKeyStartRangeWithMinValue_ShouldReturnProperResult(
clusteringKeyValues,
clusteringKeyType,
clusteringOrder,
startInclusive,
orderingType,
withLimit);
}
}
}
}
}
}
private void scan_WithClusteringKeyStartRangeWithMinValue_ShouldReturnProperResult(
List> clusteringKeyValues,
DataType clusteringKeyType,
Order clusteringOrder,
boolean startInclusive,
OrderingType orderingType,
boolean withLimit)
throws ExecutionException, IOException {
// Arrange
Value> startClusteringKeyValue = getMinValue(CLUSTERING_KEY, clusteringKeyType);
List> expected =
getExpected(
clusteringKeyValues, startClusteringKeyValue, startInclusive, null, null, orderingType);
int limit = getLimit(withLimit, expected);
if (limit > 0) {
expected = expected.subList(0, limit);
}
Scan scan =
getScan(
clusteringKeyType,
clusteringOrder,
startClusteringKeyValue,
startInclusive,
null,
null,
orderingType,
limit);
// Act
List actual = scanAll(scan);
// Assert
assertScanResult(
actual,
expected,
description(
clusteringKeyType, clusteringOrder, startInclusive, null, orderingType, withLimit));
}
@Test
public void scan_WithClusteringKeyEndRange_ShouldReturnProperResult()
throws ExecutionException, IOException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
random.setSeed(seed);
truncateTable(clusteringKeyType, clusteringOrder);
List> clusteringKeyValues = prepareRecords(clusteringKeyType, clusteringOrder);
for (boolean endInclusive : Arrays.asList(true, false)) {
for (OrderingType orderingType : OrderingType.values()) {
for (boolean withLimit : Arrays.asList(false, true)) {
scan_WithClusteringKeyEndRange_ShouldReturnProperResult(
clusteringKeyValues,
clusteringKeyType,
clusteringOrder,
endInclusive,
orderingType,
withLimit);
}
}
}
}
}
}
private void scan_WithClusteringKeyEndRange_ShouldReturnProperResult(
List> clusteringKeyValues,
DataType clusteringKeyType,
Order clusteringOrder,
boolean endInclusive,
OrderingType orderingType,
boolean withLimit)
throws ExecutionException, IOException {
// Arrange
Value> endClusteringKeyValue;
if (clusteringKeyType == DataType.BOOLEAN) {
endClusteringKeyValue = clusteringKeyValues.get(1);
} else {
endClusteringKeyValue = clusteringKeyValues.get(14);
}
List> expected =
getExpected(
clusteringKeyValues, null, null, endClusteringKeyValue, endInclusive, orderingType);
int limit = getLimit(withLimit, expected);
if (limit > 0) {
expected = expected.subList(0, limit);
}
Scan scan =
getScan(
clusteringKeyType,
clusteringOrder,
null,
null,
endClusteringKeyValue,
endInclusive,
orderingType,
limit);
// Act
List actual = scanAll(scan);
// Assert
assertScanResult(
actual,
expected,
description(
clusteringKeyType, clusteringOrder, null, endInclusive, orderingType, withLimit));
}
@Test
public void scan_WithClusteringKeyEndRangeWithMaxValue_ShouldReturnProperResult()
throws ExecutionException, IOException {
for (DataType clusteringKeyType : clusteringKeyTypes) {
for (Order clusteringOrder : Order.values()) {
random.setSeed(seed);
truncateTable(clusteringKeyType, clusteringOrder);
List> clusteringKeyValues = prepareRecords(clusteringKeyType, clusteringOrder);
for (boolean endInclusive : Arrays.asList(true, false)) {
for (OrderingType orderingType : OrderingType.values()) {
for (boolean withLimit : Arrays.asList(false, true)) {
scan_WithClusteringKeyEndRangeWithMaxValue_ShouldReturnProperResult(
clusteringKeyValues,
clusteringKeyType,
clusteringOrder,
endInclusive,
orderingType,
withLimit);
}
}
}
}
}
}
private void scan_WithClusteringKeyEndRangeWithMaxValue_ShouldReturnProperResult(
List> clusteringKeyValues,
DataType clusteringKeyType,
Order clusteringOrder,
boolean endInclusive,
OrderingType orderingType,
boolean withLimit)
throws ExecutionException, IOException {
// Arrange
Value> endClusteringKey = getMaxValue(CLUSTERING_KEY, clusteringKeyType);
List> expected =
getExpected(clusteringKeyValues, null, null, endClusteringKey, endInclusive, orderingType);
int limit = getLimit(withLimit, expected);
if (limit > 0) {
expected = expected.subList(0, limit);
}
Scan scan =
getScan(
clusteringKeyType,
clusteringOrder,
null,
null,
endClusteringKey,
endInclusive,
orderingType,
limit);
// Act
List actual = scanAll(scan);
// Assert
assertScanResult(
actual,
expected,
description(
clusteringKeyType, clusteringOrder, null, endInclusive, orderingType, withLimit));
}
private List> prepareRecords(DataType clusteringKeyType, Order clusteringOrder)
throws ExecutionException {
List> ret = new ArrayList<>();
List puts = new ArrayList<>();
if (clusteringKeyType == DataType.BOOLEAN) {
TestUtils.booleanValues(CLUSTERING_KEY)
.forEach(
clusteringKeyValue -> {
ret.add(clusteringKeyValue);
puts.add(preparePut(clusteringKeyType, clusteringOrder, clusteringKeyValue));
});
} else {
Set> valueSet = new HashSet<>();
// Add min and max clustering key values
Arrays.asList(
getMinValue(CLUSTERING_KEY, clusteringKeyType),
getMaxValue(CLUSTERING_KEY, clusteringKeyType))
.forEach(
clusteringKeyValue -> {
valueSet.add(clusteringKeyValue);
ret.add(clusteringKeyValue);
puts.add(preparePut(clusteringKeyType, clusteringOrder, clusteringKeyValue));
});
IntStream.range(0, CLUSTERING_KEY_NUM - 2)
.forEach(
i -> {
Value> clusteringKeyValue;
while (true) {
clusteringKeyValue = getRandomValue(random, CLUSTERING_KEY, clusteringKeyType);
// reject duplication
if (!valueSet.contains(clusteringKeyValue)) {
valueSet.add(clusteringKeyValue);
break;
}
}
ret.add(clusteringKeyValue);
puts.add(preparePut(clusteringKeyType, clusteringOrder, clusteringKeyValue));
});
}
try {
List buffer = new ArrayList<>();
for (Put put : puts) {
buffer.add(put);
if (buffer.size() == 20) {
storage.mutate(buffer);
buffer.clear();
}
}
if (!buffer.isEmpty()) {
storage.mutate(buffer);
}
} catch (ExecutionException e) {
throw new ExecutionException("put data to database failed", e);
}
ret.sort(
clusteringOrder == Order.ASC
? com.google.common.collect.Ordering.natural()
: com.google.common.collect.Ordering.natural().reverse());
return ret;
}
private Put preparePut(
DataType clusteringKeyType, Order clusteringOrder, Value> clusteringKeyValue) {
return new Put(getPartitionKey(), new Key(clusteringKeyValue))
.withValue(COL_NAME, 1)
.forNamespace(namespace)
.forTable(getTableName(clusteringKeyType, clusteringOrder));
}
private Key getPartitionKey() {
return new Key(PARTITION_KEY, 1);
}
protected Value> getRandomValue(Random random, String columnName, DataType dataType) {
return TestUtils.getRandomValue(random, columnName, dataType);
}
protected Value> getMinValue(String columnName, DataType dataType) {
return TestUtils.getMinValue(columnName, dataType);
}
protected Value> getMaxValue(String columnName, DataType dataType) {
return TestUtils.getMaxValue(columnName, dataType);
}
private String description(
DataType clusteringKeyType,
Order clusteringOrder,
@Nullable Boolean startInclusive,
@Nullable Boolean endInclusive,
OrderingType orderingType,
boolean withLimit) {
StringBuilder builder = new StringBuilder();
builder.append(
String.format(
"failed with clusteringKeyType: %s, clusteringOrder: %s",
clusteringKeyType, clusteringOrder));
if (startInclusive != null) {
builder.append(String.format(", startInclusive: %s", startInclusive));
}
if (endInclusive != null) {
builder.append(String.format(", endInclusive: %s", endInclusive));
}
builder.append(String.format(", orderingType: %s, withLimit: %b", orderingType, withLimit));
return builder.toString();
}
private List scanAll(Scan scan) throws ExecutionException, IOException {
try (Scanner scanner = storage.scan(scan)) {
return scanner.all();
}
}
private List> getExpected(
List> clusteringKeyValues,
@Nullable Value> startClusteringKeyValue,
@Nullable Boolean startInclusive,
@Nullable Value> endClusteringKeyValue,
@Nullable Boolean endInclusive,
OrderingType orderingType) {
List> ret = new ArrayList<>();
for (Value> clusteringKeyValue : clusteringKeyValues) {
if (startClusteringKeyValue != null && startInclusive != null) {
int compare =
Objects.compare(
clusteringKeyValue,
startClusteringKeyValue,
com.google.common.collect.Ordering.natural());
if (!(startInclusive ? compare >= 0 : compare > 0)) {
continue;
}
}
if (endClusteringKeyValue != null && endInclusive != null) {
int compare =
Objects.compare(
clusteringKeyValue,
endClusteringKeyValue,
com.google.common.collect.Ordering.natural());
if (!(endInclusive ? compare <= 0 : compare < 0)) {
continue;
}
}
ret.add(clusteringKeyValue);
}
if (orderingType == OrderingType.REVERSED) {
Collections.reverse(ret);
}
return ret;
}
private int getLimit(boolean withLimit, List> expected) {
int limit = 0;
if (withLimit && !expected.isEmpty()) {
if (expected.size() == 1) {
limit = 1;
} else {
limit = random.nextInt(expected.size() - 1) + 1;
}
}
return limit;
}
private Scan getScan(
DataType clusteringKeyType,
Order clusteringOrder,
@Nullable Value> startClusteringKeyValue,
@Nullable Boolean startInclusive,
@Nullable Value> endClusteringKeyValue,
@Nullable Boolean endInclusive,
OrderingType orderingType,
int limit) {
Scan scan =
new Scan(getPartitionKey())
.forNamespace(namespace)
.forTable(getTableName(clusteringKeyType, clusteringOrder));
if (startClusteringKeyValue != null && startInclusive != null) {
scan.withStart(new Key(startClusteringKeyValue), startInclusive);
}
if (endClusteringKeyValue != null && endInclusive != null) {
scan.withEnd(new Key(endClusteringKeyValue), endInclusive);
}
switch (orderingType) {
case SPECIFIED:
scan.withOrdering(new Ordering(CLUSTERING_KEY, clusteringOrder));
break;
case REVERSED:
scan.withOrdering(new Ordering(CLUSTERING_KEY, TestUtils.reverseOrder(clusteringOrder)));
break;
case NOTHING:
break;
default:
throw new AssertionError();
}
if (limit > 0) {
scan.withLimit(limit);
}
return scan;
}
private void assertScanResult(
List actualResults, List> expected, String description) {
List> actual = new ArrayList<>();
for (Result actualResult : actualResults) {
assertThat(actualResult.getValue(CLUSTERING_KEY).isPresent()).isTrue();
actual.add(actualResult.getValue(CLUSTERING_KEY).get());
}
assertThat(actual).describedAs(description).isEqualTo(expected);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy