Skip to content

Commit

Permalink
Introduce 'toBeCallActivity' Jest extension
Browse files Browse the repository at this point in the history
  • Loading branch information
csouchet committed Oct 14, 2020
1 parent 1e4c0fb commit fd351f6
Show file tree
Hide file tree
Showing 4 changed files with 18 additions and 19 deletions.
6 changes: 4 additions & 2 deletions test/e2e/ExpectModelUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ import { FlowKind } from '../../src/model/bpmn/internal/edge/FlowKind';
import { MessageVisibleKind } from '../../src/model/bpmn/internal/edge/MessageVisibleKind';
import { SequenceFlowKind } from '../../src/model/bpmn/internal/edge/SequenceFlowKind';
import BpmnVisualization from '../../src/component/BpmnVisualization';
import { toBeCell, withGeometry, withFont, toBeSequenceFlow, toBeMessageFlow, toBeAssociationFlow, toBeShape } from './matchers';
import { toBeCell, withGeometry, withFont, toBeSequenceFlow, toBeMessageFlow, toBeAssociationFlow, toBeShape, toBeCallActivity } from './matchers';

declare global {
// eslint-disable-next-line @typescript-eslint/no-namespace
Expand All @@ -31,6 +31,7 @@ declare global {
toBeMessageFlow(modelElement: ExpectedEdgeModelElement): R;
toBeAssociationFlow(modelElement: ExpectedEdgeModelElement): R;
toBeShape(modelElement: ExpectedShapeModelElement): R;
toBeCallActivity(modelElement: ExpectedShapeModelElement): R;
}
}
}
Expand All @@ -43,6 +44,7 @@ expect.extend({
toBeMessageFlow,
toBeAssociationFlow,
toBeShape,
toBeCallActivity,
});

export interface ExpectedFont {
Expand All @@ -56,7 +58,7 @@ export interface ExpectedFont {

export interface ExpectedShapeModelElement {
label?: string;
kind: ShapeBpmnElementKind;
kind?: ShapeBpmnElementKind;
font?: ExpectedFont;
parentId?: string;
/** Only needed when the BPMN shape doesn't exist yet (use an arbitrary shape until the final render is implemented) */
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,7 +14,7 @@
* limitations under the License.
*/
export { toBeSequenceFlow, toBeMessageFlow, toBeAssociationFlow } from './toBeEdge';
export { toBeShape } from './toBeShape';
export { toBeShape, toBeCallActivity } from './toBeShape';
export { toBeCell } from './toBeCell';
export { withGeometry } from './withGeometry';
export { withFont } from './withFont';
5 changes: 5 additions & 0 deletions test/e2e/matchers/toBeShape/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import MatcherContext = jest.MatcherContext;
import CustomMatcherResult = jest.CustomMatcherResult;
import { ExpectedShapeModelElement, getDefaultParentId } from '../../ExpectModelUtils';
import { buildCellMatcher } from '../toBeCell';
import { ShapeBpmnElementKind } from '../../../../src/model/bpmn/internal/shape';

function buildExpectedStateStyle(expectedModel: ExpectedShapeModelElement): ExpectedStateStyle {
const expectedStateStyle = buildCommonExpectedStateStyle(expectedModel);
Expand Down Expand Up @@ -60,3 +61,7 @@ function buildExpectedCell(id: string, expectedModel: ExpectedShapeModelElement)
export function toBeShape(this: MatcherContext, received: string, expected: ExpectedShapeModelElement): CustomMatcherResult {
return buildCellMatcher('toBeShape', this, received, expected, 'Shape', buildExpectedCell);
}

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

// Call Activity calling process
// Expanded
expect('expanded_call_activity_id').toBeShape({
kind: ShapeBpmnElementKind.CALL_ACTIVITY,
expect('expanded_call_activity_id').toBeCallActivity({
label: 'Expanded Call Activity',
parentId: 'participant_1_id',
verticalAlign: 'top',
});
expect('expanded_call_activity_with_loop_id').toBeShape({
kind: ShapeBpmnElementKind.CALL_ACTIVITY,
expect('expanded_call_activity_with_loop_id').toBeCallActivity({
label: 'Expanded Call Activity With Loop',
markers: [ShapeBpmnMarkerKind.LOOP],
parentId: 'participant_1_id',
verticalAlign: 'top',
});
expect('expanded_call_activity_with_sequential_multi_instance_id').toBeShape({
kind: ShapeBpmnElementKind.CALL_ACTIVITY,
expect('expanded_call_activity_with_sequential_multi_instance_id').toBeCallActivity({
label: 'Expanded Call Activity With Sequential Multi-instance',
markers: [ShapeBpmnMarkerKind.MULTI_INSTANCE_SEQUENTIAL],
parentId: 'participant_1_id',
verticalAlign: 'top',
});
expect('expanded_call_activity_with_parallel_multi_instance_id').toBeShape({
kind: ShapeBpmnElementKind.CALL_ACTIVITY,
expect('expanded_call_activity_with_parallel_multi_instance_id').toBeCallActivity({
label: 'Expanded Call Activity With Parallel Multi-instance',
markers: [ShapeBpmnMarkerKind.MULTI_INSTANCE_PARALLEL],
parentId: 'participant_1_id',
verticalAlign: 'top',
});

// Collapsed
expect('collapsed_call_activity_id').toBeShape({
kind: ShapeBpmnElementKind.CALL_ACTIVITY,
expect('collapsed_call_activity_id').toBeCallActivity({
label: 'Collapsed Call Activity',
parentId: 'participant_1_id',
verticalAlign: 'top',
});
expect('collapsed_call_activity_with_loop_id').toBeShape({
kind: ShapeBpmnElementKind.CALL_ACTIVITY,
expect('collapsed_call_activity_with_loop_id').toBeCallActivity({
label: 'Collapsed Call Activity With Loop',
markers: [ShapeBpmnMarkerKind.LOOP, ShapeBpmnMarkerKind.EXPAND],
parentId: 'participant_1_id',
});
expect('collapsed_call_activity_with_sequential_multi_instance_id').toBeShape({
kind: ShapeBpmnElementKind.CALL_ACTIVITY,
expect('collapsed_call_activity_with_sequential_multi_instance_id').toBeCallActivity({
label: 'Collapsed Call Activity With Sequential Multi-instance',
markers: [ShapeBpmnMarkerKind.MULTI_INSTANCE_SEQUENTIAL, ShapeBpmnMarkerKind.EXPAND],
parentId: 'participant_1_id',
});
expect('collapsed_call_activity_with_parallel_multi_instance_id').toBeShape({
kind: ShapeBpmnElementKind.CALL_ACTIVITY,
expect('collapsed_call_activity_with_parallel_multi_instance_id').toBeCallActivity({
label: 'Collapsed Call Activity With Parallel Multi-instance',
markers: [ShapeBpmnMarkerKind.MULTI_INSTANCE_PARALLEL, ShapeBpmnMarkerKind.EXPAND],
parentId: 'participant_1_id',
Expand Down

0 comments on commit fd351f6

Please sign in to comment.