Search in sources :

Example 41 with SubscribedEvent

use of io.zeebe.test.broker.protocol.clientapi.SubscribedEvent in project zeebe by zeebe-io.

the class IncidentTest method failTaskWithNoRetriesLeft.

private void failTaskWithNoRetriesLeft() {
    apiRule.openTaskSubscription("test").await();
    final SubscribedEvent taskEvent = testClient.receiveSingleEvent(taskEvents("LOCKED"));
    final ExecuteCommandResponse response = apiRule.createCmdRequest().key(taskEvent.key()).eventTypeTask().command().put("state", "FAIL").put("retries", 0).put("type", "failingTask").put("lockOwner", taskEvent.event().get("lockOwner")).put("headers", taskEvent.event().get("headers")).done().sendAndAwait();
    assertThat(response.getEvent()).containsEntry("state", "FAILED");
}
Also used : ExecuteCommandResponse(io.zeebe.test.broker.protocol.clientapi.ExecuteCommandResponse) SubscribedEvent(io.zeebe.test.broker.protocol.clientapi.SubscribedEvent)

Example 42 with SubscribedEvent

use of io.zeebe.test.broker.protocol.clientapi.SubscribedEvent in project zeebe by zeebe-io.

the class IncidentTest method shouldResolveIncidentForFailedCondition.

@Test
public void shouldResolveIncidentForFailedCondition() throws Throwable {
    // given
    testClient.deploy(Bpmn.createExecutableWorkflow("workflow").startEvent().exclusiveGateway("xor").sequenceFlow("s1", s -> s.condition("$.foo < 5")).endEvent().sequenceFlow("s2", s -> s.condition("$.foo >= 5 && $.foo < 10")).endEvent().done());
    // when
    final long workflowInstanceKey = testClient.createWorkflowInstance("workflow", asMsgPack("foo", "bar"));
    // then incident is created
    testClient.receiveSingleEvent(incidentEvents("CREATED"));
    final SubscribedEvent failureEvent = testClient.receiveSingleEvent(workflowInstanceEvents("GATEWAY_ACTIVATED"));
    // when correct payload is used
    updatePayload(workflowInstanceKey, failureEvent.key(), asMsgPack("foo", 7).byteArray());
    // then
    testClient.receiveSingleEvent(incidentEvents("RESOLVE"));
    testClient.receiveSingleEvent(workflowInstanceEvents("GATEWAY_ACTIVATED"));
    testClient.receiveSingleEvent(workflowInstanceEvents("SEQUENCE_FLOW_TAKEN"));
    testClient.receiveSingleEvent(incidentEvents("RESOLVED"));
    testClient.receiveSingleEvent(workflowInstanceEvents("END_EVENT_OCCURRED"));
    testClient.receiveSingleEvent(workflowInstanceEvents("WORKFLOW_INSTANCE_COMPLETED"));
}
Also used : ExecuteCommandResponse(io.zeebe.test.broker.protocol.clientapi.ExecuteCommandResponse) MsgPackUtil.encodeMsgPack(io.zeebe.broker.test.MsgPackUtil.encodeMsgPack) MSGPACK_PAYLOAD(io.zeebe.broker.test.MsgPackUtil.MSGPACK_PAYLOAD) TestTopicClient(io.zeebe.test.broker.protocol.clientapi.TestTopicClient) Assertions.assertThat(org.assertj.core.api.Assertions.assertThat) MsgPackHelper(io.zeebe.msgpack.spec.MsgPackHelper) EmbeddedBrokerRule(io.zeebe.broker.test.EmbeddedBrokerRule) Bpmn(io.zeebe.model.bpmn.Bpmn) MsgPackUtil.asMsgPack(io.zeebe.test.util.MsgPackUtil.asMsgPack) TestTopicClient.taskEvents(io.zeebe.test.broker.protocol.clientapi.TestTopicClient.taskEvents) ErrorType(io.zeebe.broker.incident.data.ErrorType) WorkflowDefinition(io.zeebe.model.bpmn.instance.WorkflowDefinition) Before(org.junit.Before) SubscribedEvent(io.zeebe.test.broker.protocol.clientapi.SubscribedEvent) IOException(java.io.IOException) Test(org.junit.Test) RuleChain(org.junit.rules.RuleChain) TestTopicClient.incidentEvents(io.zeebe.test.broker.protocol.clientapi.TestTopicClient.incidentEvents) JSON_MAPPER(io.zeebe.broker.test.MsgPackUtil.JSON_MAPPER) Rule(org.junit.Rule) MSGPACK_MAPPER(io.zeebe.broker.test.MsgPackUtil.MSGPACK_MAPPER) EventType(io.zeebe.protocol.clientapi.EventType) BufferUtil.wrapString(io.zeebe.util.buffer.BufferUtil.wrapString) MutableDirectBuffer(org.agrona.MutableDirectBuffer) TestTopicClient.workflowInstanceEvents(io.zeebe.test.broker.protocol.clientapi.TestTopicClient.workflowInstanceEvents) WorkflowInstanceState(io.zeebe.broker.workflow.data.WorkflowInstanceState) ClientApiRule(io.zeebe.test.broker.protocol.clientapi.ClientApiRule) SubscribedEvent(io.zeebe.test.broker.protocol.clientapi.SubscribedEvent) Test(org.junit.Test)

Example 43 with SubscribedEvent

use of io.zeebe.test.broker.protocol.clientapi.SubscribedEvent in project zeebe by zeebe-io.

the class IncidentTest method shouldCreateIncidentForInvalidResultOnInputMapping.

@Test
public void shouldCreateIncidentForInvalidResultOnInputMapping() throws Throwable {
    // given
    testClient.deploy(Bpmn.createExecutableWorkflow("process").startEvent().serviceTask("failingTask", t -> t.taskType("external").input("$.string", "$")).done());
    // when
    testClient.createWorkflowInstance("process", MSGPACK_PAYLOAD);
    // then incident is created
    final SubscribedEvent incidentEvent = testClient.receiveSingleEvent(incidentEvents("CREATE"));
    assertThat(incidentEvent.key()).isGreaterThan(0);
    assertThat(incidentEvent.event()).containsEntry("errorType", ErrorType.IO_MAPPING_ERROR.name()).containsEntry("errorMessage", "Processing failed, since mapping will result in a non map object (json object).");
}
Also used : SubscribedEvent(io.zeebe.test.broker.protocol.clientapi.SubscribedEvent) Test(org.junit.Test)

Example 44 with SubscribedEvent

use of io.zeebe.test.broker.protocol.clientapi.SubscribedEvent in project zeebe by zeebe-io.

the class IncidentTest method shouldFailToResolveIncident.

@Test
public void shouldFailToResolveIncident() throws Exception {
    // given
    final WorkflowDefinition modelInstance = Bpmn.createExecutableWorkflow("process").startEvent().serviceTask("failingTask", t -> t.taskType("external").input("$.foo", "$.foo").input("$.bar", "$.bar")).done();
    testClient.deploy(modelInstance);
    final long workflowInstanceKey = testClient.createWorkflowInstance("process");
    final SubscribedEvent failureEvent = testClient.receiveSingleEvent(workflowInstanceEvents("ACTIVITY_READY"));
    final SubscribedEvent incidentEvent = testClient.receiveSingleEvent(incidentEvents("CREATED"));
    assertThat(incidentEvent.event()).containsEntry("errorMessage", "No data found for query $.foo.");
    // when
    updatePayload(workflowInstanceKey, failureEvent.key(), PAYLOAD);
    // then
    final SubscribedEvent resolveFailedEvent = testClient.receiveSingleEvent(incidentEvents("RESOLVE_FAILED"));
    assertThat(resolveFailedEvent.key()).isEqualTo(incidentEvent.key());
    assertThat(resolveFailedEvent.event()).containsEntry("errorType", ErrorType.IO_MAPPING_ERROR.name()).containsEntry("errorMessage", "No data found for query $.bar.").containsEntry("bpmnProcessId", "process").containsEntry("workflowInstanceKey", workflowInstanceKey).containsEntry("activityId", "failingTask");
}
Also used : ExecuteCommandResponse(io.zeebe.test.broker.protocol.clientapi.ExecuteCommandResponse) MsgPackUtil.encodeMsgPack(io.zeebe.broker.test.MsgPackUtil.encodeMsgPack) MSGPACK_PAYLOAD(io.zeebe.broker.test.MsgPackUtil.MSGPACK_PAYLOAD) TestTopicClient(io.zeebe.test.broker.protocol.clientapi.TestTopicClient) Assertions.assertThat(org.assertj.core.api.Assertions.assertThat) MsgPackHelper(io.zeebe.msgpack.spec.MsgPackHelper) EmbeddedBrokerRule(io.zeebe.broker.test.EmbeddedBrokerRule) Bpmn(io.zeebe.model.bpmn.Bpmn) MsgPackUtil.asMsgPack(io.zeebe.test.util.MsgPackUtil.asMsgPack) TestTopicClient.taskEvents(io.zeebe.test.broker.protocol.clientapi.TestTopicClient.taskEvents) ErrorType(io.zeebe.broker.incident.data.ErrorType) WorkflowDefinition(io.zeebe.model.bpmn.instance.WorkflowDefinition) Before(org.junit.Before) SubscribedEvent(io.zeebe.test.broker.protocol.clientapi.SubscribedEvent) IOException(java.io.IOException) Test(org.junit.Test) RuleChain(org.junit.rules.RuleChain) TestTopicClient.incidentEvents(io.zeebe.test.broker.protocol.clientapi.TestTopicClient.incidentEvents) JSON_MAPPER(io.zeebe.broker.test.MsgPackUtil.JSON_MAPPER) Rule(org.junit.Rule) MSGPACK_MAPPER(io.zeebe.broker.test.MsgPackUtil.MSGPACK_MAPPER) EventType(io.zeebe.protocol.clientapi.EventType) BufferUtil.wrapString(io.zeebe.util.buffer.BufferUtil.wrapString) MutableDirectBuffer(org.agrona.MutableDirectBuffer) TestTopicClient.workflowInstanceEvents(io.zeebe.test.broker.protocol.clientapi.TestTopicClient.workflowInstanceEvents) WorkflowInstanceState(io.zeebe.broker.workflow.data.WorkflowInstanceState) ClientApiRule(io.zeebe.test.broker.protocol.clientapi.ClientApiRule) WorkflowDefinition(io.zeebe.model.bpmn.instance.WorkflowDefinition) SubscribedEvent(io.zeebe.test.broker.protocol.clientapi.SubscribedEvent) Test(org.junit.Test)

Example 45 with SubscribedEvent

use of io.zeebe.test.broker.protocol.clientapi.SubscribedEvent in project zeebe by zeebe-io.

the class CompleteTaskTest method shouldRejectCompletionIfTaskIsCompleted.

@Test
public void shouldRejectCompletionIfTaskIsCompleted() {
    // given
    createTask(TASK_TYPE);
    apiRule.openTaskSubscription(TASK_TYPE).await();
    final SubscribedEvent subscribedEvent = receiveSingleSubscribedEvent();
    completeTask(subscribedEvent.key(), subscribedEvent.event());
    // when
    final ExecuteCommandResponse response = completeTask(subscribedEvent.key(), subscribedEvent.event());
    // then
    assertThat(response.getEvent()).containsEntry("state", "COMPLETE_REJECTED");
}
Also used : ExecuteCommandResponse(io.zeebe.test.broker.protocol.clientapi.ExecuteCommandResponse) SubscribedEvent(io.zeebe.test.broker.protocol.clientapi.SubscribedEvent) Test(org.junit.Test)

Aggregations

SubscribedEvent (io.zeebe.test.broker.protocol.clientapi.SubscribedEvent)57 Test (org.junit.Test)55 ExecuteCommandResponse (io.zeebe.test.broker.protocol.clientapi.ExecuteCommandResponse)28 EmbeddedBrokerRule (io.zeebe.broker.test.EmbeddedBrokerRule)13 ClientApiRule (io.zeebe.test.broker.protocol.clientapi.ClientApiRule)13 Assertions.assertThat (org.assertj.core.api.Assertions.assertThat)13 Rule (org.junit.Rule)13 RuleChain (org.junit.rules.RuleChain)13 IOException (java.io.IOException)11 EventType (io.zeebe.protocol.clientapi.EventType)10 TestTopicClient (io.zeebe.test.broker.protocol.clientapi.TestTopicClient)10 HashMap (java.util.HashMap)10 Before (org.junit.Before)10 Bpmn (io.zeebe.model.bpmn.Bpmn)9 WorkflowDefinition (io.zeebe.model.bpmn.instance.WorkflowDefinition)9 TestTopicClient.taskEvents (io.zeebe.test.broker.protocol.clientapi.TestTopicClient.taskEvents)8 List (java.util.List)7 Map (java.util.Map)7 ErrorType (io.zeebe.broker.incident.data.ErrorType)6 JSON_MAPPER (io.zeebe.broker.test.MsgPackUtil.JSON_MAPPER)6