Skip to content

Commit

Permalink
Add support for "balance" option
Browse files Browse the repository at this point in the history
Closes #462
  • Loading branch information
nickkkccc committed Jan 25, 2024
1 parent 97e03fd commit 5f1fab1
Show file tree
Hide file tree
Showing 4 changed files with 55 additions and 2 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package io.tarantool.driver.api.space.options;

import io.tarantool.driver.api.space.options.crud.OperationWithBalanceOptions;
import io.tarantool.driver.api.space.options.crud.OperationWithBatchSizeOptions;
import io.tarantool.driver.api.space.options.crud.OperationWithBucketIdOptions;
import io.tarantool.driver.api.space.options.crud.OperationWithFieldsOptions;
Expand All @@ -21,5 +22,6 @@
public interface SelectOptions<T extends SelectOptions<T>>
extends OperationWithBucketIdOptions<T>, OperationWithTimeoutOptions<T>, OperationWithFieldsOptions<T>,
OperationWithModeOptions<T>, OperationWithBatchSizeOptions<T>, OperationWithYieldEveryOptions<T>,
OperationWithForceMapCallOptions<T>, OperationWithFullScanOptions<T>, OperationWithPreferReplicaOptions<T> {
OperationWithForceMapCallOptions<T>, OperationWithFullScanOptions<T>, OperationWithPreferReplicaOptions<T>,
OperationWithBalanceOptions<T> {
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
package io.tarantool.driver.api.space.options.crud;

import java.util.Optional;

import io.tarantool.driver.api.space.options.Options;
import io.tarantool.driver.api.space.options.Self;
import io.tarantool.driver.api.space.options.crud.enums.ProxyOption;

/**
* Base interface for all operation options that may have a configurable "balance" option.
*
* @author Belonogov Nikolay
*/
public interface OperationWithBalanceOptions<T extends OperationWithBalanceOptions<T>> extends Options, Self<T> {

/**
* Sets "balance" option value to true. If true then use replica according to vshard load balancing policy. Default
* value is false.
*
* @return this options instance.
*/
default T balance() {
addOption(ProxyOption.BALANCE, true);
return self();
}

/**
* @return "balance" option value.
*/
default Optional<Boolean> getBalance() {
return getOption(ProxyOption.BALANCE, Boolean.class);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,9 @@ public enum ProxyOption {

FULL_SCAN("fullscan"),

PREFER_REPLICA("prefer_replica");
PREFER_REPLICA("prefer_replica"),

BALANCE("balance");

private final String name;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -302,4 +302,20 @@ public void withPreferReplicaTest() {

assertEquals(true, ((HashMap<?, ?>) crudSelectOpts.get(0)).get(ProxyOption.PREFER_REPLICA.toString()));
}

@Test
public void withBalanceTest() {
TarantoolSpaceOperations<TarantoolTuple, TarantoolResult<TarantoolTuple>> operations =
client.space(TEST_SPACE_NAME);

SelectOptions<ProxySelectOptions> options = ProxySelectOptions.create().balance();

assertTrue(options.getBalance().isPresent());
assertTrue(options.getBalance().get());

operations.select(Conditions.any(), options).join();
List<?> crudSelectOpts = client.eval("return crud_select_opts").join();

assertEquals(true, ((HashMap<?, ?>) crudSelectOpts.get(0)).get(ProxyOption.BALANCE.toString()));
}
}

0 comments on commit 5f1fab1

Please sign in to comment.