io.camunda.zeebe.process.test.qa.abstracts.assertions.AbstractJobAssertTest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of zeebe-process-test-qa-abstracts Show documentation
Show all versions of zeebe-process-test-qa-abstracts Show documentation
QA tests for testing the Zeebe Process Test project.
/*
* Copyright © 2021 camunda services GmbH ([email protected])
*
* 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 io.camunda.zeebe.process.test.qa.abstracts.assertions;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
import static org.assertj.core.api.Assertions.entry;
import static org.assertj.core.data.Offset.offset;
import io.camunda.zeebe.client.ZeebeClient;
import io.camunda.zeebe.client.api.response.ActivateJobsResponse;
import io.camunda.zeebe.client.api.response.ActivatedJob;
import io.camunda.zeebe.process.test.api.ZeebeTestEngine;
import io.camunda.zeebe.process.test.assertions.BpmnAssert;
import io.camunda.zeebe.process.test.assertions.IncidentAssert;
import io.camunda.zeebe.process.test.qa.abstracts.util.Utilities;
import io.camunda.zeebe.process.test.qa.abstracts.util.Utilities.ProcessPackLoopingServiceTask;
import io.camunda.zeebe.protocol.record.value.ErrorType;
import java.time.Duration;
import java.util.Collections;
import java.util.Map;
import java.util.concurrent.TimeoutException;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Nested;
import org.junit.jupiter.api.Test;
public abstract class AbstractJobAssertTest {
public static final String WRONG_VALUE = "wrong value";
public static final String ERROR_CODE = "error";
public static final String ERROR_MSG = "error occurred";
// These tests are for testing assertions as well as examples for users
@Nested
class HappyPathTests {
private ZeebeClient client;
private ZeebeTestEngine engine;
@Test
void testHasElementId() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
BpmnAssert.assertThat(actual).hasElementId(ProcessPackLoopingServiceTask.ELEMENT_ID);
}
@Test
void testHasDeadline() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final long expectedDeadline = System.currentTimeMillis() + 100;
final ActivateJobsResponse jobActivationResponse =
client
.newActivateJobsCommand()
.jobType(ProcessPackLoopingServiceTask.JOB_TYPE)
.maxJobsToActivate(1)
.timeout(Duration.ofMillis(100))
.send()
.join();
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
BpmnAssert.assertThat(actual).hasDeadline(expectedDeadline, offset(50L));
}
@Test
void testHasBpmnProcessId() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
BpmnAssert.assertThat(actual).hasBpmnProcessId(ProcessPackLoopingServiceTask.PROCESS_ID);
}
@Test
void testHasRetries() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
BpmnAssert.assertThat(actual).hasRetries(1);
}
@Test
void testHasAnyIncidents() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
Utilities.startProcessInstance(engine, client, ProcessPackLoopingServiceTask.PROCESS_ID);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
Utilities.throwErrorCommand(engine, client, actual.getKey(), ERROR_CODE, ERROR_MSG);
// then
BpmnAssert.assertThat(actual).hasAnyIncidents();
}
@Test
void testHasNoIncidents() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
Utilities.startProcessInstance(engine, client, ProcessPackLoopingServiceTask.PROCESS_ID);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
BpmnAssert.assertThat(actual).hasNoIncidents();
}
@Test
void testExtractLatestIncident() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
Utilities.startProcessInstance(engine, client, ProcessPackLoopingServiceTask.PROCESS_ID);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
Utilities.throwErrorCommand(engine, client, actual.getKey(), ERROR_CODE, ERROR_MSG);
final IncidentAssert incidentAssert =
BpmnAssert.assertThat(actual).extractingLatestIncident();
// then
Assertions.assertThat(incidentAssert).isNotNull();
incidentAssert
.isUnresolved()
.hasErrorType(ErrorType.UNHANDLED_ERROR_EVENT)
.occurredDuringJob(actual);
}
@Test
void testExtractingVariables() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
BpmnAssert.assertThat(actual)
.extractingVariables()
.containsOnly(
entry(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1), entry("loopAmount", 0));
}
@Test
void testExtractingHeaders() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
BpmnAssert.assertThat(actual).extractingHeaders().isEmpty();
}
}
// These tests are just for assertion testing purposes. These should not be used as examples.
@Nested
class UnhappyPathTests {
private ZeebeClient client;
private ZeebeTestEngine engine;
@Test
void testHasElementIdFailure() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
assertThatThrownBy(() -> BpmnAssert.assertThat(actual).hasElementId(WRONG_VALUE))
.isInstanceOf(AssertionError.class)
.hasMessage(
"Job is not associated with expected element id '%s' but is instead associated with '%s'.",
WRONG_VALUE, ProcessPackLoopingServiceTask.ELEMENT_ID);
}
@Test
void testHasDeadlineFailure() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final long expectedDeadline = System.currentTimeMillis() + 100;
final ActivateJobsResponse jobActivationResponse =
client
.newActivateJobsCommand()
.jobType(ProcessPackLoopingServiceTask.JOB_TYPE)
.maxJobsToActivate(1)
.timeout(Duration.ofMillis(100))
.send()
.join();
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
assertThatThrownBy(() -> BpmnAssert.assertThat(actual).hasDeadline(-1, offset(20L)))
.isInstanceOf(AssertionError.class)
.hasMessageContainingAll("Deadline", "-1", "20");
}
@Test
void testHasBpmnProcessIdFailure() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
assertThatThrownBy(() -> BpmnAssert.assertThat(actual).hasBpmnProcessId(WRONG_VALUE))
.isInstanceOf(AssertionError.class)
.hasMessage(
"Job is not associated with BPMN process id '%s' but is instead associated with '%s'.",
WRONG_VALUE, ProcessPackLoopingServiceTask.PROCESS_ID);
}
@Test
void testHasRetriesFailure() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
final Map variables =
Collections.singletonMap(ProcessPackLoopingServiceTask.TOTAL_LOOPS, 1);
Utilities.startProcessInstance(
engine, client, ProcessPackLoopingServiceTask.PROCESS_ID, variables);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
assertThatThrownBy(() -> BpmnAssert.assertThat(actual).hasRetries(12345))
.isInstanceOf(AssertionError.class)
.hasMessage(
"Job does not have %d retries, as expected, but instead has %d retries.", 12345, 1);
}
@Test
void testHasAnyIncidentsFailure() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
Utilities.startProcessInstance(engine, client, ProcessPackLoopingServiceTask.PROCESS_ID);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
assertThatThrownBy(() -> BpmnAssert.assertThat(actual).hasAnyIncidents())
.isInstanceOf(AssertionError.class)
.hasMessage("No incidents were raised for this job");
}
@Test
void testHasNoIncidentsFailure() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
Utilities.startProcessInstance(engine, client, ProcessPackLoopingServiceTask.PROCESS_ID);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
Utilities.throwErrorCommand(engine, client, actual.getKey(), ERROR_CODE, ERROR_MSG);
// then
assertThatThrownBy(() -> BpmnAssert.assertThat(actual).hasNoIncidents())
.isInstanceOf(AssertionError.class)
.hasMessage("Incidents were raised for this job");
}
@Test
void testExtractLatestIncidentFailure() throws InterruptedException, TimeoutException {
// given
Utilities.deployResource(client, ProcessPackLoopingServiceTask.RESOURCE_NAME);
Utilities.startProcessInstance(engine, client, ProcessPackLoopingServiceTask.PROCESS_ID);
// when
final ActivateJobsResponse jobActivationResponse =
Utilities.activateSingleJob(client, ProcessPackLoopingServiceTask.JOB_TYPE);
// then
final ActivatedJob actual = jobActivationResponse.getJobs().get(0);
assertThatThrownBy(() -> BpmnAssert.assertThat(actual).extractingLatestIncident())
.isInstanceOf(AssertionError.class)
.hasMessage("No incidents were raised for this job");
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy