2018-04-02 21:01:53 +02:00
|
|
|
import {
|
|
|
|
bootstrapModeler,
|
|
|
|
inject
|
|
|
|
} from 'test/TestHelper';
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2021-08-06 10:49:45 +02:00
|
|
|
import {
|
|
|
|
getDi
|
|
|
|
} from 'lib/util/ModelUtil';
|
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
import modelingModule from 'lib/features/modeling';
|
|
|
|
import coreModule from 'lib/core';
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
|
|
|
describe('features/modeling - create connection', function() {
|
|
|
|
|
2015-03-31 14:17:15 +02:00
|
|
|
var diagramXML = require('../../../fixtures/bpmn/sequence-flows.bpmn');
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2014-10-30 12:06:43 +01:00
|
|
|
var testModules = [ coreModule, modelingModule ];
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2014-08-05 08:17:22 +02:00
|
|
|
beforeEach(bootstrapModeler(diagramXML, { modules: testModules }));
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
it('should connect', inject(function(elementRegistry, modeling, bpmnFactory) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var taskShape = elementRegistry.get('Task_1'),
|
|
|
|
task = taskShape.businessObject,
|
2021-08-06 10:49:45 +02:00
|
|
|
taskDi = getDi(taskShape),
|
2016-06-22 14:38:44 +02:00
|
|
|
gatewayShape = elementRegistry.get('Gateway_1'),
|
|
|
|
gateway = gatewayShape.businessObject;
|
|
|
|
|
|
|
|
// when
|
|
|
|
var sequenceFlowConnection = modeling.createConnection(taskShape, gatewayShape, {
|
|
|
|
type: 'bpmn:SequenceFlow'
|
|
|
|
}, taskShape.parent);
|
|
|
|
|
2021-08-06 10:49:45 +02:00
|
|
|
var sequenceFlow = sequenceFlowConnection.businessObject,
|
|
|
|
sequenceFlowDi = getDi(sequenceFlowConnection);
|
2016-06-22 14:38:44 +02:00
|
|
|
|
|
|
|
// then
|
|
|
|
expect(sequenceFlowConnection).to.exist;
|
|
|
|
expect(sequenceFlow).to.exist;
|
|
|
|
|
|
|
|
expect(sequenceFlow.sourceRef).to.eql(task);
|
|
|
|
expect(sequenceFlow.targetRef).to.eql(gateway);
|
|
|
|
|
|
|
|
expect(task.outgoing).to.include(sequenceFlow);
|
|
|
|
expect(gateway.incoming).to.include(sequenceFlow);
|
|
|
|
|
2021-08-06 10:49:45 +02:00
|
|
|
expect(sequenceFlowDi.$parent).to.eql(taskDi.$parent);
|
|
|
|
expect(sequenceFlowDi.$parent.planeElement).to.include(sequenceFlowDi);
|
2016-06-22 14:38:44 +02:00
|
|
|
|
|
|
|
// expect cropped connection
|
|
|
|
expect(sequenceFlowConnection.waypoints).eql([
|
|
|
|
{ original: { x: 242, y: 376 }, x: 292, y: 376 },
|
|
|
|
{ x: 410, y: 376 },
|
|
|
|
{ x: 410, y: 341 },
|
|
|
|
{ original: { x: 553, y: 341 }, x: 528, y: 341 }
|
|
|
|
]);
|
|
|
|
|
|
|
|
var diWaypoints = bpmnFactory.createDiWaypoints([
|
|
|
|
{ x: 292, y: 376 },
|
|
|
|
{ x: 410, y: 376 },
|
|
|
|
{ x: 410, y: 341 },
|
|
|
|
{ x: 528, y: 341 }
|
|
|
|
]);
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// expect cropped waypoints in di
|
2021-08-06 10:49:45 +02:00
|
|
|
expect(sequenceFlowDi.waypoint).eql(diWaypoints);
|
2016-06-22 14:38:44 +02:00
|
|
|
}));
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
it('should connect with custom start / end', inject(function(elementRegistry, modeling) {
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// given
|
|
|
|
var sourceShape = elementRegistry.get('Task_2'),
|
|
|
|
sourcePosition = {
|
|
|
|
x: 740,
|
|
|
|
y: 400
|
|
|
|
},
|
|
|
|
targetShape = elementRegistry.get('Task_3'),
|
|
|
|
targetPosition = {
|
|
|
|
x: 420,
|
|
|
|
y: 130
|
|
|
|
};
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// when
|
|
|
|
var newConnection = modeling.connect(
|
|
|
|
sourceShape, targetShape,
|
|
|
|
null,
|
|
|
|
{
|
|
|
|
connectionStart: sourcePosition,
|
|
|
|
connectionEnd: targetPosition
|
|
|
|
}
|
|
|
|
);
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// then
|
|
|
|
// expect cropped connection with custom start/end
|
|
|
|
expect(newConnection).to.have.waypoints([
|
2017-12-13 14:05:29 +01:00
|
|
|
{ x: 734, y: 400 },
|
2016-06-22 14:38:44 +02:00
|
|
|
{ x: 590, y: 400 },
|
|
|
|
{ x: 590, y: 130 },
|
2017-12-13 14:05:29 +01:00
|
|
|
{ x: 447, y: 130 }
|
2016-06-22 14:38:44 +02:00
|
|
|
]);
|
|
|
|
}));
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
it('should undo', inject(function(elementRegistry, commandStack, modeling) {
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// given
|
|
|
|
var taskShape = elementRegistry.get('Task_1'),
|
|
|
|
task = taskShape.businessObject,
|
|
|
|
gatewayShape = elementRegistry.get('Gateway_1'),
|
|
|
|
gateway = gatewayShape.businessObject;
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
var sequenceFlowConnection = modeling.createConnection(taskShape, gatewayShape, {
|
|
|
|
type: 'bpmn:SequenceFlow'
|
|
|
|
}, taskShape.parent);
|
2015-07-15 17:22:19 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
var sequenceFlow = sequenceFlowConnection.businessObject;
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// when
|
|
|
|
commandStack.undo();
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// then
|
|
|
|
expect(sequenceFlow.$parent).to.be.null;
|
|
|
|
expect(sequenceFlow.sourceRef).to.be.null;
|
|
|
|
expect(sequenceFlow.targetRef).to.be.null;
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
expect(task.outgoing).not.to.include(sequenceFlow);
|
|
|
|
expect(gateway.incoming).not.to.include(sequenceFlow);
|
|
|
|
}));
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
it('should redo', inject(function(elementRegistry, commandStack, modeling) {
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// given
|
|
|
|
var taskShape = elementRegistry.get('Task_1'),
|
|
|
|
task = taskShape.businessObject,
|
2021-08-06 10:49:45 +02:00
|
|
|
taskDi = getDi(taskShape),
|
2016-06-22 14:38:44 +02:00
|
|
|
gatewayShape = elementRegistry.get('Gateway_1'),
|
|
|
|
gateway = gatewayShape.businessObject;
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
var sequenceFlowConnection = modeling.createConnection(taskShape, gatewayShape, {
|
|
|
|
type: 'bpmn:SequenceFlow'
|
|
|
|
}, taskShape.parent);
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2021-08-06 10:49:45 +02:00
|
|
|
var sequenceFlow = sequenceFlowConnection.businessObject,
|
|
|
|
sequenceFlowDi = getDi(sequenceFlowConnection);
|
2016-06-22 14:38:44 +02:00
|
|
|
|
|
|
|
var newWaypoints = sequenceFlowConnection.waypoints,
|
2021-08-06 10:49:45 +02:00
|
|
|
newDiWaypoints = sequenceFlowDi.waypoint;
|
2016-06-22 14:38:44 +02:00
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// then
|
|
|
|
expect(sequenceFlow.sourceRef).to.eql(task);
|
|
|
|
expect(sequenceFlow.targetRef).to.eql(gateway);
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
expect(task.outgoing).to.include(sequenceFlow);
|
|
|
|
expect(gateway.incoming).to.include(sequenceFlow);
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2021-08-06 10:49:45 +02:00
|
|
|
expect(sequenceFlowDi.$parent).to.eql(taskDi.$parent);
|
|
|
|
expect(sequenceFlowDi.$parent.planeElement).to.include(sequenceFlowDi);
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// expect cropped connection
|
|
|
|
expect(sequenceFlowConnection.waypoints).eql(newWaypoints);
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2016-06-22 14:38:44 +02:00
|
|
|
// expect cropped waypoints in di
|
2021-08-06 10:49:45 +02:00
|
|
|
expect(sequenceFlowDi.waypoint).eql(newDiWaypoints);
|
2016-06-22 14:38:44 +02:00
|
|
|
}));
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2015-07-15 17:22:19 +02:00
|
|
|
});
|