2018-04-02 21:01:53 +02:00
|
|
|
import {
|
|
|
|
bootstrapModeler,
|
|
|
|
inject
|
|
|
|
} from 'test/TestHelper';
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
import {
|
|
|
|
flatten
|
|
|
|
} from 'min-dash';
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
import coreModule from 'lib/core';
|
|
|
|
import moveModule from 'diagram-js/lib/features/move';
|
|
|
|
import modelingModule from 'lib/features/modeling';
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
var noTouchInteractionModule = { touchInteractionEvents: ['value', null ] };
|
|
|
|
|
|
|
|
import {
|
|
|
|
createCanvasEvent as canvasEvent
|
|
|
|
} from '../../../../util/MockEvents';
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2019-08-29 11:55:34 +02:00
|
|
|
import { getMid } from 'diagram-js/lib/layout/LayoutUtil';
|
|
|
|
|
2017-01-25 17:27:30 +01:00
|
|
|
|
|
|
|
describe('modeling/behavior - drop on connection', function() {
|
|
|
|
|
|
|
|
var diagramXML = require('./DropOnFlowBehavior.bpmn');
|
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: [
|
|
|
|
noTouchInteractionModule,
|
|
|
|
moveModule,
|
|
|
|
modelingModule,
|
|
|
|
coreModule
|
|
|
|
]
|
|
|
|
}));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
|
|
|
|
|
|
|
describe('execution', function() {
|
|
|
|
|
|
|
|
describe('create', function() {
|
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
it('should connect start -> target -> end', inject(
|
|
|
|
function(modeling, elementRegistry, elementFactory) {
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// given
|
|
|
|
var intermediateThrowEvent = elementFactory.createShape({
|
|
|
|
type: 'bpmn:IntermediateThrowEvent'
|
|
|
|
});
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var startEvent = elementRegistry.get('StartEvent'),
|
|
|
|
sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
task = elementRegistry.get('Task_1');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var originalWaypoints = sequenceFlow.waypoints;
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var dropPosition = { x: 340, y: 120 }; // first bendpoint
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// when
|
|
|
|
var newShape = modeling.createShape(
|
|
|
|
intermediateThrowEvent,
|
|
|
|
dropPosition,
|
|
|
|
sequenceFlow
|
|
|
|
);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// then
|
|
|
|
var targetConnection = newShape.outgoing[0];
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// new incoming connection
|
|
|
|
expect(newShape.incoming.length).to.equal(1);
|
|
|
|
expect(newShape.incoming[0]).to.eql(sequenceFlow);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// new outgoing connection
|
|
|
|
expect(newShape.outgoing.length).to.equal(1);
|
2018-07-24 16:30:42 +02:00
|
|
|
expect(targetConnection).to.exist;
|
2018-02-14 22:20:11 +01:00
|
|
|
expect(targetConnection.type).to.equal('bpmn:SequenceFlow');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
expect(startEvent.outgoing[0]).to.equal(newShape.incoming[0]);
|
2018-07-24 16:30:42 +02:00
|
|
|
expect(task.incoming[1]).to.equal(newShape.outgoing[0]);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 1),
|
|
|
|
{ x: 322, y: 120 }
|
|
|
|
]));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
expect(sequenceFlow).to.have.endDocking(dropPosition);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
expect(targetConnection).to.have.waypoints(flatten([
|
|
|
|
{ x: 340, y: 138 },
|
|
|
|
originalWaypoints.slice(2)
|
|
|
|
]));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
expect(targetConnection).to.have.startDocking(dropPosition);
|
|
|
|
}
|
|
|
|
));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
it('should connect start -> target', inject(
|
|
|
|
function(modeling, elementRegistry, elementFactory) {
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// given
|
|
|
|
var endEventShape = elementFactory.createShape({ type: 'bpmn:EndEvent' });
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1');
|
|
|
|
var originalWaypoints = sequenceFlow.waypoints;
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var dropPosition = { x: 340, y: 120 }; // first bendpoint
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// when
|
|
|
|
var newShape = modeling.createShape(
|
|
|
|
endEventShape,
|
|
|
|
dropPosition,
|
|
|
|
sequenceFlow
|
|
|
|
);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// then
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// new incoming connection
|
|
|
|
expect(newShape.incoming.length).to.equal(1);
|
|
|
|
expect(newShape.incoming[0]).to.eql(sequenceFlow);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// no outgoing edges
|
|
|
|
expect(newShape.outgoing.length).to.equal(0);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 1),
|
|
|
|
{ x: 322, y: 120 }
|
|
|
|
]));
|
|
|
|
}
|
|
|
|
));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
it('should connect target -> end', inject(
|
|
|
|
function(modeling, elementRegistry, elementFactory) {
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// given
|
|
|
|
var startEventShape = elementFactory.createShape({
|
|
|
|
type: 'bpmn:StartEvent'
|
|
|
|
});
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1');
|
|
|
|
var originalWaypoints = sequenceFlow.waypoints;
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var dropPosition = { x: 340, y: 120 }; // first bendpoint
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// when
|
|
|
|
var newShape = modeling.createShape(
|
|
|
|
startEventShape,
|
|
|
|
dropPosition,
|
|
|
|
sequenceFlow
|
|
|
|
);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// then
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// no incoming connection
|
|
|
|
expect(newShape.incoming.length).to.equal(0);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// no outgoing edges
|
|
|
|
expect(newShape.outgoing.length).to.equal(1);
|
|
|
|
expect(newShape.outgoing[0]).to.eql(sequenceFlow);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
{ x: 340, y: 138 },
|
|
|
|
originalWaypoints.slice(2)
|
|
|
|
]));
|
|
|
|
}
|
|
|
|
));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2017-07-24 15:07:44 +02:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should connect start -> target -> end (with bendpointBefore inside bbox)', inject(
|
|
|
|
function(modeling, elementRegistry, elementFactory) {
|
2019-08-19 10:39:20 +02:00
|
|
|
|
2017-07-24 15:07:44 +02:00
|
|
|
// given
|
|
|
|
var taskShape = elementFactory.createShape({ type: 'bpmn:Task' }),
|
|
|
|
sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
originalWaypoints = sequenceFlow.waypoints,
|
|
|
|
dropPosition = { x: 340, y: 145 }; // 25 pixels below bendpoint
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.createShape(taskShape, dropPosition, sequenceFlow);
|
|
|
|
|
|
|
|
// then
|
|
|
|
// split target but don't keep insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 1),
|
|
|
|
{ x: 290, y: 120 }
|
|
|
|
]));
|
|
|
|
|
|
|
|
expect(sequenceFlow).to.have.endDocking({ x: 340, y: 120 });
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should connect start -> target -> end (with bendpointAfter inside bbox)', inject(
|
|
|
|
function(modeling, elementRegistry, elementFactory) {
|
2017-07-24 15:07:44 +02:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// given
|
2017-07-24 15:07:44 +02:00
|
|
|
var taskShape = elementFactory.createShape({ type: 'bpmn:Task' }),
|
|
|
|
sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
originalWaypoints = sequenceFlow.waypoints,
|
|
|
|
dropPosition = { x: 340, y: 280 }; // 25 pixels above bendpoint
|
|
|
|
|
|
|
|
// when
|
|
|
|
var newShape = modeling.createShape(taskShape, dropPosition, sequenceFlow),
|
|
|
|
targetConnection = newShape.outgoing[0];
|
|
|
|
|
|
|
|
// then
|
|
|
|
// split target but don't keep insertion point
|
|
|
|
expect(targetConnection).to.have.waypoints(flatten([
|
|
|
|
{ x: 390, y: 299 },
|
|
|
|
originalWaypoints.slice(3)
|
|
|
|
]));
|
|
|
|
|
|
|
|
expect(targetConnection).to.have.startDocking({ x: 340, y: 299 });
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2019-08-29 11:55:34 +02:00
|
|
|
|
|
|
|
it('should handle shape created with bounds', inject(
|
|
|
|
function(elementFactory, elementRegistry, modeling) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var intermediateThrowEvent = elementFactory.createShape({
|
|
|
|
type: 'bpmn:IntermediateThrowEvent'
|
|
|
|
});
|
|
|
|
|
|
|
|
var startEvent = elementRegistry.get('StartEvent'),
|
|
|
|
sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
task = elementRegistry.get('Task_1');
|
|
|
|
|
|
|
|
var originalWaypoints = sequenceFlow.waypoints;
|
|
|
|
|
|
|
|
var dropBounds = { x: 322, y: 102, width: 36, height: 36 }; // first bendpoint
|
|
|
|
|
|
|
|
// when
|
|
|
|
var newShape = modeling.createShape(
|
|
|
|
intermediateThrowEvent,
|
|
|
|
dropBounds,
|
|
|
|
sequenceFlow
|
|
|
|
);
|
|
|
|
|
|
|
|
// then
|
|
|
|
var targetConnection = newShape.outgoing[0];
|
|
|
|
|
|
|
|
// new incoming connection
|
|
|
|
expect(newShape.incoming.length).to.equal(1);
|
|
|
|
expect(newShape.incoming[0]).to.eql(sequenceFlow);
|
|
|
|
|
|
|
|
// new outgoing connection
|
|
|
|
expect(newShape.outgoing.length).to.equal(1);
|
|
|
|
expect(targetConnection).to.exist;
|
|
|
|
expect(targetConnection.type).to.equal('bpmn:SequenceFlow');
|
|
|
|
|
|
|
|
expect(startEvent.outgoing[0]).to.equal(newShape.incoming[0]);
|
|
|
|
expect(task.incoming[1]).to.equal(newShape.outgoing[0]);
|
|
|
|
|
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 1),
|
|
|
|
{ x: 322, y: 120 }
|
|
|
|
]));
|
|
|
|
|
|
|
|
expect(sequenceFlow).to.have.endDocking(getMid(dropBounds));
|
|
|
|
|
|
|
|
expect(targetConnection).to.have.waypoints(flatten([
|
|
|
|
{ x: 340, y: 138 },
|
|
|
|
originalWaypoints.slice(2)
|
|
|
|
]));
|
|
|
|
|
|
|
|
expect(targetConnection).to.have.startDocking(getMid(dropBounds));
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2017-01-25 17:27:30 +01:00
|
|
|
});
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
|
2017-01-25 17:27:30 +01:00
|
|
|
describe('move', function() {
|
|
|
|
|
|
|
|
beforeEach(inject(function(dragging) {
|
|
|
|
dragging.setOptions({ manual: true });
|
|
|
|
}));
|
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
it('should connect start -> target -> end', inject(
|
|
|
|
function(dragging, move, elementRegistry, selection) {
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// given
|
|
|
|
var intermediateThrowEvent = elementRegistry.get('IntermediateThrowEvent_foo');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var startEvent = elementRegistry.get('StartEvent'),
|
|
|
|
sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
sequenceFlowGfx = elementRegistry.getGraphics(sequenceFlow),
|
|
|
|
task = elementRegistry.get('Task_1');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var originalWaypoints = sequenceFlow.waypoints;
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// when
|
|
|
|
selection.select(intermediateThrowEvent);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), intermediateThrowEvent);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
dragging.hover({
|
|
|
|
element: sequenceFlow,
|
|
|
|
gfx: sequenceFlowGfx
|
|
|
|
});
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2019-04-09 14:35:48 +02:00
|
|
|
dragging.move(canvasEvent({ x: 149, y: 0 }));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
dragging.end();
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// then
|
|
|
|
var targetConnection = intermediateThrowEvent.outgoing[0];
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// new incoming connection
|
|
|
|
expect(intermediateThrowEvent.incoming.length).to.equal(1);
|
|
|
|
expect(intermediateThrowEvent.incoming[0]).to.eql(sequenceFlow);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// new outgoing connection
|
|
|
|
expect(intermediateThrowEvent.outgoing.length).to.equal(1);
|
2018-07-24 16:30:42 +02:00
|
|
|
expect(targetConnection).to.exist;
|
2018-02-14 22:20:11 +01:00
|
|
|
expect(targetConnection.type).to.equal('bpmn:SequenceFlow');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
expect(startEvent.outgoing[0]).to.equal(intermediateThrowEvent.incoming[0]);
|
2018-07-24 16:30:42 +02:00
|
|
|
expect(task.incoming[1]).to.equal(intermediateThrowEvent.outgoing[0]);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 2),
|
2019-04-09 14:35:48 +02:00
|
|
|
{ x: 340, y: 192 }
|
2018-02-14 22:20:11 +01:00
|
|
|
]));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2019-04-09 14:35:48 +02:00
|
|
|
expect(sequenceFlow).to.have.endDocking({ x: 340, y: 210 });
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
expect(targetConnection).to.have.waypoints(flatten([
|
2019-04-09 14:35:48 +02:00
|
|
|
{ x: 340, y: 228 },
|
2018-02-14 22:20:11 +01:00
|
|
|
originalWaypoints.slice(2)
|
|
|
|
]));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2019-04-09 14:35:48 +02:00
|
|
|
expect(targetConnection).to.have.startDocking({ x: 340, y: 210 });
|
2018-02-14 22:20:11 +01:00
|
|
|
}
|
|
|
|
));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should connect start -> target -> end (hovering parent)', inject(
|
|
|
|
function(dragging, move, elementRegistry, selection, canvas) {
|
2017-07-27 13:40:21 +02:00
|
|
|
|
|
|
|
// given
|
|
|
|
var intermediateThrowEvent = elementRegistry.get('IntermediateThrowEvent_foo');
|
|
|
|
|
|
|
|
var startEvent = elementRegistry.get('StartEvent'),
|
|
|
|
sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
task = elementRegistry.get('Task_1'),
|
|
|
|
rootElement = canvas.getRootElement(),
|
|
|
|
rootElementGfx = elementRegistry.getGraphics(rootElement);
|
|
|
|
|
|
|
|
var originalWaypoints = sequenceFlow.waypoints;
|
|
|
|
|
|
|
|
// when
|
|
|
|
selection.select(intermediateThrowEvent);
|
|
|
|
|
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), intermediateThrowEvent);
|
|
|
|
|
|
|
|
dragging.hover({
|
|
|
|
element: rootElement,
|
|
|
|
gfx: rootElementGfx
|
|
|
|
});
|
|
|
|
|
2019-04-09 14:35:48 +02:00
|
|
|
dragging.move(canvasEvent({ x: 149, y: 0 }));
|
2017-07-27 13:40:21 +02:00
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var targetConnection = intermediateThrowEvent.outgoing[0];
|
|
|
|
|
|
|
|
// new incoming connection
|
|
|
|
expect(intermediateThrowEvent.incoming.length).to.equal(1);
|
|
|
|
expect(intermediateThrowEvent.incoming[0]).to.eql(sequenceFlow);
|
|
|
|
|
|
|
|
// new outgoing connection
|
|
|
|
expect(intermediateThrowEvent.outgoing.length).to.equal(1);
|
2018-07-24 16:30:42 +02:00
|
|
|
expect(targetConnection).to.exist;
|
2017-07-27 13:40:21 +02:00
|
|
|
expect(targetConnection.type).to.equal('bpmn:SequenceFlow');
|
|
|
|
|
|
|
|
expect(startEvent.outgoing[0]).to.equal(intermediateThrowEvent.incoming[0]);
|
2018-07-24 16:30:42 +02:00
|
|
|
expect(task.incoming[1]).to.equal(intermediateThrowEvent.outgoing[0]);
|
2017-07-27 13:40:21 +02:00
|
|
|
|
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 2),
|
2019-04-09 14:35:48 +02:00
|
|
|
{ x: 340, y: 192 }
|
2017-07-27 13:40:21 +02:00
|
|
|
]));
|
|
|
|
|
2019-04-09 14:35:48 +02:00
|
|
|
expect(sequenceFlow).to.have.endDocking({ x: 340, y: 210 });
|
2017-07-27 13:40:21 +02:00
|
|
|
|
|
|
|
expect(targetConnection).to.have.waypoints(flatten([
|
2019-04-09 14:35:48 +02:00
|
|
|
{ x: 340, y: 228 },
|
2017-07-27 13:40:21 +02:00
|
|
|
originalWaypoints.slice(2)
|
|
|
|
]));
|
|
|
|
|
2019-04-09 14:35:48 +02:00
|
|
|
expect(targetConnection).to.have.startDocking({ x: 340, y: 210 });
|
2017-07-27 13:40:21 +02:00
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should connect start -> target -> end (with bendpointBefore inside bbox)', inject(
|
|
|
|
function(elementRegistry, selection, move, dragging) {
|
2019-08-19 10:39:20 +02:00
|
|
|
|
2017-07-27 13:40:21 +02:00
|
|
|
// given
|
|
|
|
var task3 = elementRegistry.get('Task_3'),
|
|
|
|
sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
sequenceFlowGfx = elementRegistry.getGraphics(sequenceFlow),
|
|
|
|
originalWaypoints = sequenceFlow.waypoints;
|
|
|
|
|
|
|
|
// when
|
|
|
|
selection.select(task3);
|
|
|
|
|
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), task3);
|
|
|
|
|
|
|
|
dragging.hover({
|
|
|
|
element: sequenceFlow,
|
|
|
|
gfx: sequenceFlowGfx
|
|
|
|
});
|
|
|
|
|
2019-04-09 14:35:48 +02:00
|
|
|
dragging.move(canvasEvent({ x: 149, y: -130 }));
|
2017-07-27 13:40:21 +02:00
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
// split target but don't keep insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 2),
|
2019-04-09 14:35:48 +02:00
|
|
|
{ x: 340, y: 241 }
|
2017-07-27 13:40:21 +02:00
|
|
|
]));
|
|
|
|
|
2019-04-09 14:35:48 +02:00
|
|
|
expect(sequenceFlow).to.have.endDocking({ x: 340, y: 281 });
|
2017-07-27 13:40:21 +02:00
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should connect start -> target -> end (with bendpointAfter inside bbox)', inject(
|
|
|
|
function(elementRegistry, selection, move, dragging) {
|
2019-08-19 10:39:20 +02:00
|
|
|
|
2017-07-27 13:40:21 +02:00
|
|
|
// given
|
|
|
|
var task3 = elementRegistry.get('Task_3'),
|
|
|
|
sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
sequenceFlowGfx = elementRegistry.getGraphics(sequenceFlow),
|
|
|
|
originalWaypoints = sequenceFlow.waypoints;
|
|
|
|
|
|
|
|
// when
|
|
|
|
selection.select(task3);
|
|
|
|
|
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), task3);
|
|
|
|
|
|
|
|
dragging.hover({
|
|
|
|
element: sequenceFlow,
|
|
|
|
gfx: sequenceFlowGfx
|
|
|
|
});
|
|
|
|
|
|
|
|
dragging.move(canvasEvent({ x: 170, y: -110 }));
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
// split target but don't keep insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 2),
|
|
|
|
{ x: 340, y: 261 }
|
|
|
|
]));
|
|
|
|
|
|
|
|
expect(sequenceFlow).to.have.endDocking({ x: 340, y: 299 });
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should connect start -> target', inject(
|
|
|
|
function(modeling, elementRegistry, selection, move, dragging) {
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// given
|
|
|
|
var endEventShape = elementRegistry.get('EndEvent_foo');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
sequenceFlowGfx = elementRegistry.getGraphics(sequenceFlow),
|
|
|
|
originalWaypoints = sequenceFlow.waypoints;
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// when
|
|
|
|
selection.select(endEventShape);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), endEventShape);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.hover({
|
|
|
|
element: sequenceFlow,
|
|
|
|
gfx: sequenceFlowGfx
|
|
|
|
});
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.move(canvasEvent({ x: 150, y: 0 }));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.end();
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// then
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// new incoming connection
|
|
|
|
expect(endEventShape.incoming.length).to.equal(1);
|
|
|
|
expect(endEventShape.incoming[0]).to.eql(sequenceFlow);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// no outgoing edges
|
|
|
|
expect(endEventShape.outgoing.length).to.equal(0);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
originalWaypoints.slice(0, 2),
|
|
|
|
{ x: 340, y: 281 }
|
|
|
|
]));
|
|
|
|
}
|
|
|
|
));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should connect target -> end', inject(
|
|
|
|
function(modeling, elementRegistry, dragging, selection, move) {
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
var startEventShape = elementRegistry.get('StartEvent_foo');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
sequenceFlowGfx = elementRegistry.getGraphics(sequenceFlow),
|
|
|
|
originalWaypoints = sequenceFlow.waypoints;
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// when
|
|
|
|
selection.select(startEventShape);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), startEventShape);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.hover({
|
|
|
|
element: sequenceFlow,
|
|
|
|
gfx: sequenceFlowGfx
|
|
|
|
});
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.move(canvasEvent({ x: -215, y: 0 }));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.end();
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// then
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// no incoming connection
|
|
|
|
expect(startEventShape.incoming.length).to.equal(0);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// 1 outgoing connection
|
|
|
|
expect(startEventShape.outgoing.length).to.equal(1);
|
|
|
|
expect(startEventShape.outgoing[0]).to.eql(sequenceFlow);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([
|
|
|
|
{ x: 338, y: 228 },
|
|
|
|
originalWaypoints.slice(2)
|
|
|
|
]));
|
|
|
|
}
|
|
|
|
));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2017-03-01 11:25:33 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should undo', inject(
|
|
|
|
function(modeling, elementRegistry, dragging, selection, move, commandStack) {
|
2017-03-01 11:25:33 +01:00
|
|
|
|
|
|
|
// given
|
|
|
|
var startEventShape = elementRegistry.get('StartEvent_foo');
|
|
|
|
|
2017-03-10 10:38:29 +01:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
2017-03-01 11:25:33 +01:00
|
|
|
sequenceFlowGfx = elementRegistry.getGraphics(sequenceFlow),
|
|
|
|
originalWaypoints = sequenceFlow.waypoints;
|
|
|
|
|
|
|
|
selection.select(startEventShape);
|
|
|
|
|
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), startEventShape);
|
|
|
|
|
|
|
|
dragging.hover({
|
|
|
|
element: sequenceFlow,
|
|
|
|
gfx: sequenceFlowGfx
|
|
|
|
});
|
|
|
|
|
|
|
|
dragging.move(canvasEvent({ x: -215, y: 0 }));
|
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
|
|
|
|
// no incoming connection
|
|
|
|
expect(startEventShape.incoming.length).to.equal(0);
|
|
|
|
|
|
|
|
// no outgoing edges
|
|
|
|
expect(startEventShape.outgoing.length).to.equal(0);
|
|
|
|
|
|
|
|
// split target at insertion point
|
|
|
|
expect(sequenceFlow).to.have.waypoints(flatten([ originalWaypoints ]));
|
2018-01-05 14:32:52 +01:00
|
|
|
}
|
|
|
|
));
|
2017-03-01 11:25:33 +01:00
|
|
|
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
it('should not insert on inaccuratly found intersection', inject(
|
|
|
|
function(dragging, move, elementRegistry, selection) {
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// given
|
|
|
|
var intermediateThrowEvent = elementRegistry.get('IntermediateThrowEvent_foo');
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
sequenceFlowGfx = elementRegistry.getGraphics(sequenceFlow);
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// when
|
|
|
|
selection.select(intermediateThrowEvent);
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), intermediateThrowEvent);
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
dragging.hover({
|
|
|
|
element: sequenceFlow,
|
|
|
|
gfx: sequenceFlowGfx
|
|
|
|
});
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
dragging.move(canvasEvent({ x: 20, y: -90 }));
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
dragging.end();
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// then
|
|
|
|
expect(intermediateThrowEvent.incoming).to.have.lengthOf(0);
|
|
|
|
expect(intermediateThrowEvent.outgoing).to.have.lengthOf(0);
|
|
|
|
}
|
|
|
|
));
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-07-24 16:30:42 +02:00
|
|
|
|
|
|
|
it('should remove redundant flows', inject(
|
|
|
|
function(elementRegistry, selection, move, dragging) {
|
|
|
|
|
|
|
|
var existingIncoming = elementRegistry.get('SequenceFlow_3'),
|
|
|
|
existingOutgoing = elementRegistry.get('SequenceFlow_4');
|
|
|
|
|
|
|
|
// given
|
|
|
|
var element = elementRegistry.get('Task_4');
|
|
|
|
|
|
|
|
var targetFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
targetFlowGfx = elementRegistry.getGraphics(targetFlow);
|
|
|
|
|
|
|
|
// when
|
|
|
|
selection.select(element);
|
|
|
|
|
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), element);
|
|
|
|
|
|
|
|
dragging.hover({
|
|
|
|
element: targetFlow,
|
|
|
|
gfx: targetFlowGfx
|
|
|
|
});
|
|
|
|
|
|
|
|
dragging.move(canvasEvent({ x: -40, y: 179 }));
|
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
// existing connections are removed, as they are duplicates
|
|
|
|
expect(element.incoming).not.to.contain(existingIncoming);
|
|
|
|
expect(element.outgoing).not.to.contain(existingOutgoing);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2017-01-25 17:27:30 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('rules', function() {
|
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
it('should be allowed for an IntermediateThrowEvent', inject(
|
|
|
|
function(elementRegistry, bpmnRules, elementFactory) {
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// when
|
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1');
|
|
|
|
var intermediateThrowEvent = elementFactory.createShape({
|
|
|
|
type: 'bpmn:IntermediateThrowEvent'
|
|
|
|
});
|
2018-02-14 13:36:30 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// then
|
|
|
|
expect(bpmnRules.canCreate(intermediateThrowEvent, sequenceFlow)).to.be.true;
|
|
|
|
}
|
|
|
|
));
|
2018-02-14 13:36:30 +01:00
|
|
|
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should not insert participant', inject(
|
|
|
|
function(rules, elementRegistry, elementFactory) {
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// given
|
2018-02-14 22:20:11 +01:00
|
|
|
var participantShape = elementFactory.createShape({
|
|
|
|
type: 'bpmn:Participant'
|
|
|
|
});
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
var dropPosition = { x: 340, y: 120 }; // first bendpoint
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// when
|
|
|
|
var canDrop = rules.allowed('shape.create', {
|
|
|
|
shape: participantShape,
|
|
|
|
parent: sequenceFlow,
|
|
|
|
dropPosition: dropPosition
|
|
|
|
});
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// then
|
|
|
|
expect(canDrop).to.be.false;
|
|
|
|
}
|
|
|
|
));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
it('should not insert multiple with "move"', inject(
|
|
|
|
function(elementRegistry, selection, move, dragging) {
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// given
|
|
|
|
var intermediateThrowEvent = elementRegistry.get('IntermediateThrowEvent_foo'),
|
|
|
|
endEventShape = elementRegistry.get('EndEvent_foo');
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
sequenceFlowGfx = elementRegistry.getGraphics(sequenceFlow);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
var intInitPosition = {
|
|
|
|
x: intermediateThrowEvent.x,
|
|
|
|
y: intermediateThrowEvent.y
|
|
|
|
},
|
|
|
|
endInitPosition = {
|
|
|
|
x: endEventShape.x,
|
|
|
|
y: endEventShape.y
|
|
|
|
};
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
selection.select([ intermediateThrowEvent, endEventShape ]);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// when
|
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), intermediateThrowEvent);
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.hover({
|
|
|
|
element: sequenceFlow,
|
|
|
|
gfx: sequenceFlowGfx
|
|
|
|
});
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.move(canvasEvent({ x: -215, y: 0 }));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
dragging.end();
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2018-01-05 14:32:52 +01:00
|
|
|
// then
|
|
|
|
expect(intermediateThrowEvent).to.have.position(intInitPosition);
|
|
|
|
expect(endEventShape).to.have.position(endInitPosition);
|
|
|
|
}
|
|
|
|
));
|
2017-01-25 17:27:30 +01:00
|
|
|
|
2017-03-10 10:38:29 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
it('should not insert on sequence flow label', inject(
|
|
|
|
function(bpmnRules, elementRegistry) {
|
2017-03-10 10:38:29 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// given
|
|
|
|
var eventShape = elementRegistry.get('IntermediateThrowEvent_foo'),
|
|
|
|
sequenceFlowLabel = elementRegistry.get('SequenceFlow_2').label;
|
2017-03-10 10:38:29 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
var dropPosition = { x: 675, y: 275 }; // sequence flow label
|
2017-03-10 10:38:29 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// when
|
|
|
|
var canInsert = bpmnRules.canInsert(eventShape, sequenceFlowLabel, dropPosition);
|
2017-03-10 10:38:29 +01:00
|
|
|
|
2018-02-14 22:20:11 +01:00
|
|
|
// then
|
|
|
|
expect(canInsert).to.be.false;
|
|
|
|
}
|
|
|
|
));
|
2018-01-05 14:32:52 +01:00
|
|
|
|
2017-01-25 17:27:30 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
});
|