From 697da00e1842bb1f1595b9234a3148ad07418c06 Mon Sep 17 00:00:00 2001 From: Robsdedude Date: Wed, 7 Dec 2022 16:26:11 +0100 Subject: [PATCH 1/3] TestKit backend: except txMeta as Cypher types Depends on: * https://github.com/neo4j-drivers/testkit/pull/538 --- .../backend/messages/requests/NewDriver.java | 2 + .../requests/SessionBeginTransaction.java | 52 ++++------------ .../requests/SessionReadTransaction.java | 28 ++++++--- .../backend/messages/requests/SessionRun.java | 58 +++++------------ .../requests/SessionWriteTransaction.java | 29 ++++++--- .../messages/requests/WithTxConfig.java | 62 +++++++++++++++++++ 6 files changed, 131 insertions(+), 100 deletions(-) create mode 100644 testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/WithTxConfig.java diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/NewDriver.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/NewDriver.java index 62217f4f1c..30125127ca 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/NewDriver.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/NewDriver.java @@ -30,6 +30,7 @@ import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; import java.util.concurrent.TimeUnit; +import java.util.logging.Level; import java.util.stream.Collectors; import lombok.Getter; import lombok.RequiredArgsConstructor; @@ -45,6 +46,7 @@ import org.neo4j.driver.AuthToken; import org.neo4j.driver.AuthTokens; import org.neo4j.driver.Config; +import org.neo4j.driver.Logging; import org.neo4j.driver.internal.BoltServerAddress; import org.neo4j.driver.internal.DefaultDomainNameResolver; import org.neo4j.driver.internal.DomainNameResolver; diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionBeginTransaction.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionBeginTransaction.java index 7b8c1dcf34..24cde32b59 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionBeginTransaction.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionBeginTransaction.java @@ -20,13 +20,11 @@ import static reactor.adapter.JdkFlowAdapter.flowPublisherToFlux; -import java.time.Duration; +import com.fasterxml.jackson.databind.annotation.JsonDeserialize; import java.util.Map; -import java.util.Optional; import java.util.concurrent.CompletionStage; import lombok.Getter; import lombok.Setter; -import neo4j.org.testkit.backend.CustomDriverError; import neo4j.org.testkit.backend.TestkitState; import neo4j.org.testkit.backend.holder.AsyncTransactionHolder; import neo4j.org.testkit.backend.holder.ReactiveTransactionHolder; @@ -34,6 +32,7 @@ import neo4j.org.testkit.backend.holder.RxTransactionHolder; import neo4j.org.testkit.backend.holder.SessionHolder; import neo4j.org.testkit.backend.holder.TransactionHolder; +import neo4j.org.testkit.backend.messages.requests.deserializer.TestkitCypherParamDeserializer; import neo4j.org.testkit.backend.messages.responses.TestkitResponse; import neo4j.org.testkit.backend.messages.responses.Transaction; import org.neo4j.driver.Session; @@ -45,33 +44,15 @@ @Setter @Getter -public class SessionBeginTransaction implements TestkitRequest { +public class SessionBeginTransaction extends WithTxConfig { private SessionBeginTransactionBody data; - private void configureTimeout(TransactionConfig.Builder builder) { - if (data.getTimeoutPresent()) { - try { - if (data.getTimeout() != null) { - builder.withTimeout(Duration.ofMillis(data.getTimeout())); - } else { - builder.withDefaultTimeout(); - } - } catch (IllegalArgumentException e) { - throw new CustomDriverError(e); - } - } - } - @Override public TestkitResponse process(TestkitState testkitState) { SessionHolder sessionHolder = testkitState.getSessionHolder(data.getSessionId()); Session session = sessionHolder.getSession(); - TransactionConfig.Builder builder = TransactionConfig.builder(); - Optional.ofNullable(data.txMeta).ifPresent(builder::withMetadata); - configureTimeout(builder); - - org.neo4j.driver.Transaction transaction = session.beginTransaction(builder.build()); + org.neo4j.driver.Transaction transaction = session.beginTransaction(getTxConfig()); return transaction(testkitState.addTransactionHolder(new TransactionHolder(sessionHolder, transaction))); } @@ -80,11 +61,8 @@ public CompletionStage processAsync(TestkitState testkitState) return testkitState.getAsyncSessionHolder(data.getSessionId()).thenCompose(sessionHolder -> { AsyncSession session = sessionHolder.getSession(); TransactionConfig.Builder builder = TransactionConfig.builder(); - Optional.ofNullable(data.txMeta).ifPresent(builder::withMetadata); - - configureTimeout(builder); - return session.beginTransactionAsync(builder.build()) + return session.beginTransactionAsync(getTxConfig()) .thenApply(tx -> transaction( testkitState.addAsyncTransactionHolder(new AsyncTransactionHolder(sessionHolder, tx)))); }); @@ -96,11 +74,8 @@ public Mono processRx(TestkitState testkitState) { return testkitState.getRxSessionHolder(data.getSessionId()).flatMap(sessionHolder -> { RxSession session = sessionHolder.getSession(); TransactionConfig.Builder builder = TransactionConfig.builder(); - Optional.ofNullable(data.txMeta).ifPresent(builder::withMetadata); - configureTimeout(builder); - - return Mono.fromDirect(session.beginTransaction(builder.build())) + return Mono.fromDirect(session.beginTransaction(getTxConfig())) .map(tx -> transaction( testkitState.addRxTransactionHolder(new RxTransactionHolder(sessionHolder, tx)))); }); @@ -111,11 +86,8 @@ public Mono processReactive(TestkitState testkitState) { return testkitState.getReactiveSessionHolder(data.getSessionId()).flatMap(sessionHolder -> { ReactiveSession session = sessionHolder.getSession(); TransactionConfig.Builder builder = TransactionConfig.builder(); - Optional.ofNullable(data.txMeta).ifPresent(builder::withMetadata); - - configureTimeout(builder); - return Mono.fromDirect(flowPublisherToFlux(session.beginTransaction(builder.build()))) + return Mono.fromDirect(flowPublisherToFlux(session.beginTransaction(getTxConfig()))) .map(tx -> transaction(testkitState.addReactiveTransactionHolder( new ReactiveTransactionHolder(sessionHolder, tx)))); }); @@ -126,11 +98,8 @@ public Mono processReactiveStreams(TestkitState testkitState) { return testkitState.getReactiveSessionStreamsHolder(data.getSessionId()).flatMap(sessionHolder -> { var session = sessionHolder.getSession(); TransactionConfig.Builder builder = TransactionConfig.builder(); - Optional.ofNullable(data.txMeta).ifPresent(builder::withMetadata); - - configureTimeout(builder); - return Mono.fromDirect(session.beginTransaction(builder.build())) + return Mono.fromDirect(session.beginTransaction(getTxConfig())) .map(tx -> transaction(testkitState.addReactiveTransactionStreamsHolder( new ReactiveTransactionStreamsHolder(sessionHolder, tx)))); }); @@ -144,9 +113,12 @@ private Transaction transaction(String txId) { @Getter @Setter - public static class SessionBeginTransactionBody { + public static class SessionBeginTransactionBody implements WithTxConfig.ITxConfigBody { private String sessionId; + + @JsonDeserialize(using = TestkitCypherParamDeserializer.class) private Map txMeta; + private Integer timeout; private Boolean timeoutPresent = false; diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionReadTransaction.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionReadTransaction.java index 2d13c08e81..ff106c5662 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionReadTransaction.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionReadTransaction.java @@ -21,6 +21,8 @@ import static reactor.adapter.JdkFlowAdapter.flowPublisherToFlux; import static reactor.adapter.JdkFlowAdapter.publisherToFlowPublisher; +import com.fasterxml.jackson.databind.annotation.JsonDeserialize; +import java.util.Map; import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; import java.util.concurrent.ExecutionException; @@ -35,6 +37,7 @@ import neo4j.org.testkit.backend.holder.RxTransactionHolder; import neo4j.org.testkit.backend.holder.SessionHolder; import neo4j.org.testkit.backend.holder.TransactionHolder; +import neo4j.org.testkit.backend.messages.requests.deserializer.TestkitCypherParamDeserializer; import neo4j.org.testkit.backend.messages.responses.RetryableDone; import neo4j.org.testkit.backend.messages.responses.RetryableTry; import neo4j.org.testkit.backend.messages.responses.TestkitResponse; @@ -49,7 +52,7 @@ @Setter @Getter -public class SessionReadTransaction implements TestkitRequest { +public class SessionReadTransaction extends WithTxConfig { private SessionReadTransactionBody data; @Override @@ -57,7 +60,7 @@ public class SessionReadTransaction implements TestkitRequest { public TestkitResponse process(TestkitState testkitState) { SessionHolder sessionHolder = testkitState.getSessionHolder(data.getSessionId()); Session session = sessionHolder.getSession(); - session.readTransaction(handle(testkitState, sessionHolder)); + session.readTransaction(handle(testkitState, sessionHolder), getTxConfig()); return retryableDone(); } @@ -78,7 +81,7 @@ public CompletionStage processAsync(TestkitState testkitState) return txWorkFuture; }; - return session.readTransactionAsync(workWrapper); + return session.readTransactionAsync(workWrapper, getTxConfig()); }) .thenApply(nothing -> retryableDone()); } @@ -97,7 +100,7 @@ public Mono processRx(TestkitState testkitState) { return Mono.fromCompletionStage(tryResult); }; - return Mono.fromDirect(sessionHolder.getSession().readTransaction(workWrapper)); + return Mono.fromDirect(sessionHolder.getSession().readTransaction(workWrapper, getTxConfig())); }) .then(Mono.just(retryableDone())); } @@ -117,7 +120,7 @@ public Mono processReactive(TestkitState testkitState) { }; return Mono.fromDirect( - flowPublisherToFlux(sessionHolder.getSession().executeRead(workWrapper))); + flowPublisherToFlux(sessionHolder.getSession().executeRead(workWrapper, getTxConfig()))); }) .then(Mono.just(retryableDone())); } @@ -137,7 +140,7 @@ public Mono processReactiveStreams(TestkitState testkitState) { return Mono.fromCompletionStage(tryResult); }; - return Mono.fromDirect(sessionHolder.getSession().executeRead(workWrapper)); + return Mono.fromDirect(sessionHolder.getSession().executeRead(workWrapper, getTxConfig())); }) .then(Mono.just(retryableDone())); } @@ -177,7 +180,18 @@ private RetryableDone retryableDone() { @Setter @Getter - public static class SessionReadTransactionBody { + public static class SessionReadTransactionBody implements WithTxConfig.ITxConfigBody { private String sessionId; + + @JsonDeserialize(using = TestkitCypherParamDeserializer.class) + private Map txMeta; + + private Integer timeout; + private Boolean timeoutPresent = false; + + public void setTimeout(Integer timeout) { + this.timeout = timeout; + timeoutPresent = true; + } } } diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionRun.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionRun.java index 2e0eb237c4..3d4eb8385b 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionRun.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionRun.java @@ -21,14 +21,12 @@ import static reactor.adapter.JdkFlowAdapter.flowPublisherToFlux; import com.fasterxml.jackson.databind.annotation.JsonDeserialize; -import java.time.Duration; import java.util.List; import java.util.Map; import java.util.Optional; import java.util.concurrent.CompletionStage; import lombok.Getter; import lombok.Setter; -import neo4j.org.testkit.backend.CustomDriverError; import neo4j.org.testkit.backend.TestkitState; import neo4j.org.testkit.backend.holder.ReactiveResultHolder; import neo4j.org.testkit.backend.holder.ReactiveResultStreamsHolder; @@ -41,7 +39,6 @@ import neo4j.org.testkit.backend.messages.responses.TestkitResponse; import org.neo4j.driver.Query; import org.neo4j.driver.Session; -import org.neo4j.driver.TransactionConfig; import org.neo4j.driver.async.AsyncSession; import org.neo4j.driver.reactive.ReactiveSession; import org.neo4j.driver.reactive.RxResult; @@ -50,23 +47,9 @@ @Setter @Getter -public class SessionRun implements TestkitRequest { +public class SessionRun extends WithTxConfig { private SessionRunBody data; - private void configureTimeout(TransactionConfig.Builder builder) { - if (data.getTimeoutPresent()) { - try { - if (data.getTimeout() != null) { - builder.withTimeout(Duration.ofMillis(data.getTimeout())); - } else { - builder.withDefaultTimeout(); - } - } catch (IllegalArgumentException e) { - throw new CustomDriverError(e); - } - } - } - @Override public TestkitResponse process(TestkitState testkitState) { SessionHolder sessionHolder = testkitState.getSessionHolder(data.getSessionId()); @@ -74,10 +57,7 @@ public TestkitResponse process(TestkitState testkitState) { Query query = Optional.ofNullable(data.params) .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - TransactionConfig.Builder transactionConfig = TransactionConfig.builder(); - Optional.ofNullable(data.getTxMeta()).ifPresent(transactionConfig::withMetadata); - configureTimeout(transactionConfig); - org.neo4j.driver.Result result = session.run(query, transactionConfig.build()); + org.neo4j.driver.Result result = session.run(query, getTxConfig()); String id = testkitState.addResultHolder(new ResultHolder(sessionHolder, result)); return createResponse(id, result.keys()); @@ -90,11 +70,8 @@ public CompletionStage processAsync(TestkitState testkitState) Query query = Optional.ofNullable(data.params) .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - TransactionConfig.Builder transactionConfig = TransactionConfig.builder(); - Optional.ofNullable(data.getTxMeta()).ifPresent(transactionConfig::withMetadata); - configureTimeout(transactionConfig); - return session.runAsync(query, transactionConfig.build()).thenApply(resultCursor -> { + return session.runAsync(query, getTxConfig()).thenApply(resultCursor -> { String id = testkitState.addAsyncResultHolder(new ResultCursorHolder(sessionHolder, resultCursor)); return createResponse(id, resultCursor.keys()); }); @@ -109,11 +86,8 @@ public Mono processRx(TestkitState testkitState) { Query query = Optional.ofNullable(data.params) .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - TransactionConfig.Builder transactionConfig = TransactionConfig.builder(); - Optional.ofNullable(data.getTxMeta()).ifPresent(transactionConfig::withMetadata); - configureTimeout(transactionConfig); - RxResult result = session.run(query, transactionConfig.build()); + RxResult result = session.run(query, getTxConfig()); String id = testkitState.addRxResultHolder(new RxResultHolder(sessionHolder, result)); // The keys() method causes RUN message exchange. @@ -129,11 +103,8 @@ public Mono processReactive(TestkitState testkitState) { Query query = Optional.ofNullable(data.params) .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - TransactionConfig.Builder transactionConfig = TransactionConfig.builder(); - Optional.ofNullable(data.getTxMeta()).ifPresent(transactionConfig::withMetadata); - configureTimeout(transactionConfig); - return Mono.fromDirect(flowPublisherToFlux(session.run(query, transactionConfig.build()))) + return Mono.fromDirect(flowPublisherToFlux(session.run(query, getTxConfig()))) .map(result -> { String id = testkitState.addReactiveResultHolder(new ReactiveResultHolder(sessionHolder, result)); @@ -149,16 +120,12 @@ public Mono processReactiveStreams(TestkitState testkitState) { Query query = Optional.ofNullable(data.params) .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - TransactionConfig.Builder transactionConfig = TransactionConfig.builder(); - Optional.ofNullable(data.getTxMeta()).ifPresent(transactionConfig::withMetadata); - configureTimeout(transactionConfig); - return Mono.fromDirect(session.run(query, transactionConfig.build())) - .map(result -> { - String id = testkitState.addReactiveResultStreamsHolder( - new ReactiveResultStreamsHolder(sessionHolder, result)); - return createResponse(id, result.keys()); - }); + return Mono.fromDirect(session.run(query, getTxConfig())).map(result -> { + String id = testkitState.addReactiveResultStreamsHolder( + new ReactiveResultStreamsHolder(sessionHolder, result)); + return createResponse(id, result.keys()); + }); }); } @@ -170,13 +137,16 @@ private Result createResponse(String resultId, List keys) { @Setter @Getter - public static class SessionRunBody { + public static class SessionRunBody implements ITxConfigBody { @JsonDeserialize(using = TestkitCypherParamDeserializer.class) private Map params; private String sessionId; private String cypher; + + @JsonDeserialize(using = TestkitCypherParamDeserializer.class) private Map txMeta; + private Integer timeout; private Boolean timeoutPresent = false; diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionWriteTransaction.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionWriteTransaction.java index 88abf48685..85bfc30c7c 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionWriteTransaction.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionWriteTransaction.java @@ -21,6 +21,7 @@ import static reactor.adapter.JdkFlowAdapter.flowPublisherToFlux; import static reactor.adapter.JdkFlowAdapter.publisherToFlowPublisher; +import com.fasterxml.jackson.databind.annotation.JsonDeserialize; import java.util.Map; import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; @@ -36,6 +37,7 @@ import neo4j.org.testkit.backend.holder.RxTransactionHolder; import neo4j.org.testkit.backend.holder.SessionHolder; import neo4j.org.testkit.backend.holder.TransactionHolder; +import neo4j.org.testkit.backend.messages.requests.deserializer.TestkitCypherParamDeserializer; import neo4j.org.testkit.backend.messages.responses.RetryableDone; import neo4j.org.testkit.backend.messages.responses.RetryableTry; import neo4j.org.testkit.backend.messages.responses.TestkitResponse; @@ -50,7 +52,7 @@ @Setter @Getter -public class SessionWriteTransaction implements TestkitRequest { +public class SessionWriteTransaction extends WithTxConfig { private SessionWriteTransactionBody data; @Override @@ -58,7 +60,7 @@ public class SessionWriteTransaction implements TestkitRequest { public TestkitResponse process(TestkitState testkitState) { SessionHolder sessionHolder = testkitState.getSessionHolder(data.getSessionId()); Session session = sessionHolder.getSession(); - session.writeTransaction(handle(testkitState, sessionHolder)); + session.writeTransaction(handle(testkitState, sessionHolder), getTxConfig()); return retryableDone(); } @@ -79,7 +81,7 @@ public CompletionStage processAsync(TestkitState testkitState) return tryResult; }; - return session.writeTransactionAsync(workWrapper); + return session.writeTransactionAsync(workWrapper, getTxConfig()); }) .thenApply(nothing -> retryableDone()); } @@ -98,7 +100,7 @@ public Mono processRx(TestkitState testkitState) { return Mono.fromCompletionStage(tryResult); }; - return Mono.fromDirect(sessionHolder.getSession().writeTransaction(workWrapper)); + return Mono.fromDirect(sessionHolder.getSession().writeTransaction(workWrapper, getTxConfig())); }) .then(Mono.just(retryableDone())); } @@ -118,7 +120,7 @@ public Mono processReactive(TestkitState testkitState) { }; return Mono.fromDirect( - flowPublisherToFlux(sessionHolder.getSession().executeWrite(workWrapper))); + flowPublisherToFlux(sessionHolder.getSession().executeWrite(workWrapper, getTxConfig()))); }) .then(Mono.just(retryableDone())); } @@ -138,7 +140,7 @@ public Mono processReactiveStreams(TestkitState testkitState) { return Mono.fromCompletionStage(tryResult); }; - return Mono.fromDirect(sessionHolder.getSession().executeWrite(workWrapper)); + return Mono.fromDirect(sessionHolder.getSession().executeWrite(workWrapper, getTxConfig())); }) .then(Mono.just(retryableDone())); } @@ -178,9 +180,18 @@ private RetryableDone retryableDone() { @Setter @Getter - public static class SessionWriteTransactionBody { + public static class SessionWriteTransactionBody implements ITxConfigBody { private String sessionId; - private Map txMeta; - private String timeout; + + @JsonDeserialize(using = TestkitCypherParamDeserializer.class) + private Map txMeta; + + private Integer timeout; + private Boolean timeoutPresent = false; + + public void setTimeout(Integer timeout) { + this.timeout = timeout; + timeoutPresent = true; + } } } diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/WithTxConfig.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/WithTxConfig.java new file mode 100644 index 0000000000..8a3ee66645 --- /dev/null +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/WithTxConfig.java @@ -0,0 +1,62 @@ +/* + * Copyright (c) "Neo4j" + * Neo4j Sweden AB [http://neo4j.com] + * + * This file is part of Neo4j. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package neo4j.org.testkit.backend.messages.requests; + +import java.time.Duration; +import java.util.Map; +import java.util.Optional; +import neo4j.org.testkit.backend.CustomDriverError; +import org.neo4j.driver.TransactionConfig; + +public abstract class WithTxConfig implements TestkitRequest { + public abstract ITxConfigBody getData(); + + protected TransactionConfig.Builder configureTxTimeout(TransactionConfig.Builder builder) { + if (!getData().getTimeoutPresent()) return builder; + try { + Optional.ofNullable(getData().getTimeout()) + .ifPresentOrElse( + (timeout) -> builder.withTimeout(Duration.ofMillis(timeout)), builder::withDefaultTimeout); + } catch (IllegalArgumentException e) { + throw new CustomDriverError(e); + } + return builder; + } + + protected TransactionConfig.Builder configureTxMetadata(TransactionConfig.Builder builder) { + Optional.ofNullable(getData().getTxMeta()).ifPresent(builder::withMetadata); + return builder; + } + + protected TransactionConfig.Builder configureTx(TransactionConfig.Builder builder) { + return configureTxMetadata(configureTxTimeout(builder)); + } + + protected TransactionConfig getTxConfig() { + return configureTx(TransactionConfig.builder()).build(); + } + + public interface ITxConfigBody { + Boolean getTimeoutPresent(); + + Integer getTimeout(); + + Map getTxMeta(); + } +} From d56407b3211f400307e109ebfc949b38537bd9be Mon Sep 17 00:00:00 2001 From: Robsdedude Date: Thu, 8 Dec 2022 10:05:05 +0100 Subject: [PATCH 2/3] Remove unused imports --- .../neo4j/org/testkit/backend/messages/requests/NewDriver.java | 2 -- 1 file changed, 2 deletions(-) diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/NewDriver.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/NewDriver.java index 30125127ca..62217f4f1c 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/NewDriver.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/NewDriver.java @@ -30,7 +30,6 @@ import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; import java.util.concurrent.TimeUnit; -import java.util.logging.Level; import java.util.stream.Collectors; import lombok.Getter; import lombok.RequiredArgsConstructor; @@ -46,7 +45,6 @@ import org.neo4j.driver.AuthToken; import org.neo4j.driver.AuthTokens; import org.neo4j.driver.Config; -import org.neo4j.driver.Logging; import org.neo4j.driver.internal.BoltServerAddress; import org.neo4j.driver.internal.DefaultDomainNameResolver; import org.neo4j.driver.internal.DomainNameResolver; From 3f8a37231d6dbb642da4e74e2425707cb9f29820 Mon Sep 17 00:00:00 2001 From: Dmitriy Tverdiakov Date: Tue, 13 Dec 2022 17:08:59 +0000 Subject: [PATCH 3/3] Refactoring --- ...ctTestkitRequestWithTransactionConfig.java | 75 +++++++++++++++++++ .../requests/SessionBeginTransaction.java | 34 +++------ .../requests/SessionReadTransaction.java | 34 +++------ .../backend/messages/requests/SessionRun.java | 29 ++----- .../requests/SessionWriteTransaction.java | 34 +++------ .../messages/requests/WithTxConfig.java | 62 --------------- 6 files changed, 109 insertions(+), 159 deletions(-) create mode 100644 testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/AbstractTestkitRequestWithTransactionConfig.java delete mode 100644 testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/WithTxConfig.java diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/AbstractTestkitRequestWithTransactionConfig.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/AbstractTestkitRequestWithTransactionConfig.java new file mode 100644 index 0000000000..e34890aa6b --- /dev/null +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/AbstractTestkitRequestWithTransactionConfig.java @@ -0,0 +1,75 @@ +/* + * Copyright (c) "Neo4j" + * Neo4j Sweden AB [http://neo4j.com] + * + * This file is part of Neo4j. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package neo4j.org.testkit.backend.messages.requests; + +import com.fasterxml.jackson.databind.annotation.JsonDeserialize; +import java.time.Duration; +import java.util.Map; +import java.util.Optional; +import lombok.Getter; +import lombok.Setter; +import neo4j.org.testkit.backend.CustomDriverError; +import neo4j.org.testkit.backend.messages.requests.deserializer.TestkitCypherParamDeserializer; +import org.neo4j.driver.TransactionConfig; + +@Setter +@Getter +abstract class AbstractTestkitRequestWithTransactionConfig< + T extends AbstractTestkitRequestWithTransactionConfig.TransactionConfigBody> + implements TestkitRequest { + protected T data; + + protected TransactionConfig buildTxConfig() { + return configureTx(TransactionConfig.builder()).build(); + } + + private TransactionConfig.Builder configureTx(TransactionConfig.Builder builder) { + return configureTxMetadata(configureTxTimeout(builder)); + } + + private TransactionConfig.Builder configureTxMetadata(TransactionConfig.Builder builder) { + data.getTxMeta().ifPresent(builder::withMetadata); + return builder; + } + + private TransactionConfig.Builder configureTxTimeout(TransactionConfig.Builder builder) { + try { + data.getTimeout().ifPresent((timeout) -> builder.withTimeout(Duration.ofMillis(timeout))); + } catch (IllegalArgumentException e) { + throw new CustomDriverError(e); + } + return builder; + } + + @Setter + abstract static class TransactionConfigBody { + protected Integer timeout; + + @JsonDeserialize(using = TestkitCypherParamDeserializer.class) + protected Map txMeta; + + Optional getTimeout() { + return Optional.ofNullable(timeout); + } + + Optional> getTxMeta() { + return Optional.ofNullable(txMeta); + } + } +} diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionBeginTransaction.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionBeginTransaction.java index 24cde32b59..6df030315c 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionBeginTransaction.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionBeginTransaction.java @@ -20,8 +20,6 @@ import static reactor.adapter.JdkFlowAdapter.flowPublisherToFlux; -import com.fasterxml.jackson.databind.annotation.JsonDeserialize; -import java.util.Map; import java.util.concurrent.CompletionStage; import lombok.Getter; import lombok.Setter; @@ -32,7 +30,6 @@ import neo4j.org.testkit.backend.holder.RxTransactionHolder; import neo4j.org.testkit.backend.holder.SessionHolder; import neo4j.org.testkit.backend.holder.TransactionHolder; -import neo4j.org.testkit.backend.messages.requests.deserializer.TestkitCypherParamDeserializer; import neo4j.org.testkit.backend.messages.responses.TestkitResponse; import neo4j.org.testkit.backend.messages.responses.Transaction; import org.neo4j.driver.Session; @@ -42,17 +39,14 @@ import org.neo4j.driver.reactive.RxSession; import reactor.core.publisher.Mono; -@Setter -@Getter -public class SessionBeginTransaction extends WithTxConfig { - private SessionBeginTransactionBody data; - +public class SessionBeginTransaction + extends AbstractTestkitRequestWithTransactionConfig { @Override public TestkitResponse process(TestkitState testkitState) { SessionHolder sessionHolder = testkitState.getSessionHolder(data.getSessionId()); Session session = sessionHolder.getSession(); - org.neo4j.driver.Transaction transaction = session.beginTransaction(getTxConfig()); + org.neo4j.driver.Transaction transaction = session.beginTransaction(buildTxConfig()); return transaction(testkitState.addTransactionHolder(new TransactionHolder(sessionHolder, transaction))); } @@ -62,7 +56,7 @@ public CompletionStage processAsync(TestkitState testkitState) AsyncSession session = sessionHolder.getSession(); TransactionConfig.Builder builder = TransactionConfig.builder(); - return session.beginTransactionAsync(getTxConfig()) + return session.beginTransactionAsync(buildTxConfig()) .thenApply(tx -> transaction( testkitState.addAsyncTransactionHolder(new AsyncTransactionHolder(sessionHolder, tx)))); }); @@ -75,7 +69,7 @@ public Mono processRx(TestkitState testkitState) { RxSession session = sessionHolder.getSession(); TransactionConfig.Builder builder = TransactionConfig.builder(); - return Mono.fromDirect(session.beginTransaction(getTxConfig())) + return Mono.fromDirect(session.beginTransaction(buildTxConfig())) .map(tx -> transaction( testkitState.addRxTransactionHolder(new RxTransactionHolder(sessionHolder, tx)))); }); @@ -87,7 +81,7 @@ public Mono processReactive(TestkitState testkitState) { ReactiveSession session = sessionHolder.getSession(); TransactionConfig.Builder builder = TransactionConfig.builder(); - return Mono.fromDirect(flowPublisherToFlux(session.beginTransaction(getTxConfig()))) + return Mono.fromDirect(flowPublisherToFlux(session.beginTransaction(buildTxConfig()))) .map(tx -> transaction(testkitState.addReactiveTransactionHolder( new ReactiveTransactionHolder(sessionHolder, tx)))); }); @@ -99,7 +93,7 @@ public Mono processReactiveStreams(TestkitState testkitState) { var session = sessionHolder.getSession(); TransactionConfig.Builder builder = TransactionConfig.builder(); - return Mono.fromDirect(session.beginTransaction(getTxConfig())) + return Mono.fromDirect(session.beginTransaction(buildTxConfig())) .map(tx -> transaction(testkitState.addReactiveTransactionStreamsHolder( new ReactiveTransactionStreamsHolder(sessionHolder, tx)))); }); @@ -113,18 +107,8 @@ private Transaction transaction(String txId) { @Getter @Setter - public static class SessionBeginTransactionBody implements WithTxConfig.ITxConfigBody { + public static class SessionBeginTransactionBody + extends AbstractTestkitRequestWithTransactionConfig.TransactionConfigBody { private String sessionId; - - @JsonDeserialize(using = TestkitCypherParamDeserializer.class) - private Map txMeta; - - private Integer timeout; - private Boolean timeoutPresent = false; - - public void setTimeout(Integer timeout) { - this.timeout = timeout; - timeoutPresent = true; - } } } diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionReadTransaction.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionReadTransaction.java index ff106c5662..60167f1e6c 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionReadTransaction.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionReadTransaction.java @@ -21,8 +21,6 @@ import static reactor.adapter.JdkFlowAdapter.flowPublisherToFlux; import static reactor.adapter.JdkFlowAdapter.publisherToFlowPublisher; -import com.fasterxml.jackson.databind.annotation.JsonDeserialize; -import java.util.Map; import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; import java.util.concurrent.ExecutionException; @@ -37,7 +35,6 @@ import neo4j.org.testkit.backend.holder.RxTransactionHolder; import neo4j.org.testkit.backend.holder.SessionHolder; import neo4j.org.testkit.backend.holder.TransactionHolder; -import neo4j.org.testkit.backend.messages.requests.deserializer.TestkitCypherParamDeserializer; import neo4j.org.testkit.backend.messages.responses.RetryableDone; import neo4j.org.testkit.backend.messages.responses.RetryableTry; import neo4j.org.testkit.backend.messages.responses.TestkitResponse; @@ -50,17 +47,14 @@ import org.reactivestreams.Publisher; import reactor.core.publisher.Mono; -@Setter -@Getter -public class SessionReadTransaction extends WithTxConfig { - private SessionReadTransactionBody data; - +public class SessionReadTransaction + extends AbstractTestkitRequestWithTransactionConfig { @Override @SuppressWarnings("deprecation") public TestkitResponse process(TestkitState testkitState) { SessionHolder sessionHolder = testkitState.getSessionHolder(data.getSessionId()); Session session = sessionHolder.getSession(); - session.readTransaction(handle(testkitState, sessionHolder), getTxConfig()); + session.readTransaction(handle(testkitState, sessionHolder), buildTxConfig()); return retryableDone(); } @@ -81,7 +75,7 @@ public CompletionStage processAsync(TestkitState testkitState) return txWorkFuture; }; - return session.readTransactionAsync(workWrapper, getTxConfig()); + return session.readTransactionAsync(workWrapper, buildTxConfig()); }) .thenApply(nothing -> retryableDone()); } @@ -100,7 +94,7 @@ public Mono processRx(TestkitState testkitState) { return Mono.fromCompletionStage(tryResult); }; - return Mono.fromDirect(sessionHolder.getSession().readTransaction(workWrapper, getTxConfig())); + return Mono.fromDirect(sessionHolder.getSession().readTransaction(workWrapper, buildTxConfig())); }) .then(Mono.just(retryableDone())); } @@ -120,7 +114,7 @@ public Mono processReactive(TestkitState testkitState) { }; return Mono.fromDirect( - flowPublisherToFlux(sessionHolder.getSession().executeRead(workWrapper, getTxConfig()))); + flowPublisherToFlux(sessionHolder.getSession().executeRead(workWrapper, buildTxConfig()))); }) .then(Mono.just(retryableDone())); } @@ -140,7 +134,7 @@ public Mono processReactiveStreams(TestkitState testkitState) { return Mono.fromCompletionStage(tryResult); }; - return Mono.fromDirect(sessionHolder.getSession().executeRead(workWrapper, getTxConfig())); + return Mono.fromDirect(sessionHolder.getSession().executeRead(workWrapper, buildTxConfig())); }) .then(Mono.just(retryableDone())); } @@ -180,18 +174,8 @@ private RetryableDone retryableDone() { @Setter @Getter - public static class SessionReadTransactionBody implements WithTxConfig.ITxConfigBody { + public static class SessionReadTransactionBody + extends AbstractTestkitRequestWithTransactionConfig.TransactionConfigBody { private String sessionId; - - @JsonDeserialize(using = TestkitCypherParamDeserializer.class) - private Map txMeta; - - private Integer timeout; - private Boolean timeoutPresent = false; - - public void setTimeout(Integer timeout) { - this.timeout = timeout; - timeoutPresent = true; - } } } diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionRun.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionRun.java index 3d4eb8385b..01758e8610 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionRun.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionRun.java @@ -45,11 +45,7 @@ import org.neo4j.driver.reactive.RxSession; import reactor.core.publisher.Mono; -@Setter -@Getter -public class SessionRun extends WithTxConfig { - private SessionRunBody data; - +public class SessionRun extends AbstractTestkitRequestWithTransactionConfig { @Override public TestkitResponse process(TestkitState testkitState) { SessionHolder sessionHolder = testkitState.getSessionHolder(data.getSessionId()); @@ -57,7 +53,7 @@ public TestkitResponse process(TestkitState testkitState) { Query query = Optional.ofNullable(data.params) .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - org.neo4j.driver.Result result = session.run(query, getTxConfig()); + org.neo4j.driver.Result result = session.run(query, buildTxConfig()); String id = testkitState.addResultHolder(new ResultHolder(sessionHolder, result)); return createResponse(id, result.keys()); @@ -71,7 +67,7 @@ public CompletionStage processAsync(TestkitState testkitState) .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - return session.runAsync(query, getTxConfig()).thenApply(resultCursor -> { + return session.runAsync(query, buildTxConfig()).thenApply(resultCursor -> { String id = testkitState.addAsyncResultHolder(new ResultCursorHolder(sessionHolder, resultCursor)); return createResponse(id, resultCursor.keys()); }); @@ -87,7 +83,7 @@ public Mono processRx(TestkitState testkitState) { .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - RxResult result = session.run(query, getTxConfig()); + RxResult result = session.run(query, buildTxConfig()); String id = testkitState.addRxResultHolder(new RxResultHolder(sessionHolder, result)); // The keys() method causes RUN message exchange. @@ -104,7 +100,7 @@ public Mono processReactive(TestkitState testkitState) { .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - return Mono.fromDirect(flowPublisherToFlux(session.run(query, getTxConfig()))) + return Mono.fromDirect(flowPublisherToFlux(session.run(query, buildTxConfig()))) .map(result -> { String id = testkitState.addReactiveResultHolder(new ReactiveResultHolder(sessionHolder, result)); @@ -121,7 +117,7 @@ public Mono processReactiveStreams(TestkitState testkitState) { .map(params -> new Query(data.cypher, data.params)) .orElseGet(() -> new Query(data.cypher)); - return Mono.fromDirect(session.run(query, getTxConfig())).map(result -> { + return Mono.fromDirect(session.run(query, buildTxConfig())).map(result -> { String id = testkitState.addReactiveResultStreamsHolder( new ReactiveResultStreamsHolder(sessionHolder, result)); return createResponse(id, result.keys()); @@ -137,22 +133,11 @@ private Result createResponse(String resultId, List keys) { @Setter @Getter - public static class SessionRunBody implements ITxConfigBody { + public static class SessionRunBody extends AbstractTestkitRequestWithTransactionConfig.TransactionConfigBody { @JsonDeserialize(using = TestkitCypherParamDeserializer.class) private Map params; private String sessionId; private String cypher; - - @JsonDeserialize(using = TestkitCypherParamDeserializer.class) - private Map txMeta; - - private Integer timeout; - private Boolean timeoutPresent = false; - - public void setTimeout(Integer timeout) { - this.timeout = timeout; - timeoutPresent = true; - } } } diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionWriteTransaction.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionWriteTransaction.java index 85bfc30c7c..d942af21e4 100644 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionWriteTransaction.java +++ b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/SessionWriteTransaction.java @@ -21,8 +21,6 @@ import static reactor.adapter.JdkFlowAdapter.flowPublisherToFlux; import static reactor.adapter.JdkFlowAdapter.publisherToFlowPublisher; -import com.fasterxml.jackson.databind.annotation.JsonDeserialize; -import java.util.Map; import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; import java.util.concurrent.ExecutionException; @@ -37,7 +35,6 @@ import neo4j.org.testkit.backend.holder.RxTransactionHolder; import neo4j.org.testkit.backend.holder.SessionHolder; import neo4j.org.testkit.backend.holder.TransactionHolder; -import neo4j.org.testkit.backend.messages.requests.deserializer.TestkitCypherParamDeserializer; import neo4j.org.testkit.backend.messages.responses.RetryableDone; import neo4j.org.testkit.backend.messages.responses.RetryableTry; import neo4j.org.testkit.backend.messages.responses.TestkitResponse; @@ -50,17 +47,14 @@ import org.reactivestreams.Publisher; import reactor.core.publisher.Mono; -@Setter -@Getter -public class SessionWriteTransaction extends WithTxConfig { - private SessionWriteTransactionBody data; - +public class SessionWriteTransaction + extends AbstractTestkitRequestWithTransactionConfig { @Override @SuppressWarnings("deprecation") public TestkitResponse process(TestkitState testkitState) { SessionHolder sessionHolder = testkitState.getSessionHolder(data.getSessionId()); Session session = sessionHolder.getSession(); - session.writeTransaction(handle(testkitState, sessionHolder), getTxConfig()); + session.writeTransaction(handle(testkitState, sessionHolder), buildTxConfig()); return retryableDone(); } @@ -81,7 +75,7 @@ public CompletionStage processAsync(TestkitState testkitState) return tryResult; }; - return session.writeTransactionAsync(workWrapper, getTxConfig()); + return session.writeTransactionAsync(workWrapper, buildTxConfig()); }) .thenApply(nothing -> retryableDone()); } @@ -100,7 +94,7 @@ public Mono processRx(TestkitState testkitState) { return Mono.fromCompletionStage(tryResult); }; - return Mono.fromDirect(sessionHolder.getSession().writeTransaction(workWrapper, getTxConfig())); + return Mono.fromDirect(sessionHolder.getSession().writeTransaction(workWrapper, buildTxConfig())); }) .then(Mono.just(retryableDone())); } @@ -120,7 +114,7 @@ public Mono processReactive(TestkitState testkitState) { }; return Mono.fromDirect( - flowPublisherToFlux(sessionHolder.getSession().executeWrite(workWrapper, getTxConfig()))); + flowPublisherToFlux(sessionHolder.getSession().executeWrite(workWrapper, buildTxConfig()))); }) .then(Mono.just(retryableDone())); } @@ -140,7 +134,7 @@ public Mono processReactiveStreams(TestkitState testkitState) { return Mono.fromCompletionStage(tryResult); }; - return Mono.fromDirect(sessionHolder.getSession().executeWrite(workWrapper, getTxConfig())); + return Mono.fromDirect(sessionHolder.getSession().executeWrite(workWrapper, buildTxConfig())); }) .then(Mono.just(retryableDone())); } @@ -180,18 +174,8 @@ private RetryableDone retryableDone() { @Setter @Getter - public static class SessionWriteTransactionBody implements ITxConfigBody { + public static class SessionWriteTransactionBody + extends AbstractTestkitRequestWithTransactionConfig.TransactionConfigBody { private String sessionId; - - @JsonDeserialize(using = TestkitCypherParamDeserializer.class) - private Map txMeta; - - private Integer timeout; - private Boolean timeoutPresent = false; - - public void setTimeout(Integer timeout) { - this.timeout = timeout; - timeoutPresent = true; - } } } diff --git a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/WithTxConfig.java b/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/WithTxConfig.java deleted file mode 100644 index 8a3ee66645..0000000000 --- a/testkit-backend/src/main/java/neo4j/org/testkit/backend/messages/requests/WithTxConfig.java +++ /dev/null @@ -1,62 +0,0 @@ -/* - * Copyright (c) "Neo4j" - * Neo4j Sweden AB [http://neo4j.com] - * - * This file is part of Neo4j. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package neo4j.org.testkit.backend.messages.requests; - -import java.time.Duration; -import java.util.Map; -import java.util.Optional; -import neo4j.org.testkit.backend.CustomDriverError; -import org.neo4j.driver.TransactionConfig; - -public abstract class WithTxConfig implements TestkitRequest { - public abstract ITxConfigBody getData(); - - protected TransactionConfig.Builder configureTxTimeout(TransactionConfig.Builder builder) { - if (!getData().getTimeoutPresent()) return builder; - try { - Optional.ofNullable(getData().getTimeout()) - .ifPresentOrElse( - (timeout) -> builder.withTimeout(Duration.ofMillis(timeout)), builder::withDefaultTimeout); - } catch (IllegalArgumentException e) { - throw new CustomDriverError(e); - } - return builder; - } - - protected TransactionConfig.Builder configureTxMetadata(TransactionConfig.Builder builder) { - Optional.ofNullable(getData().getTxMeta()).ifPresent(builder::withMetadata); - return builder; - } - - protected TransactionConfig.Builder configureTx(TransactionConfig.Builder builder) { - return configureTxMetadata(configureTxTimeout(builder)); - } - - protected TransactionConfig getTxConfig() { - return configureTx(TransactionConfig.builder()).build(); - } - - public interface ITxConfigBody { - Boolean getTimeoutPresent(); - - Integer getTimeout(); - - Map getTxMeta(); - } -}