diff --git a/CHANGELOG.md b/CHANGELOG.md index 330fcec26..badb249e5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ ### Internal and API changes +- **[breaking change]** replace `List` type with `Collection` for the `arguments` client API method parameters - Bump testcontainers-java-tarantool to 1.0.1 ([#400](https://github.com/tarantool/cartridge-java/issues/400)) - Add `"mode"` option for select operation ([#107](https://github.com/tarantool/cartridge-java/issues/107)) - Change using of proxy client parameters (`mode`, `rollback_on_error`, `stop_on_error`) with enum classes ([#419](https://github.com/tarantool/cartridge-java/issues/419)) diff --git a/src/main/java/io/tarantool/driver/api/TarantoolCallOperations.java b/src/main/java/io/tarantool/driver/api/TarantoolCallOperations.java index feb7b7f26..eb6ff7ae3 100644 --- a/src/main/java/io/tarantool/driver/api/TarantoolCallOperations.java +++ b/src/main/java/io/tarantool/driver/api/TarantoolCallOperations.java @@ -8,6 +8,7 @@ import io.tarantool.driver.mappers.factories.ResultMapperFactoryFactory; import org.msgpack.value.Value; +import java.util.Collection; import java.util.List; import java.util.concurrent.CompletableFuture; import java.util.function.Supplier; @@ -51,7 +52,7 @@ public interface TarantoolCallOperations { * @return some result * @throws TarantoolClientException if the client is not connected or some other error occurred */ - CompletableFuture> call(String functionName, List arguments) throws TarantoolClientException; + CompletableFuture> call(String functionName, Collection arguments) throws TarantoolClientException; /** * Execute a function defined on Tarantool instance @@ -62,7 +63,7 @@ public interface TarantoolCallOperations { * @return some result * @throws TarantoolClientException if the client is not connected */ - CompletableFuture> call(String functionName, List arguments, MessagePackMapper mapper) + CompletableFuture> call(String functionName, Collection arguments, MessagePackMapper mapper) throws TarantoolClientException; /** @@ -108,7 +109,7 @@ CompletableFuture call( */ CompletableFuture> callForTupleResult( String functionName, - List arguments, + Collection arguments, Class entityClass) throws TarantoolClientException; @@ -125,7 +126,7 @@ CompletableFuture> callForTupleResult( */ CompletableFuture call( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException; @@ -144,7 +145,7 @@ CompletableFuture call( */ CompletableFuture> callForTupleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Class entityClass) throws TarantoolClientException; @@ -162,7 +163,7 @@ CompletableFuture> callForTupleResult( */ CompletableFuture call( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException; @@ -181,7 +182,7 @@ CompletableFuture call( */ CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Class resultClass) throws TarantoolClientException; @@ -200,7 +201,7 @@ CompletableFuture callForSingleResult( */ CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, ValueConverter valueConverter) throws TarantoolClientException; @@ -219,7 +220,7 @@ CompletableFuture callForSingleResult( */ CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException; @@ -237,7 +238,7 @@ CompletableFuture callForSingleResult( */ CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, Class resultClass) throws TarantoolClientException; @@ -254,7 +255,7 @@ CompletableFuture callForSingleResult( */ CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, ValueConverter valueConverter) throws TarantoolClientException; @@ -271,7 +272,7 @@ CompletableFuture callForSingleResult( */ CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException; @@ -335,7 +336,7 @@ CompletableFuture callForSingleResult( */ > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Supplier resultContainerSupplier, Class resultClass) @@ -356,7 +357,7 @@ > CompletableFuture callForMultiResult( */ > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Supplier resultContainerSupplier, ValueConverter valueConverter) @@ -376,7 +377,7 @@ > CompletableFuture callForMultiResult( */ > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException; @@ -395,7 +396,7 @@ > CompletableFuture callForMultiResult( */ > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, Supplier resultContainerSupplier, Class resultClass) throws TarantoolClientException; @@ -414,7 +415,7 @@ > CompletableFuture callForMultiResult( */ > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, Supplier resultContainerSupplier, ValueConverter valueConverter) throws TarantoolClientException; @@ -432,7 +433,7 @@ > CompletableFuture callForMultiResult( */ > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException; diff --git a/src/main/java/io/tarantool/driver/api/TarantoolEvalOperations.java b/src/main/java/io/tarantool/driver/api/TarantoolEvalOperations.java index a69a144bf..68173bb05 100644 --- a/src/main/java/io/tarantool/driver/api/TarantoolEvalOperations.java +++ b/src/main/java/io/tarantool/driver/api/TarantoolEvalOperations.java @@ -4,6 +4,7 @@ import io.tarantool.driver.mappers.MessagePackObjectMapper; import io.tarantool.driver.mappers.MessagePackValueMapper; +import java.util.Collection; import java.util.List; import java.util.concurrent.CompletableFuture; @@ -35,7 +36,7 @@ public interface TarantoolEvalOperations { * @return some result * @throws TarantoolClientException if the client is not connected */ - CompletableFuture> eval(String expression, List arguments) throws TarantoolClientException; + CompletableFuture> eval(String expression, Collection arguments) throws TarantoolClientException; /** * Execute a Lua expression in the Tarantool instance. If a result is expected, the expression must start with @@ -60,7 +61,7 @@ CompletableFuture> eval(String expression, MessagePackValueMapper result * @return some result * @throws TarantoolClientException if the client is not connected */ - CompletableFuture> eval(String expression, List arguments, MessagePackValueMapper resultMapper) + CompletableFuture> eval(String expression, Collection arguments, MessagePackValueMapper resultMapper) throws TarantoolClientException; /** @@ -76,7 +77,7 @@ CompletableFuture> eval(String expression, List arguments, MessagePac */ CompletableFuture> eval( String expression, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, MessagePackValueMapper resultMapper) throws TarantoolClientException; } diff --git a/src/main/java/io/tarantool/driver/core/AbstractTarantoolClient.java b/src/main/java/io/tarantool/driver/core/AbstractTarantoolClient.java index e7eb176d3..25b4440ba 100644 --- a/src/main/java/io/tarantool/driver/core/AbstractTarantoolClient.java +++ b/src/main/java/io/tarantool/driver/core/AbstractTarantoolClient.java @@ -234,13 +234,13 @@ public CompletableFuture> call(String functionName, Object... arguments) } @Override - public CompletableFuture> call(String functionName, List arguments) + public CompletableFuture> call(String functionName, Collection arguments) throws TarantoolClientException { return call(functionName, arguments, config.getMessagePackMapper()); } @Override - public CompletableFuture> call(String functionName, List arguments, MessagePackMapper mapper) + public CompletableFuture> call(String functionName, Collection arguments, MessagePackMapper mapper) throws TarantoolClientException { return makeRequest(functionName, arguments, mapper, mapper); } @@ -261,7 +261,7 @@ public CompletableFuture call( @Override public CompletableFuture> callForTupleResult( - String functionName, List arguments, Class tupleClass) + String functionName, Collection arguments, Class tupleClass) throws TarantoolClientException { return callForTupleResult(functionName, arguments, config.getMessagePackMapper(), tupleClass); } @@ -269,7 +269,7 @@ public CompletableFuture> callForTupleResult( @Override public CompletableFuture call( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return call(functionName, arguments, config.getMessagePackMapper(), resultMapper); @@ -278,7 +278,7 @@ public CompletableFuture call( @Override public CompletableFuture> callForTupleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Class tupleClass) throws TarantoolClientException { @@ -289,7 +289,7 @@ public CompletableFuture> callForTupleResult( @Override public CompletableFuture call( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { @@ -299,7 +299,7 @@ public CompletableFuture call( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, Class resultClass) throws TarantoolClientException { return callForSingleResult(functionName, arguments, config.getMessagePackMapper(), resultClass); @@ -308,7 +308,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, ValueConverter valueConverter) throws TarantoolClientException { return callForSingleResult(functionName, arguments, config.getMessagePackMapper(), valueConverter); @@ -317,7 +317,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return callForSingleResult(functionName, arguments, config.getMessagePackMapper(), resultMapper); } @@ -344,7 +344,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Class resultClass) throws TarantoolClientException { @@ -355,7 +355,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, ValueConverter valueConverter) throws TarantoolClientException { @@ -366,7 +366,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { @@ -377,7 +377,7 @@ public CompletableFuture callForSingleResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, Supplier resultContainerSupplier, Class resultClass) throws TarantoolClientException { @@ -388,7 +388,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, Supplier resultContainerSupplier, ValueConverter valueConverter) throws TarantoolClientException { return callForMultiResult(functionName, arguments, config.getMessagePackMapper(), @@ -398,7 +398,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return callForMultiResult(functionName, arguments, config.getMessagePackMapper(), resultMapper); } @@ -432,7 +432,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Supplier resultContainerSupplier, Class resultClass) @@ -444,7 +444,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Supplier resultContainerSupplier, ValueConverter valueConverter) @@ -456,7 +456,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { @@ -466,7 +466,7 @@ public > CompletableFuture callForMultiResult( private CompletableFuture> makeRequestForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { return makeRequest(functionName, arguments, argumentsMapper, resultMapper); @@ -474,7 +474,7 @@ private CompletableFuture> makeRequestForSingleResult( private > CompletableFuture> makeRequestForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { return makeRequest(functionName, arguments, argumentsMapper, resultMapper); @@ -482,7 +482,7 @@ private > CompletableFuture> makeRequestForMu private CompletableFuture makeRequest( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, MessagePackValueMapper resultMapper) throws TarantoolClientException { @@ -507,7 +507,7 @@ public CompletableFuture> eval(String expression) throws TarantoolClient } @Override - public CompletableFuture> eval(String expression, List arguments) + public CompletableFuture> eval(String expression, Collection arguments) throws TarantoolClientException { return eval(expression, arguments, config.getMessagePackMapper()); } @@ -519,7 +519,8 @@ public CompletableFuture> eval(String expression, MessagePackValueMapper } @Override - public CompletableFuture> eval(String expression, List arguments, MessagePackValueMapper resultMapper) + public CompletableFuture> eval( + String expression, Collection arguments, MessagePackValueMapper resultMapper) throws TarantoolClientException { return eval(expression, arguments, config.getMessagePackMapper(), resultMapper); } @@ -527,7 +528,7 @@ public CompletableFuture> eval(String expression, List arguments, Mes @Override public CompletableFuture> eval( String expression, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, MessagePackValueMapper resultMapper) throws TarantoolClientException { try { diff --git a/src/main/java/io/tarantool/driver/core/ProxyTarantoolClient.java b/src/main/java/io/tarantool/driver/core/ProxyTarantoolClient.java index 280b2171f..e16269f4d 100644 --- a/src/main/java/io/tarantool/driver/core/ProxyTarantoolClient.java +++ b/src/main/java/io/tarantool/driver/core/ProxyTarantoolClient.java @@ -177,13 +177,13 @@ public CompletableFuture> call(String functionName, Object... arguments) } @Override - public CompletableFuture> call(String functionName, List arguments) + public CompletableFuture> call(String functionName, Collection arguments) throws TarantoolClientException { return client.call(functionName, arguments); } @Override - public CompletableFuture> call(String functionName, List arguments, MessagePackMapper mapper) + public CompletableFuture> call(String functionName, Collection arguments, MessagePackMapper mapper) throws TarantoolClientException { return client.call(functionName, arguments, mapper); } @@ -201,25 +201,25 @@ public CompletableFuture call(String functionName, } @Override - public CompletableFuture> callForTupleResult(String functionName, List arguments, + public CompletableFuture> callForTupleResult(String functionName, Collection arguments, Class entityClass) throws TarantoolClientException { return client.callForTupleResult(functionName, arguments, entityClass); } @Override - public CompletableFuture call(String functionName, List arguments, + public CompletableFuture call(String functionName, Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return client.call(functionName, arguments, resultMapper); } @Override - public CompletableFuture> callForTupleResult(String functionName, List arguments, + public CompletableFuture> callForTupleResult(String functionName, Collection arguments, MessagePackObjectMapper argumentsMapper, Class entityClass) throws TarantoolClientException { return client.callForTupleResult(functionName, arguments, argumentsMapper, entityClass); } @Override - public CompletableFuture call(String functionName, List arguments, + public CompletableFuture call(String functionName, Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { return client.call(functionName, arguments, argumentsMapper, resultMapper); @@ -228,7 +228,7 @@ public CompletableFuture call(String functionName, List arguments, @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Class resultClass) throws TarantoolClientException { @@ -238,7 +238,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, ValueConverter valueConverter) throws TarantoolClientException { @@ -248,7 +248,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { @@ -256,7 +256,8 @@ public CompletableFuture callForSingleResult( } @Override - public CompletableFuture callForSingleResult(String functionName, List arguments, Class resultClass) + public CompletableFuture callForSingleResult( + String functionName, Collection arguments, Class resultClass) throws TarantoolClientException { return client.callForSingleResult(functionName, arguments, resultClass); } @@ -264,7 +265,7 @@ public CompletableFuture callForSingleResult(String functionName, List @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, ValueConverter valueConverter) throws TarantoolClientException { return client.callForSingleResult(functionName, arguments, valueConverter); @@ -273,7 +274,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return client.callForSingleResult(functionName, arguments, resultMapper); } @@ -300,7 +301,7 @@ public CompletableFuture callForSingleResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Supplier resultContainerSupplier, Class resultClass) throws TarantoolClientException { @@ -311,7 +312,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Supplier resultContainerSupplier, ValueConverter valueConverter) throws TarantoolClientException { @@ -322,7 +323,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { return client.callForMultiResult(functionName, arguments, argumentsMapper, resultMapper); @@ -331,7 +332,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, Supplier resultContainerSupplier, Class resultClass) throws TarantoolClientException { @@ -341,7 +342,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, Supplier resultContainerSupplier, ValueConverter valueConverter) throws TarantoolClientException { @@ -351,7 +352,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return client.callForMultiResult(functionName, arguments, resultMapper); } @@ -388,7 +389,7 @@ public CompletableFuture> eval(String expression) throws TarantoolClient } @Override - public CompletableFuture> eval(String expression, List arguments) throws TarantoolClientException { + public CompletableFuture> eval(String expression, Collection arguments) throws TarantoolClientException { return client.eval(expression, arguments); } @@ -399,7 +400,8 @@ public CompletableFuture> eval(String expression, MessagePackValueMapper } @Override - public CompletableFuture> eval(String expression, List arguments, MessagePackValueMapper resultMapper) + public CompletableFuture> eval( + String expression, Collection arguments, MessagePackValueMapper resultMapper) throws TarantoolClientException { return client.eval(expression, arguments, resultMapper); } @@ -407,7 +409,7 @@ public CompletableFuture> eval(String expression, List arguments, Mes @Override public CompletableFuture> eval( String expression, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, MessagePackValueMapper resultMapper) throws TarantoolClientException { return client.eval(expression, arguments, argumentsMapper, resultMapper); diff --git a/src/main/java/io/tarantool/driver/core/RetryingTarantoolClient.java b/src/main/java/io/tarantool/driver/core/RetryingTarantoolClient.java index bc148137e..e086a2d22 100644 --- a/src/main/java/io/tarantool/driver/core/RetryingTarantoolClient.java +++ b/src/main/java/io/tarantool/driver/core/RetryingTarantoolClient.java @@ -141,14 +141,15 @@ public CompletableFuture> call(String functionName, Object... arguments) } @Override - public CompletableFuture> call(String functionName, List arguments) throws TarantoolClientException { + public CompletableFuture> call(String functionName, Collection arguments) + throws TarantoolClientException { return wrapOperation(() -> client.call(functionName, arguments)); } @Override public CompletableFuture> call( String functionName, - List arguments, + Collection arguments, MessagePackMapper mapper) throws TarantoolClientException { return wrapOperation(() -> client.call(functionName, arguments, mapper)); } @@ -166,25 +167,25 @@ public CompletableFuture call(String functionName, } @Override - public CompletableFuture> callForTupleResult(String functionName, List arguments, + public CompletableFuture> callForTupleResult(String functionName, Collection arguments, Class entityClass) throws TarantoolClientException { return wrapOperation(() -> client.callForTupleResult(functionName, arguments, entityClass)); } @Override - public CompletableFuture call(String functionName, List arguments, + public CompletableFuture call(String functionName, Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return wrapOperation(() -> client.call(functionName, arguments, resultMapper)); } @Override - public CompletableFuture> callForTupleResult(String functionName, List arguments, + public CompletableFuture> callForTupleResult(String functionName, Collection arguments, MessagePackObjectMapper argumentsMapper, Class entityClass) throws TarantoolClientException { return wrapOperation(() -> client.callForTupleResult(functionName, arguments, argumentsMapper, entityClass)); } @Override - public CompletableFuture call(String functionName, List arguments, + public CompletableFuture call(String functionName, Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { return wrapOperation(() -> client.call(functionName, arguments, argumentsMapper, resultMapper)); @@ -193,7 +194,7 @@ public CompletableFuture call(String functionName, List arguments, @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Class resultClass) throws TarantoolClientException { return wrapOperation(() -> client.callForSingleResult(functionName, arguments, argumentsMapper, resultClass)); @@ -202,7 +203,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, ValueConverter valueConverter) throws TarantoolClientException { @@ -213,7 +214,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { @@ -221,7 +222,8 @@ public CompletableFuture callForSingleResult( } @Override - public CompletableFuture callForSingleResult(String functionName, List arguments, Class resultClass) + public CompletableFuture callForSingleResult( + String functionName, Collection arguments, Class resultClass) throws TarantoolClientException { return wrapOperation(() -> client.callForSingleResult(functionName, arguments, resultClass)); } @@ -229,7 +231,7 @@ public CompletableFuture callForSingleResult(String functionName, List @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, ValueConverter valueConverter) throws TarantoolClientException { return wrapOperation(() -> client.callForSingleResult(functionName, arguments, valueConverter)); @@ -238,7 +240,7 @@ public CompletableFuture callForSingleResult( @Override public CompletableFuture callForSingleResult( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return wrapOperation(() -> client.callForSingleResult(functionName, arguments, resultMapper)); @@ -267,7 +269,7 @@ public CompletableFuture callForSingleResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Supplier resultContainerSupplier, Class resultClass) @@ -279,7 +281,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, Supplier resultContainerSupplier, ValueConverter valueConverter) @@ -291,7 +293,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) throws TarantoolClientException { @@ -301,7 +303,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, Supplier resultContainerSupplier, Class resultClass) throws TarantoolClientException { @@ -312,7 +314,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, Supplier resultContainerSupplier, ValueConverter valueConverter) throws TarantoolClientException { @@ -323,7 +325,7 @@ public > CompletableFuture callForMultiResult( @Override public > CompletableFuture callForMultiResult( String functionName, - List arguments, + Collection arguments, CallResultMapper> resultMapper) throws TarantoolClientException { return wrapOperation(() -> client.callForMultiResult(functionName, arguments, resultMapper)); } @@ -364,7 +366,7 @@ public CompletableFuture> eval(String expression) throws TarantoolClient } @Override - public CompletableFuture> eval(String expression, List arguments) throws TarantoolClientException { + public CompletableFuture> eval(String expression, Collection arguments) throws TarantoolClientException { return wrapOperation(() -> client.eval(expression, arguments)); } @@ -378,14 +380,14 @@ public CompletableFuture> eval( @Override public CompletableFuture> eval( String expression, - List arguments, + Collection arguments, MessagePackValueMapper resultMapper) throws TarantoolClientException { return wrapOperation(() -> client.eval(expression, arguments, resultMapper)); } @Override public CompletableFuture> eval( - String expression, List arguments, + String expression, Collection arguments, MessagePackObjectMapper argumentsMapper, MessagePackValueMapper resultMapper) throws TarantoolClientException { return wrapOperation(() -> client.eval(expression, arguments, argumentsMapper, resultMapper)); diff --git a/src/main/java/io/tarantool/driver/core/proxy/AbstractProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/AbstractProxyOperation.java index 475f16c1d..4c0dc5604 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/AbstractProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/AbstractProxyOperation.java @@ -8,8 +8,8 @@ import io.tarantool.driver.mappers.CallResultMapper; import io.tarantool.driver.mappers.MessagePackObjectMapper; +import java.util.Collection; import java.util.EnumMap; -import java.util.List; import java.util.concurrent.CompletableFuture; /** @@ -23,14 +23,14 @@ abstract class AbstractProxyOperation implements ProxyOperation { protected final TarantoolCallOperations client; protected final String functionName; - protected final List arguments; + protected final Collection arguments; protected final CallResultMapper> resultMapper; private final MessagePackObjectMapper argumentsMapper; AbstractProxyOperation( TarantoolCallOperations client, String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { this.client = client; @@ -48,7 +48,7 @@ public String getFunctionName() { return functionName; } - public List getArguments() { + public Collection getArguments() { return arguments; } diff --git a/src/main/java/io/tarantool/driver/core/proxy/DeleteProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/DeleteProxyOperation.java index 29a479d4e..905b3fa57 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/DeleteProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/DeleteProxyOperation.java @@ -6,8 +6,7 @@ import io.tarantool.driver.mappers.CallResultMapper; import io.tarantool.driver.mappers.MessagePackObjectMapper; -import java.util.ArrayList; -import java.util.List; +import java.util.Collection; /** * Proxy operation for delete @@ -21,7 +20,7 @@ public final class DeleteProxyOperation extends AbstractProxyOperation { private DeleteProxyOperation( TarantoolCallOperations client, String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { super(client, functionName, arguments, argumentsMapper, resultMapper); @@ -45,8 +44,7 @@ public Builder self() { public DeleteProxyOperation build() { return new DeleteProxyOperation<>( - this.client, this.functionName, new ArrayList<>(arguments.values()), this.argumentsMapper, - this.resultMapper); + this.client, this.functionName, this.arguments.values(), this.argumentsMapper, this.resultMapper); } } } diff --git a/src/main/java/io/tarantool/driver/core/proxy/InsertManyProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/InsertManyProxyOperation.java index d8de0407f..a3d925c0d 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/InsertManyProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/InsertManyProxyOperation.java @@ -7,9 +7,7 @@ import io.tarantool.driver.mappers.MessagePackObjectMapper; import io.tarantool.driver.protocol.Packable; -import java.util.ArrayList; import java.util.Collection; -import java.util.List; /** * Proxy operation for inserting many records at once @@ -24,7 +22,7 @@ public final class InsertManyProxyOperation arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { super(client, functionName, arguments, argumentsMapper, resultMapper); @@ -47,8 +45,7 @@ public Builder self() { public InsertManyProxyOperation build() { return new InsertManyProxyOperation<>( - this.client, this.functionName, new ArrayList<>(arguments.values()), this.argumentsMapper, - this.resultMapper); + this.client, this.functionName, this.arguments.values(), this.argumentsMapper, this.resultMapper); } } } diff --git a/src/main/java/io/tarantool/driver/core/proxy/InsertProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/InsertProxyOperation.java index 0aa994b49..b0ad065df 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/InsertProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/InsertProxyOperation.java @@ -7,9 +7,7 @@ import io.tarantool.driver.mappers.MessagePackObjectMapper; import io.tarantool.driver.protocol.Packable; -import java.util.ArrayList; import java.util.Collection; -import java.util.List; /** * Proxy operation for insert @@ -24,7 +22,7 @@ public final class InsertProxyOperation arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { super(client, functionName, arguments, argumentsMapper, resultMapper); @@ -48,8 +46,7 @@ public Builder self() { public InsertProxyOperation build() { return new InsertProxyOperation<>( - this.client, this.functionName, new ArrayList<>(arguments.values()), this.argumentsMapper, - this.resultMapper); + this.client, this.functionName, this.arguments.values(), this.argumentsMapper, this.resultMapper); } } } diff --git a/src/main/java/io/tarantool/driver/core/proxy/ReplaceManyProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/ReplaceManyProxyOperation.java index 314f2847f..1dd4eaae0 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/ReplaceManyProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/ReplaceManyProxyOperation.java @@ -7,9 +7,7 @@ import io.tarantool.driver.mappers.MessagePackObjectMapper; import io.tarantool.driver.protocol.Packable; -import java.util.ArrayList; import java.util.Collection; -import java.util.List; /** * Proxy operation for replacing many records at once @@ -24,7 +22,7 @@ public final class ReplaceManyProxyOperation arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { super(client, functionName, arguments, argumentsMapper, resultMapper); @@ -48,8 +46,7 @@ public Builder self() { public ReplaceManyProxyOperation build() { return new ReplaceManyProxyOperation<>( - this.client, this.functionName, new ArrayList<>(arguments.values()), this.argumentsMapper, - this.resultMapper); + this.client, this.functionName, this.arguments.values(), this.argumentsMapper, this.resultMapper); } } } diff --git a/src/main/java/io/tarantool/driver/core/proxy/ReplaceProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/ReplaceProxyOperation.java index 56155c024..ccf09ffaa 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/ReplaceProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/ReplaceProxyOperation.java @@ -7,9 +7,7 @@ import io.tarantool.driver.mappers.MessagePackObjectMapper; import io.tarantool.driver.protocol.Packable; -import java.util.ArrayList; import java.util.Collection; -import java.util.List; /** * Proxy operation for replace @@ -25,7 +23,7 @@ public final class ReplaceProxyOperation arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { super(client, functionName, arguments, argumentsMapper, resultMapper); @@ -49,8 +47,7 @@ public Builder self() { public ReplaceProxyOperation build() { return new ReplaceProxyOperation<>( - this.client, this.functionName, new ArrayList<>(arguments.values()), this.argumentsMapper, - this.resultMapper); + this.client, this.functionName, this.arguments.values(), this.argumentsMapper, this.resultMapper); } } } diff --git a/src/main/java/io/tarantool/driver/core/proxy/SelectProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/SelectProxyOperation.java index d6f42c880..3a39358b9 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/SelectProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/SelectProxyOperation.java @@ -11,8 +11,7 @@ import io.tarantool.driver.mappers.CallResultMapper; import io.tarantool.driver.mappers.MessagePackObjectMapper; -import java.util.ArrayList; -import java.util.List; +import java.util.Collection; import java.util.Map; import java.util.Optional; @@ -28,7 +27,7 @@ public final class SelectProxyOperation extends AbstractProxyOperation { private SelectProxyOperation( TarantoolCallOperations client, String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { super(client, functionName, arguments, argumentsMapper, resultMapper); @@ -71,8 +70,7 @@ public SelectProxyOperation build() { .ifPresent(after -> options.put(ProxyOption.AFTER.toString(), after)); return new SelectProxyOperation<>( - this.client, this.functionName, new ArrayList<>(arguments.values()), this.argumentsMapper, - this.resultMapper); + this.client, this.functionName, this.arguments.values(), this.argumentsMapper, this.resultMapper); } } } diff --git a/src/main/java/io/tarantool/driver/core/proxy/TruncateProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/TruncateProxyOperation.java index 123736433..6dac3a6df 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/TruncateProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/TruncateProxyOperation.java @@ -4,8 +4,7 @@ import io.tarantool.driver.api.TarantoolVoidResult; import io.tarantool.driver.api.space.options.crud.OperationWithTimeoutOptions; -import java.util.ArrayList; -import java.util.List; +import java.util.Collection; import java.util.concurrent.CompletableFuture; /** @@ -18,12 +17,12 @@ public final class TruncateProxyOperation implements ProxyOperation { private final TarantoolCallOperations client; private final String functionName; - private final List arguments; + private final Collection arguments; private TruncateProxyOperation( TarantoolCallOperations client, String functionName, - List arguments) { + Collection arguments) { this.client = client; this.arguments = arguments; this.functionName = functionName; @@ -46,7 +45,7 @@ public String getFunctionName() { return functionName; } - public List getArguments() { + public Collection getArguments() { return arguments; } @@ -74,7 +73,7 @@ public Builder self() { */ public TruncateProxyOperation build() { - return new TruncateProxyOperation(this.client, this.functionName, new ArrayList<>(arguments.values())); + return new TruncateProxyOperation(this.client, this.functionName, this.arguments.values()); } } } diff --git a/src/main/java/io/tarantool/driver/core/proxy/UpdateProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/UpdateProxyOperation.java index 63fd7ef30..869499cc8 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/UpdateProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/UpdateProxyOperation.java @@ -6,8 +6,7 @@ import io.tarantool.driver.mappers.CallResultMapper; import io.tarantool.driver.mappers.MessagePackObjectMapper; -import java.util.ArrayList; -import java.util.List; +import java.util.Collection; /** * Proxy operation for update @@ -21,7 +20,7 @@ public final class UpdateProxyOperation extends AbstractProxyOperation { UpdateProxyOperation( TarantoolCallOperations client, String functionName, - List arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { super(client, functionName, arguments, argumentsMapper, resultMapper); @@ -45,8 +44,7 @@ public Builder self() { public UpdateProxyOperation build() { return new UpdateProxyOperation<>( - this.client, this.functionName, new ArrayList<>(arguments.values()), this.argumentsMapper, - this.resultMapper); + this.client, this.functionName, this.arguments.values(), this.argumentsMapper, this.resultMapper); } } } diff --git a/src/main/java/io/tarantool/driver/core/proxy/UpsertProxyOperation.java b/src/main/java/io/tarantool/driver/core/proxy/UpsertProxyOperation.java index ab40936ce..fcc2046e0 100644 --- a/src/main/java/io/tarantool/driver/core/proxy/UpsertProxyOperation.java +++ b/src/main/java/io/tarantool/driver/core/proxy/UpsertProxyOperation.java @@ -7,9 +7,7 @@ import io.tarantool.driver.mappers.MessagePackObjectMapper; import io.tarantool.driver.protocol.Packable; -import java.util.ArrayList; import java.util.Collection; -import java.util.List; /** * Proxy operation for upsert @@ -24,7 +22,7 @@ public final class UpsertProxyOperation arguments, + Collection arguments, MessagePackObjectMapper argumentsMapper, CallResultMapper> resultMapper) { super(client, functionName, arguments, argumentsMapper, resultMapper); @@ -48,8 +46,7 @@ public Builder self() { public UpsertProxyOperation build() { return new UpsertProxyOperation<>( - this.client, this.functionName, new ArrayList<>(arguments.values()), this.argumentsMapper, - this.resultMapper); + this.client, this.functionName, this.arguments.values(), this.argumentsMapper, this.resultMapper); } } } diff --git a/src/main/java/io/tarantool/driver/protocol/requests/TarantoolCallRequest.java b/src/main/java/io/tarantool/driver/protocol/requests/TarantoolCallRequest.java index 5dcae48cb..a566e73f4 100644 --- a/src/main/java/io/tarantool/driver/protocol/requests/TarantoolCallRequest.java +++ b/src/main/java/io/tarantool/driver/protocol/requests/TarantoolCallRequest.java @@ -7,8 +7,8 @@ import io.tarantool.driver.protocol.TarantoolRequestFieldType; import io.tarantool.driver.protocol.TarantoolRequestType; +import java.util.Collection; import java.util.HashMap; -import java.util.List; import java.util.Map; /** @@ -52,7 +52,7 @@ public Builder withFunctionName(String functionName) { * @param arguments function arguments * @return builder */ - public Builder withArguments(List arguments) { + public Builder withArguments(Collection arguments) { this.bodyMap.put(TarantoolRequestFieldType.IPROTO_TUPLE.getCode(), arguments); return this; } diff --git a/src/main/java/io/tarantool/driver/protocol/requests/TarantoolEvalRequest.java b/src/main/java/io/tarantool/driver/protocol/requests/TarantoolEvalRequest.java index 2883c4f93..d3e1ec95b 100644 --- a/src/main/java/io/tarantool/driver/protocol/requests/TarantoolEvalRequest.java +++ b/src/main/java/io/tarantool/driver/protocol/requests/TarantoolEvalRequest.java @@ -7,8 +7,8 @@ import io.tarantool.driver.protocol.TarantoolRequestFieldType; import io.tarantool.driver.protocol.TarantoolRequestType; +import java.util.Collection; import java.util.HashMap; -import java.util.List; import java.util.Map; /** @@ -52,7 +52,7 @@ public Builder withExpression(String expression) { * @param arguments eval arguments * @return builder */ - public Builder withArguments(List arguments) { + public Builder withArguments(Collection arguments) { this.bodyMap.put(TarantoolRequestFieldType.IPROTO_TUPLE.getCode(), arguments); return this; } diff --git a/src/test/java/io/tarantool/driver/core/proxy/ProxyOperationBuildersTest.java b/src/test/java/io/tarantool/driver/core/proxy/ProxyOperationBuildersTest.java index df4754a06..99f5ae789 100644 --- a/src/test/java/io/tarantool/driver/core/proxy/ProxyOperationBuildersTest.java +++ b/src/test/java/io/tarantool/driver/core/proxy/ProxyOperationBuildersTest.java @@ -32,12 +32,14 @@ import org.junit.jupiter.api.Test; import java.util.Arrays; +import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertIterableEquals; public class ProxyOperationBuildersTest { @@ -76,7 +78,7 @@ public void deleteOperationBuilderTest() { assertEquals(client, deleteProxyOperation.getClient()); assertEquals("function1", deleteProxyOperation.getFunctionName()); - assertEquals(Arrays.asList("space1", Collections.singletonList(42L), options), + assertIterableEquals(Arrays.asList("space1", Collections.singletonList(42L), options), deleteProxyOperation.getArguments()); assertEquals(defaultResultMapper, deleteProxyOperation.getResultMapper()); } @@ -104,7 +106,7 @@ public void insertOperationBuilderTest() { assertEquals(client, insertOperation.getClient()); assertEquals("function1", insertOperation.getFunctionName()); - assertEquals(Arrays.asList("space1", tarantoolTuple, options), insertOperation.getArguments()); + assertIterableEquals(Arrays.asList("space1", tarantoolTuple, options), insertOperation.getArguments()); assertEquals(defaultResultMapper, insertOperation.getResultMapper()); } @@ -136,7 +138,7 @@ public void insertManyOperationBuilderTest() { assertEquals(client, operation.getClient()); assertEquals("function1", operation.getFunctionName()); - assertEquals(Arrays.asList("space1", tarantoolTuples, options), operation.getArguments()); + assertIterableEquals(Arrays.asList("space1", tarantoolTuples, options), operation.getArguments()); assertEquals(defaultResultMapper, operation.getResultMapper()); } @@ -163,7 +165,7 @@ public void replaceOperationBuilderTest() { assertEquals(client, operation.getClient()); assertEquals("function1", operation.getFunctionName()); - assertEquals(Arrays.asList("space1", tarantoolTuple, options), operation.getArguments()); + assertIterableEquals(Arrays.asList("space1", tarantoolTuple, options), operation.getArguments()); assertEquals(defaultResultMapper, operation.getResultMapper()); } @@ -196,7 +198,7 @@ public void replaceManyOperationBuilderTest() { assertEquals(client, operation.getClient()); assertEquals("function1", operation.getFunctionName()); - assertEquals(Arrays.asList("space1", tarantoolTuples, options), operation.getArguments()); + assertIterableEquals(Arrays.asList("space1", tarantoolTuples, options), operation.getArguments()); assertEquals(defaultResultMapper, operation.getResultMapper()); } @@ -236,9 +238,10 @@ public void selectOperationBuilderTest() { assertEquals(client, op.getClient()); assertEquals("function1", op.getFunctionName()); assertEquals(3, op.getArguments().size()); - assertEquals("space1", op.getArguments().get(0)); - assertEquals(selectArguments, op.getArguments().get(1)); - Map actualOptions = (Map) op.getArguments().get(2); + List argumentValues = new ArrayList<>(op.getArguments()); + assertEquals("space1", argumentValues.get(0)); + assertEquals(selectArguments, argumentValues.get(1)); + Map actualOptions = (Map) argumentValues.get(2); assertEquals(options.toString(), actualOptions.toString()); assertEquals(defaultResultMapper, op.getResultMapper()); } @@ -268,7 +271,7 @@ public void updateOperationBuilderTest() { assertEquals("function1", operation.getFunctionName()); assertEquals(4, operation.getArguments().size()); - assertEquals(Arrays.asList("space1", + assertIterableEquals(Arrays.asList("space1", Collections.singletonList(10), TupleOperations.add(3, 90).andAdd(4, 5).asProxyOperationList(), options), operation.getArguments()); @@ -303,7 +306,7 @@ public void upsertOperationBuilderTest() { assertEquals(client, operation.getClient()); assertEquals("function1", operation.getFunctionName()); - assertEquals(Arrays.asList("space1", tarantoolTuple, + assertIterableEquals(Arrays.asList("space1", tarantoolTuple, TupleOperations.add(3, 90).andAdd(4, 5).asProxyOperationList(), options), operation.getArguments()); assertEquals(defaultResultMapper, operation.getResultMapper()); @@ -329,6 +332,6 @@ public void test_truncateOperationBuilder_shouldReturnTruncateOperationObjectsWi // then data is prepared check that is equals that we submitted to the builder assertEquals(client, truncateOperation.getClient()); assertEquals("function1", truncateOperation.getFunctionName()); - assertEquals(Arrays.asList("space1", options), truncateOperation.getArguments()); + assertIterableEquals(Arrays.asList("space1", options), truncateOperation.getArguments()); } }