Skip to content

Commit

Permalink
Introduce 'toBeReceiveTask' Jest extension
Browse files Browse the repository at this point in the history
  • Loading branch information
csouchet committed Oct 15, 2020
1 parent 49762ef commit 287b77e
Show file tree
Hide file tree
Showing 4 changed files with 24 additions and 17 deletions.
3 changes: 3 additions & 0 deletions test/e2e/ExpectModelUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import {
toBeTask,
toBeServiceTask,
toBeUserTask,
toBeReceiveTask,
} from './matchers';

declare global {
Expand All @@ -47,6 +48,7 @@ declare global {
toBeTask(modelElement: ExpectedShapeModelElement): R;
toBeServiceTask(modelElement: ExpectedShapeModelElement): R;
toBeUserTask(modelElement: ExpectedShapeModelElement): R;
toBeReceiveTask(modelElement: ExpectedShapeModelElement): R;
}
}
}
Expand All @@ -63,6 +65,7 @@ expect.extend({
toBeTask,
toBeServiceTask,
toBeUserTask,
toBeReceiveTask,
});

export interface ExpectedCellWithGeometry {
Expand Down
2 changes: 1 addition & 1 deletion test/e2e/matchers/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,6 @@
* limitations under the License.
*/
export { toBeSequenceFlow, toBeMessageFlow, toBeAssociationFlow } from './toBeEdge';
export { toBeShape, toBeCallActivity, toBeTask, toBeServiceTask, toBeUserTask } from './toBeShape';
export { toBeShape, toBeCallActivity, toBeTask, toBeServiceTask, toBeUserTask, toBeReceiveTask } from './toBeShape';
export { toBeCell, toBeCellWithParentAndGeometry } from './toBeCell';
export { withFont } from './withFont';
12 changes: 12 additions & 0 deletions test/e2e/matchers/toBeShape/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -92,3 +92,15 @@ export function toBeServiceTask(this: MatcherContext, received: string, expected
export function toBeUserTask(this: MatcherContext, received: string, expected: ExpectedShapeModelElement): CustomMatcherResult {
return buildCellMatcher('toBeUserTask', this, received, { ...expected, kind: ShapeBpmnElementKind.TASK_USER }, 'Shape', buildExpectedCell, buildReceivedCellWithCommonAttributes);
}

export function toBeReceiveTask(this: MatcherContext, received: string, expected: ExpectedShapeModelElement): CustomMatcherResult {
return buildCellMatcher(
'toBeReceiveTask',
this,
received,
{ ...expected, kind: ShapeBpmnElementKind.TASK_RECEIVE },
'Shape',
buildExpectedCell,
buildReceivedCellWithCommonAttributes,
);
}
24 changes: 8 additions & 16 deletions test/e2e/mxGraph.model.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -800,57 +800,49 @@ describe('mxGraph model', () => {
});

// Receive Task: Non instantiating
expect('receive_task_non_instantiating_id').toBeShape({
kind: ShapeBpmnElementKind.TASK_RECEIVE,
expect('receive_task_non_instantiating_id').toBeReceiveTask({
label: 'Non-instantiating Receive Task',
isInstantiating: false,
parentId: 'participant_1_id',
});
expect('receive_task_non_instantiating_with_loop_id').toBeShape({
kind: ShapeBpmnElementKind.TASK_RECEIVE,
expect('receive_task_non_instantiating_with_loop_id').toBeReceiveTask({
label: 'Non-instantiating Receive Task With Loop',
isInstantiating: false,
markers: [ShapeBpmnMarkerKind.LOOP],
parentId: 'participant_1_id',
});
expect('receive_task_non_instantiating_with_sequential_multi_instance_id').toBeShape({
kind: ShapeBpmnElementKind.TASK_RECEIVE,
expect('receive_task_non_instantiating_with_sequential_multi_instance_id').toBeReceiveTask({
label: 'Non-instantiating Receive Task With Sequential Multi-instance',
isInstantiating: false,
markers: [ShapeBpmnMarkerKind.MULTI_INSTANCE_SEQUENTIAL],
parentId: 'participant_1_id',
});
expect('receive_task_non_instantiating_with_parallel_multi_instance_id').toBeShape({
kind: ShapeBpmnElementKind.TASK_RECEIVE,
expect('receive_task_non_instantiating_with_parallel_multi_instance_id').toBeReceiveTask({
label: 'Non-instantiating Receive Task With Parallel Multi-instance',
isInstantiating: false,
markers: [ShapeBpmnMarkerKind.MULTI_INSTANCE_PARALLEL],
parentId: 'participant_1_id',
});

// Receive Task: Instantiating
expect('receive_task_instantiating_id').toBeShape({
kind: ShapeBpmnElementKind.TASK_RECEIVE,
expect('receive_task_instantiating_id').toBeReceiveTask({
label: 'Instantiating Receive Task',
isInstantiating: true,
parentId: 'participant_1_id',
});
expect('receive_task_instantiating_with_loop_id').toBeShape({
kind: ShapeBpmnElementKind.TASK_RECEIVE,
expect('receive_task_instantiating_with_loop_id').toBeReceiveTask({
label: 'Instantiating Receive Task With Loop',
isInstantiating: true,
markers: [ShapeBpmnMarkerKind.LOOP],
parentId: 'participant_1_id',
});
expect('receive_task_instantiating_with_sequential_multi_instance_id').toBeShape({
kind: ShapeBpmnElementKind.TASK_RECEIVE,
expect('receive_task_instantiating_with_sequential_multi_instance_id').toBeReceiveTask({
label: 'Instantiating Receive Task With Sequential Multi-instance',
isInstantiating: true,
markers: [ShapeBpmnMarkerKind.MULTI_INSTANCE_SEQUENTIAL],
parentId: 'participant_1_id',
});
expect('receive_task_instantiating_with_parallel_multi_instance_id').toBeShape({
kind: ShapeBpmnElementKind.TASK_RECEIVE,
expect('receive_task_instantiating_with_parallel_multi_instance_id').toBeReceiveTask({
label: 'Instantiating Receive Task With Parallel Multi-instance',
isInstantiating: true,
markers: [ShapeBpmnMarkerKind.MULTI_INSTANCE_PARALLEL],
Expand Down

0 comments on commit 287b77e

Please sign in to comment.