use of org.neo4j.bolt.v4.messaging.RunMessage in project neo4j by neo4j.
the class BoltV4TransportIT method shouldReturnUpdatedBookmarkAfterAutoCommitTransaction.
@ParameterizedTest(name = "{0}")
@MethodSource("argumentsProvider")
public void shouldReturnUpdatedBookmarkAfterAutoCommitTransaction(Class<? extends TransportConnection> connectionClass) throws Exception {
init(connectionClass);
negotiateBoltV4();
// bookmark is expected to advance once the auto-commit transaction is committed
var lastClosedTransactionId = getLastClosedTransactionId();
var expectedBookmark = new BookmarkWithDatabaseId(lastClosedTransactionId + 1, getDatabaseId()).toString();
connection.send(util.chunk(new RunMessage("CREATE ()"), new PullMessage(asMapValue(map("n", -1L)))));
assertThat(connection).satisfies(util.eventuallyReceives(msgSuccess(), msgSuccess(responseMessage -> assertThat(responseMessage).containsEntry("bookmark", expectedBookmark))));
}
use of org.neo4j.bolt.v4.messaging.RunMessage in project neo4j by neo4j.
the class InTransactionStateIT method shouldStayInTxOnAnotherRun_succ.
@Test
void shouldStayInTxOnAnotherRun_succ() throws Throwable {
// Given
BoltStateMachineV4 machine = getBoltStateMachineInTxState();
// When
BoltResponseRecorder recorder = new BoltResponseRecorder();
machine.process(new RunMessage("MATCH (n) RETURN n LIMIT 1"), recorder);
// Then
RecordedBoltResponse response = recorder.nextResponse();
assertThat(response).satisfies(succeeded());
assertFalse(response.hasMetadata("bookmark"));
assertThat(machine.state()).isInstanceOf(InTransactionState.class);
}
use of org.neo4j.bolt.v4.messaging.RunMessage in project neo4j by neo4j.
the class InTransactionStateIT method getBoltStateMachineInTxState.
private BoltStateMachineV4 getBoltStateMachineInTxState(String query) throws BoltConnectionFatality {
BoltStateMachineV4 machine = newStateMachine();
machine.process(newHelloMessage(), nullResponseHandler());
machine.process(new BeginMessage(), nullResponseHandler());
assertThat(machine.state()).isInstanceOf(InTransactionState.class);
machine.process(new RunMessage(query, EMPTY_PARAMS), nullResponseHandler());
// tx streaming state
assertThat(machine.state()).isInstanceOf(InTransactionState.class);
return machine;
}
use of org.neo4j.bolt.v4.messaging.RunMessage in project neo4j by neo4j.
the class InTransactionStateIT method shouldMoveFromInTxToFailedOnAnotherRun_fail.
@Test
void shouldMoveFromInTxToFailedOnAnotherRun_fail() throws Throwable {
// Given
BoltStateMachineV4 machine = getBoltStateMachineInTxState();
// When
BoltResponseRecorder recorder = new BoltResponseRecorder();
machine.process(new RunMessage("any string"), recorder);
// Then
assertThat(machine.state()).isInstanceOf(FailedState.class);
}
use of org.neo4j.bolt.v4.messaging.RunMessage in project neo4j by neo4j.
the class InTransactionStateIT method shouldThrowExceptionOnIllegalMessagesInTxStreamingState.
private void shouldThrowExceptionOnIllegalMessagesInTxStreamingState(RequestMessage message) throws Throwable {
// Given
BoltStateMachineV4 machine = newStateMachine();
machine.process(newHelloMessage(), nullResponseHandler());
machine.process(new BeginMessage(), nullResponseHandler());
machine.process(new RunMessage("CREATE (n {k:'k'}) RETURN n.k", EMPTY_PARAMS), nullResponseHandler());
assertThat(machine.state()).isInstanceOf(InTransactionState.class);
// when
BoltResponseRecorder recorder = new BoltResponseRecorder();
verifyKillsConnection(() -> machine.process(message, recorder));
// then
assertThat(recorder.nextResponse()).satisfies(failedWithStatus(Status.Request.Invalid));
assertNull(machine.state());
}
Aggregations