2019-05-23 20:37:06 +00:00
|
|
|
import {
|
|
|
|
bootstrapModeler,
|
|
|
|
inject
|
|
|
|
} from 'test/TestHelper';
|
|
|
|
|
|
|
|
import connectModule from 'diagram-js/lib/features/connect';
|
|
|
|
import coreModule from 'lib/core';
|
|
|
|
import globalConnectModule from 'diagram-js/lib/features/global-connect';
|
|
|
|
import modelingModule from 'lib/features/modeling';
|
|
|
|
import rulesModule from 'lib/features/rules';
|
|
|
|
import snappingModule from 'lib/features/snapping';
|
|
|
|
|
|
|
|
import { createCanvasEvent as canvasEvent } from '../../../util/MockEvents';
|
|
|
|
|
|
|
|
|
|
|
|
describe('features/snapping - BpmnConnectSnapping', function() {
|
|
|
|
|
|
|
|
var testModules = [
|
|
|
|
connectModule,
|
|
|
|
coreModule,
|
|
|
|
globalConnectModule,
|
|
|
|
modelingModule,
|
|
|
|
rulesModule,
|
|
|
|
snappingModule
|
|
|
|
];
|
|
|
|
|
|
|
|
var diagramXML = require('./BpmnConnectSnapping.bpmn');
|
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: testModules
|
|
|
|
}));
|
|
|
|
|
|
|
|
beforeEach(inject(function(dragging) {
|
|
|
|
dragging.setOptions({ manual: true });
|
|
|
|
}));
|
|
|
|
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
describe('sequence flow', function() {
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
describe('boundary event loop', function() {
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
it('should snap left',
|
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// given
|
|
|
|
var boundaryEvent = elementRegistry.get('BoundaryEvent_Bottom'),
|
|
|
|
subProcess = elementRegistry.get('SubProcess'),
|
|
|
|
subProcessGfx = elementRegistry.getGraphics(subProcess);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 590, y: 200 }), boundaryEvent);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.hover({ element: subProcess, gfx: subProcessGfx });
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 400, y: 115 }));
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.end();
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// then
|
|
|
|
var waypoints = boundaryEvent.outgoing[0].waypoints;
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(5);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints[ 4 ].original).to.eql({
|
|
|
|
x: 420,
|
|
|
|
y: 115
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
it('should snap bottom',
|
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// given
|
|
|
|
var boundaryEvent = elementRegistry.get('BoundaryEvent_Bottom'),
|
|
|
|
subProcess = elementRegistry.get('SubProcess'),
|
|
|
|
subProcessGfx = elementRegistry.getGraphics(subProcess);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 630, y: 200 }), boundaryEvent);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.hover({ element: subProcess, gfx: subProcessGfx });
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 580, y: 115 }));
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.end();
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// then
|
|
|
|
var waypoints = boundaryEvent.outgoing[0].waypoints;
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(4);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints[ 3 ].original).to.eql({
|
|
|
|
x: 550,
|
|
|
|
y: 115
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
it('should snap right',
|
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// given
|
|
|
|
var boundaryEvent = elementRegistry.get('BoundaryEvent_Right'),
|
|
|
|
subProcess = elementRegistry.get('SubProcess'),
|
|
|
|
subProcessGfx = elementRegistry.getGraphics(subProcess);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 760, y: 130 }), boundaryEvent);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.hover({ element: subProcess, gfx: subProcessGfx });
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 580, y: 115 }));
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.end();
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// then
|
|
|
|
var waypoints = boundaryEvent.outgoing[0].waypoints;
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(4);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints[ 3 ].original).to.eql({
|
|
|
|
x: 580,
|
|
|
|
y: 90
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
it('should snap bottom',
|
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// given
|
|
|
|
var boundaryEvent = elementRegistry.get('BoundaryEvent_Right'),
|
|
|
|
subProcess = elementRegistry.get('SubProcess'),
|
|
|
|
subProcessGfx = elementRegistry.getGraphics(subProcess);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 760, y: 130 }), boundaryEvent);
|
2019-06-12 14:38:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.hover({ element: subProcess, gfx: subProcessGfx });
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 580, y: 200 }));
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.end();
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// then
|
|
|
|
var waypoints = boundaryEvent.outgoing[0].waypoints;
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(5);
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints[ 4 ].original).to.eql({
|
|
|
|
x: 580,
|
|
|
|
y: 180
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
});
|
2019-06-19 06:02:00 +00:00
|
|
|
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
describe('activity target', function() {
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
it('should snap to task mid',
|
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// given
|
|
|
|
var startEvent = elementRegistry.get('StartEvent_2'),
|
|
|
|
task = elementRegistry.get('Task_3'),
|
|
|
|
taskGfx = elementRegistry.getGraphics(task);
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 80, y: 845 }), startEvent);
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.hover({ element: task, gfx: taskGfx });
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 200, y: 850 }));
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.end();
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// then
|
|
|
|
var waypoints = startEvent.outgoing[0].waypoints;
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(2);
|
2019-06-19 06:02:00 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints[ 1 ].original).to.eql({
|
|
|
|
x: 200,
|
|
|
|
y: 845
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
2019-06-19 06:02:00 +00:00
|
|
|
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
it('should snap to sub-process mid',
|
2019-06-07 08:45:58 +00:00
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
// given
|
2019-09-13 09:37:32 +00:00
|
|
|
var startEvent = elementRegistry.get('StartEvent_3'),
|
|
|
|
subProcess = elementRegistry.get('SubProcess_1'),
|
2019-06-07 08:45:58 +00:00
|
|
|
subProcessGfx = elementRegistry.getGraphics(subProcess);
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
// when
|
2019-09-13 09:37:32 +00:00
|
|
|
connect.start(canvasEvent({ x: 80, y: 1025 }), startEvent);
|
2019-05-23 20:37:06 +00:00
|
|
|
|
2019-06-07 08:45:58 +00:00
|
|
|
dragging.hover({ element: subProcess, gfx: subProcessGfx });
|
2019-05-23 20:37:06 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 325, y: 1030 }));
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
2019-09-13 09:37:32 +00:00
|
|
|
var waypoints = startEvent.outgoing[0].waypoints;
|
|
|
|
|
|
|
|
expect(waypoints).to.have.length(2);
|
2019-05-23 20:37:06 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints[ 1 ].original).to.eql({
|
|
|
|
x: 325,
|
|
|
|
y: 1025
|
|
|
|
});
|
2019-06-07 08:45:58 +00:00
|
|
|
})
|
|
|
|
);
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
});
|
2019-06-18 13:18:25 +00:00
|
|
|
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
it('should to snap gateway target mid',
|
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// given
|
|
|
|
var startEvent = elementRegistry.get('StartEvent_1'),
|
|
|
|
gateway = elementRegistry.get('Gateway_1'),
|
|
|
|
gatewayGfx = elementRegistry.getGraphics(gateway);
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 80, y: 50 }), startEvent);
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.hover({ element: gateway, gfx: gatewayGfx });
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 255, y: 55 }));
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.end();
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// then
|
|
|
|
var waypoints = startEvent.outgoing[0].waypoints;
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(2);
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints[ 1 ].original).to.eql({
|
|
|
|
x: 250,
|
|
|
|
y: 50
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
2019-06-18 13:18:25 +00:00
|
|
|
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
it('should snap to event target mid',
|
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// given
|
|
|
|
var startEvent = elementRegistry.get('StartEvent_1'),
|
|
|
|
endEvent = elementRegistry.get('EndEvent_1'),
|
|
|
|
endEventGfx = elementRegistry.getGraphics(endEvent);
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 80, y: 50 }), startEvent);
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.hover({ element: endEvent, gfx: endEventGfx });
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 85, y: 245 }));
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var waypoints = startEvent.outgoing[0].waypoints;
|
|
|
|
|
|
|
|
expect(waypoints).to.have.length(2);
|
|
|
|
|
|
|
|
expect(waypoints[ 1 ].original).to.eql({
|
|
|
|
x: 80,
|
|
|
|
y: 240
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
2019-06-18 13:18:25 +00:00
|
|
|
|
2019-05-23 20:37:06 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('message flow', function() {
|
|
|
|
|
|
|
|
describe('connect', function() {
|
|
|
|
|
|
|
|
it('should snap target', inject(function(connect, dragging, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_1'),
|
|
|
|
intermediateCatchEvent = elementRegistry.get('IntermediateCatchEvent_1'),
|
|
|
|
intermediateCatchEventGfx = elementRegistry.getGraphics(intermediateCatchEvent);
|
|
|
|
|
|
|
|
// when
|
2019-09-13 09:37:32 +00:00
|
|
|
connect.start(canvasEvent({ x: 250, y: 240 }), task);
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
dragging.hover({ element: intermediateCatchEvent, gfx: intermediateCatchEventGfx });
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 185, y: 555 }));
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var waypoints = task.outgoing[0].waypoints;
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(4);
|
|
|
|
|
|
|
|
expect(waypoints[ 3 ].original).to.eql({
|
|
|
|
x: 180,
|
|
|
|
y: 550
|
|
|
|
});
|
2019-05-23 20:37:06 +00:00
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('global connect', function() {
|
|
|
|
|
|
|
|
it('should snap source', inject(function(connect, dragging, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var intermediateThrowEvent = elementRegistry.get('IntermediateThrowEvent_1'),
|
|
|
|
task = elementRegistry.get('Task_1'),
|
|
|
|
taskGfx = elementRegistry.getGraphics(task);
|
|
|
|
|
|
|
|
// when
|
2019-09-13 09:37:32 +00:00
|
|
|
connect.start(null, intermediateThrowEvent, { x: 75, y: 555 });
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
dragging.hover({ element: task, gfx: taskGfx });
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 290, y: 240 }));
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var waypoints = intermediateThrowEvent.outgoing[0].waypoints;
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(4);
|
|
|
|
|
|
|
|
expect(waypoints[ 0 ].original).to.eql({
|
|
|
|
x: 70,
|
|
|
|
y: 550
|
|
|
|
});
|
|
|
|
|
|
|
|
// NOT snapped
|
|
|
|
expect(waypoints[ 3 ].original).to.eql({
|
|
|
|
x: 290,
|
|
|
|
y: 240
|
|
|
|
});
|
2019-05-23 20:37:06 +00:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should snap target', inject(function(connect, dragging, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_1'),
|
|
|
|
intermediateCatchEvent = elementRegistry.get('IntermediateCatchEvent_1'),
|
|
|
|
intermediateCatchEventGfx = elementRegistry.getGraphics(intermediateCatchEvent);
|
|
|
|
|
|
|
|
// when
|
2019-09-13 09:37:32 +00:00
|
|
|
connect.start(null, task, { x: 255, y: 245 });
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
dragging.hover({ element: intermediateCatchEvent, gfx: intermediateCatchEventGfx });
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
dragging.move(canvasEvent({ x: 185, y: 555 }));
|
2019-05-23 20:37:06 +00:00
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var waypoints = task.outgoing[0].waypoints;
|
|
|
|
|
2019-09-13 09:37:32 +00:00
|
|
|
expect(waypoints).to.have.length(4);
|
|
|
|
|
|
|
|
// NOT snapped
|
|
|
|
expect(waypoints[ 0 ].original).to.eql({
|
|
|
|
x: 255,
|
|
|
|
y: 245
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(waypoints[ 3 ].original).to.eql({
|
|
|
|
x: 180,
|
|
|
|
y: 550
|
|
|
|
});
|
2019-05-23 20:37:06 +00:00
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2019-09-10 10:10:24 +00:00
|
|
|
});
|