2018-04-02 21:01:53 +02:00
|
|
|
import {
|
|
|
|
bootstrapModeler,
|
|
|
|
inject
|
|
|
|
} from 'test/TestHelper';
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
import modelingModule from 'lib/features/modeling';
|
|
|
|
import coreModule from 'lib/core';
|
2019-05-03 15:15:40 +02:00
|
|
|
|
2019-05-09 10:14:27 +02:00
|
|
|
import bendpointsModule from 'diagram-js/lib/features/bendpoints';
|
2019-05-17 13:11:17 +02:00
|
|
|
import connectionPreviewModule from 'diagram-js/lib/features/connection-preview';
|
2019-05-13 16:09:14 +02:00
|
|
|
import connectModule from 'diagram-js/lib/features/connect';
|
|
|
|
import createModule from 'diagram-js/lib/features/create';
|
2019-05-09 16:12:25 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
import {
|
|
|
|
createCanvasEvent as canvasEvent
|
|
|
|
} from '../../../../util/MockEvents';
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
|
|
|
describe('features/modeling - layout connection', function() {
|
|
|
|
|
2015-07-29 15:11:54 +02:00
|
|
|
var diagramXML = require('../../../../fixtures/bpmn/sequence-flows.bpmn');
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2017-12-10 12:29:54 +01:00
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: [
|
2019-05-17 13:11:17 +02:00
|
|
|
bendpointsModule,
|
|
|
|
connectionPreviewModule,
|
2019-05-09 16:12:25 +02:00
|
|
|
connectModule,
|
2019-05-17 13:11:17 +02:00
|
|
|
coreModule,
|
2019-05-09 10:14:27 +02:00
|
|
|
createModule,
|
2019-05-17 13:11:17 +02:00
|
|
|
modelingModule
|
2017-12-10 12:29:54 +01:00
|
|
|
]
|
|
|
|
}));
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
|
2017-12-10 12:29:54 +01:00
|
|
|
describe('should not touch already layouted', function() {
|
2014-07-30 16:06:32 +02:00
|
|
|
|
2017-12-10 12:29:54 +01:00
|
|
|
it('execute', inject(function(elementRegistry, modeling, bpmnFactory) {
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
// given
|
2014-11-17 17:36:22 +01:00
|
|
|
var sequenceFlowConnection = elementRegistry.get('SequenceFlow_1'),
|
2014-07-30 16:06:32 +02:00
|
|
|
sequenceFlow = sequenceFlowConnection.businessObject;
|
|
|
|
|
2016-06-26 23:42:11 +02:00
|
|
|
var expectedWaypoints = sequenceFlowConnection.waypoints;
|
|
|
|
|
2014-07-30 16:06:32 +02:00
|
|
|
// when
|
|
|
|
modeling.layoutConnection(sequenceFlowConnection);
|
|
|
|
|
|
|
|
// then
|
|
|
|
|
2014-09-04 13:47:11 +02:00
|
|
|
// expect cropped, repaired connection
|
2015-04-22 09:08:38 +02:00
|
|
|
// that was not actually modified
|
2015-08-24 11:28:54 +02:00
|
|
|
|
2016-06-26 23:42:11 +02:00
|
|
|
expect(sequenceFlowConnection.waypoints).to.eql(expectedWaypoints);
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
// expect cropped waypoints in di
|
2016-06-26 23:42:11 +02:00
|
|
|
var diWaypoints = bpmnFactory.createDiWaypoints(expectedWaypoints);
|
2015-07-15 17:22:19 +02:00
|
|
|
|
|
|
|
expect(sequenceFlow.di.waypoint).eql(diWaypoints);
|
2014-07-30 16:06:32 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
2017-12-10 12:29:54 +01:00
|
|
|
it('undo', inject(function(elementRegistry, commandStack, modeling) {
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
// given
|
2014-11-17 17:36:22 +01:00
|
|
|
var sequenceFlowConnection = elementRegistry.get('SequenceFlow_1'),
|
2014-07-30 16:06:32 +02:00
|
|
|
sequenceFlow = sequenceFlowConnection.businessObject;
|
|
|
|
|
|
|
|
var oldWaypoints = sequenceFlowConnection.waypoints,
|
|
|
|
oldDiWaypoints = sequenceFlow.di.waypoint;
|
|
|
|
|
|
|
|
modeling.layoutConnection(sequenceFlowConnection);
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// then
|
2015-07-15 17:22:19 +02:00
|
|
|
expect(sequenceFlowConnection.waypoints).eql(oldWaypoints);
|
|
|
|
expect(sequenceFlow.di.waypoint).eql(oldDiWaypoints);
|
2014-07-30 16:06:32 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
2017-12-10 12:29:54 +01:00
|
|
|
it('redo', inject(function(elementRegistry, commandStack, modeling) {
|
2014-07-30 16:06:32 +02:00
|
|
|
|
|
|
|
// given
|
2014-11-17 17:36:22 +01:00
|
|
|
var sequenceFlowConnection = elementRegistry.get('SequenceFlow_1'),
|
2014-07-30 16:06:32 +02:00
|
|
|
sequenceFlow = sequenceFlowConnection.businessObject;
|
|
|
|
|
|
|
|
modeling.layoutConnection(sequenceFlowConnection);
|
|
|
|
|
|
|
|
var newWaypoints = sequenceFlowConnection.waypoints,
|
|
|
|
newDiWaypoints = sequenceFlow.di.waypoint;
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
2015-07-15 17:22:19 +02:00
|
|
|
expect(sequenceFlowConnection.waypoints).eql(newWaypoints);
|
|
|
|
expect(sequenceFlow.di.waypoint).eql(newDiWaypoints);
|
2014-07-30 16:06:32 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2017-12-10 12:29:54 +01:00
|
|
|
|
|
|
|
it('should remove un-needed waypoints', inject(function(elementRegistry, modeling) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var taskShape = elementRegistry.get('Task_2'),
|
|
|
|
sequenceFlowConnection = elementRegistry.get('SequenceFlow_1');
|
|
|
|
|
|
|
|
// when
|
|
|
|
// moving task
|
|
|
|
modeling.moveElements([ taskShape ], { x: 250, y: -95 });
|
|
|
|
|
|
|
|
// then
|
|
|
|
var newWaypoints = sequenceFlowConnection.waypoints;
|
|
|
|
|
|
|
|
expect(newWaypoints.map(toPoint)).to.eql([
|
|
|
|
{ x: 578, y: 341 },
|
|
|
|
{ x: 982, y: 341 }
|
|
|
|
]);
|
|
|
|
}));
|
|
|
|
|
2019-04-18 14:22:21 +02:00
|
|
|
|
|
|
|
describe('integration', function() {
|
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
describe('re-connection', function() {
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
it('should correctly layout after start re-connection', inject(function(elementRegistry, modeling) {
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
// given
|
|
|
|
var task1 = elementRegistry.get('Task_1'),
|
|
|
|
connection = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
docking = { x: 292, y: 376 };
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
// when
|
|
|
|
modeling.reconnectStart(connection, task1, docking);
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
// then
|
|
|
|
var waypoints = connection.waypoints,
|
|
|
|
i,
|
|
|
|
first,
|
|
|
|
second;
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
for (i = 0; i < waypoints.length - 1; i++) {
|
|
|
|
first = waypoints[i];
|
|
|
|
second = waypoints[i + 1];
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
expect(areOnSameAxis(first, second), 'points are on different axes').to.be.true;
|
|
|
|
}
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
}));
|
2019-04-18 14:22:21 +02:00
|
|
|
|
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
it('should correctly layout after end re-connection', inject(function(elementRegistry, modeling) {
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
// given
|
|
|
|
var task1 = elementRegistry.get('Task_1'),
|
|
|
|
connection = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
docking = { x: 292, y: 376 };
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
// when
|
|
|
|
modeling.reconnectEnd(connection, task1, docking);
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
// then
|
|
|
|
var waypoints = connection.waypoints,
|
|
|
|
i,
|
|
|
|
first,
|
|
|
|
second;
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
for (i = 0; i < waypoints.length - 1; i++) {
|
|
|
|
first = waypoints[i];
|
|
|
|
second = waypoints[i + 1];
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
expect(areOnSameAxis(first, second), 'points are on different axes').to.be.true;
|
|
|
|
}
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('connection preview', function() {
|
|
|
|
|
|
|
|
var task;
|
|
|
|
|
|
|
|
beforeEach(inject(function(elementFactory, dragging) {
|
|
|
|
task = elementFactory.createShape({
|
|
|
|
type: 'bpmn:Task'
|
|
|
|
});
|
|
|
|
|
|
|
|
dragging.setOptions({ manual: true });
|
|
|
|
}));
|
|
|
|
|
|
|
|
afterEach(inject(function(dragging) {
|
|
|
|
dragging.setOptions({ manual: false });
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
2019-05-09 10:14:27 +02:00
|
|
|
it('should correctly lay out connection preview on create',
|
2019-05-03 15:15:40 +02:00
|
|
|
inject(function(canvas, create, dragging, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var rootShape = canvas.getRootElement(),
|
|
|
|
rootShapeGfx = canvas.getGraphics(rootShape),
|
|
|
|
task1 = elementRegistry.get('Task_1');
|
|
|
|
|
|
|
|
// when
|
|
|
|
create.start(canvasEvent({ x: 0, y: 0 }), task, task1);
|
|
|
|
|
|
|
|
dragging.move(canvasEvent({ x: 175, y: 175 }));
|
|
|
|
dragging.hover({ element: rootShape, gfx: rootShapeGfx });
|
|
|
|
dragging.move(canvasEvent({ x: 200, y: 200 }));
|
|
|
|
|
|
|
|
var ctx = dragging.context();
|
|
|
|
var context = ctx.data.context;
|
|
|
|
|
2019-05-09 14:24:12 +02:00
|
|
|
var connectionPreview = context.getConnection(
|
|
|
|
context.canExecute.connect,
|
|
|
|
context.source,
|
|
|
|
context.shape
|
|
|
|
);
|
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
var waypointsPreview = connectionPreview.waypoints.slice();
|
|
|
|
|
|
|
|
dragging.end();
|
2019-04-18 14:22:21 +02:00
|
|
|
|
2019-05-03 15:15:40 +02:00
|
|
|
// then
|
|
|
|
expect(task1.outgoing[0]).to.exist;
|
|
|
|
expect(task1.outgoing[0].waypoints).to.deep.eql(waypointsPreview);
|
|
|
|
})
|
|
|
|
);
|
2019-05-09 16:12:25 +02:00
|
|
|
|
|
|
|
|
|
|
|
it('should correctly lay out new connection preview',
|
|
|
|
inject(function(connect, dragging, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task1 = elementRegistry.get('Task_1'),
|
|
|
|
task2 = elementRegistry.get('Task_2');
|
|
|
|
|
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 0, y: 0 }), task1);
|
|
|
|
|
|
|
|
dragging.move(canvasEvent({ x: 760, y: 420 }));
|
|
|
|
dragging.hover({ element: task2 });
|
|
|
|
dragging.move(canvasEvent({ x: 782, y: 436 }));
|
|
|
|
|
|
|
|
var ctx = dragging.context();
|
|
|
|
var context = ctx.data.context;
|
|
|
|
|
|
|
|
var connectionPreview = context.getConnection(
|
|
|
|
context.canExecute,
|
|
|
|
context.source,
|
|
|
|
context.target
|
|
|
|
);
|
|
|
|
|
|
|
|
var waypointsPreview = connectionPreview.waypoints.slice();
|
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(task1.outgoing[0]).to.exist;
|
|
|
|
expect(task1.outgoing[0].waypoints).to.deep.eql(waypointsPreview);
|
|
|
|
})
|
|
|
|
);
|
2019-05-09 10:14:27 +02:00
|
|
|
|
|
|
|
|
|
|
|
it('should correctly lay out connection preview on reconnect start',
|
|
|
|
inject(function(canvas, bendpointMove, dragging, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task1 = elementRegistry.get('Task_1'),
|
|
|
|
task1Gfx = canvas.getGraphics(task1),
|
|
|
|
sequenceFlow2 = elementRegistry.get('SequenceFlow_2');
|
|
|
|
|
|
|
|
// when
|
|
|
|
bendpointMove.start(canvasEvent({ x: 0, y: 0 }), sequenceFlow2, 0);
|
|
|
|
|
|
|
|
dragging.move(canvasEvent({ x: 230, y: 360 }));
|
|
|
|
dragging.hover({ element: task1, gfx: task1Gfx });
|
|
|
|
dragging.move(canvasEvent({ x: 248, y: 382 }));
|
|
|
|
|
|
|
|
var ctx = dragging.context();
|
|
|
|
var context = ctx.data.context;
|
|
|
|
|
2019-05-13 16:09:14 +02:00
|
|
|
var connectionPreview = context.getConnection(
|
|
|
|
context.allowed,
|
|
|
|
context.source,
|
|
|
|
context.target
|
|
|
|
);
|
|
|
|
|
2019-05-09 10:14:27 +02:00
|
|
|
var waypointsPreview = connectionPreview.waypoints.slice();
|
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(task1.outgoing[0]).to.exist;
|
|
|
|
expect(task1.outgoing[0].waypoints).to.deep.eql(waypointsPreview);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
it('should correctly lay out connection preview on reconnect end',
|
|
|
|
inject(function(canvas, bendpointMove, dragging, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task1 = elementRegistry.get('Task_1'),
|
|
|
|
task1Gfx = canvas.getGraphics(task1),
|
|
|
|
sequenceFlow2 = elementRegistry.get('SequenceFlow_2');
|
|
|
|
|
|
|
|
// when
|
|
|
|
bendpointMove.start(canvasEvent({ x: 0, y: 0 }), sequenceFlow2, 2);
|
|
|
|
|
|
|
|
dragging.move(canvasEvent({ x: 230, y: 360 }));
|
|
|
|
dragging.hover({ element: task1, gfx: task1Gfx });
|
|
|
|
dragging.move(canvasEvent({ x: 248, y: 382 }));
|
|
|
|
|
|
|
|
var ctx = dragging.context();
|
|
|
|
var context = ctx.data.context;
|
|
|
|
|
2019-05-13 16:09:14 +02:00
|
|
|
var connectionPreview = context.getConnection(
|
|
|
|
context.allowed,
|
|
|
|
context.source,
|
|
|
|
context.target
|
|
|
|
);
|
|
|
|
|
2019-05-09 10:14:27 +02:00
|
|
|
var waypointsPreview = connectionPreview.waypoints.slice();
|
|
|
|
|
|
|
|
dragging.end();
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(task1.incoming[0]).to.exist;
|
|
|
|
expect(task1.incoming[0].waypoints).to.deep.eql(waypointsPreview);
|
|
|
|
})
|
|
|
|
);
|
2019-05-03 15:15:40 +02:00
|
|
|
});
|
2019-04-18 14:22:21 +02:00
|
|
|
});
|
|
|
|
|
2015-07-15 17:22:19 +02:00
|
|
|
});
|
2017-12-10 12:29:54 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2018-02-27 09:57:22 +01:00
|
|
|
// helpers //////////////////////
|
2017-12-10 12:29:54 +01:00
|
|
|
|
|
|
|
function toPoint(p) {
|
|
|
|
return {
|
|
|
|
x: p.x,
|
|
|
|
y: p.y
|
|
|
|
};
|
2019-04-18 14:22:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function areOnSameAxis(a, b) {
|
|
|
|
return a.x === b.x || a.y === b.y;
|
2017-12-10 12:29:54 +01:00
|
|
|
}
|