Skip to content

Commit

Permalink
Add unit tests for pool:
Browse files Browse the repository at this point in the history
- with incoming message flow,
- with outgoing message flow,
- with incoming/outgoing message flows
  • Loading branch information
csouchet committed Apr 21, 2023
1 parent aa4ca9d commit 7b62b77
Showing 1 changed file with 59 additions and 0 deletions.
59 changes: 59 additions & 0 deletions test/unit/component/parser/json/BpmnJsonParser.process.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,9 @@ See the License for the specific language governing permissions and
limitations under the License.
*/

import { buildDefinitions } from '../../../helpers/JsonBuilder';
import { parseJsonAndExpect, parseJsonAndExpectOnlyPools, parseJsonAndExpectOnlyPoolsAndFlowNodes, parseJsonAndExpectOnlyPoolsAndLanes } from '../../../helpers/JsonTestUtils';
import type { ExpectedShape } from '../../../helpers/bpmn-model-expect';
import { verifyShape } from '../../../helpers/bpmn-model-expect';

import { ShapeBpmnElementKind } from '../../../../../src/model/bpmn/internal';
Expand Down Expand Up @@ -832,4 +834,61 @@ describe('parse bpmn as json for process/pool', () => {

model.flowNodes.map(flowNode => flowNode.bpmnElement).forEach(bpmnElement => expect(bpmnElement.parentId).toBeUndefined());
});

describe(`incoming/outgoing management for participant referencing a process`, () => {
it.each`
title | expectedAttribute
${'incoming'} | ${'bpmnElementIncomingIds'}
${'outgoing'} | ${'bpmnElementOutgoingIds'}
`(
`should convert as Shape, when a participant referencing a process with $title message flow`,
({ title, expectedAttribute }: { title: string; expectedAttribute: keyof ExpectedShape }) => {
const json = buildDefinitions({
process: { withParticipant: true, id: 'process_O' },
messageFlows: {
id: `flow_${title}`,
sourceRef: title === 'incoming' ? 'unknown' : 'process_O',
targetRef: title === 'incoming' ? 'process_O' : 'unknown',
},
});

const model = parseJsonAndExpect(json, 1, 0, 0, 1);

verifyShape(model.pools[0], {
shapeId: 'shape_process_O',
bpmnElementId: 'process_O',
bpmnElementName: undefined,
bpmnElementKind: ShapeBpmnElementKind.POOL,
bounds: { x: 567, y: 345, width: 36, height: 45 },
isHorizontal: true,
[expectedAttribute]: [`flow_${title}`],
});
},
);

it(`should convert as Shape, when a participant referencing a process with incoming/outgoing message flows`, () => {
const json = buildDefinitions({
process: { withParticipant: true, id: 'process_O' },
messageFlows: [
{ id: 'flow_in_1', sourceRef: 'unknown', targetRef: 'process_O' },
{ id: 'flow_in_2', sourceRef: 'unknown', targetRef: 'process_O' },
{ id: 'flow_out_2', sourceRef: 'process_O', targetRef: 'unknown' },
{ id: 'flow_out_3', sourceRef: 'process_O', targetRef: 'unknown' },
],
});

const model = parseJsonAndExpect(json, 1, 0, 0, 4);

verifyShape(model.pools[0], {
shapeId: 'shape_process_O',
bpmnElementId: 'process_O',
bpmnElementName: undefined,
bpmnElementKind: ShapeBpmnElementKind.POOL,
bounds: { x: 567, y: 345, width: 36, height: 45 },
isHorizontal: true,
bpmnElementIncomingIds: ['flow_in_1', 'flow_in_2'],
bpmnElementOutgoingIds: ['flow_out_2', 'flow_out_3'],
});
});
});
});

0 comments on commit 7b62b77

Please sign in to comment.