mirror of
https://github.com/sartography/bpmn-js.git
synced 2025-01-09 16:45:49 +00:00
556 lines
14 KiB
JavaScript
556 lines
14 KiB
JavaScript
import {
|
|
bootstrapModeler,
|
|
inject
|
|
} from 'test/TestHelper';
|
|
|
|
import {
|
|
connect,
|
|
element,
|
|
move,
|
|
reconnectEnd
|
|
} from './Helper';
|
|
|
|
import { getMid } from 'diagram-js/lib/layout/LayoutUtil';
|
|
|
|
import modelingModule from 'lib/features/modeling';
|
|
import coreModule from 'lib/core';
|
|
|
|
|
|
describe('features/modeling - layout', function() {
|
|
|
|
describe('boundary events', function() {
|
|
|
|
describe('loops', function() {
|
|
|
|
var diagramXML = require('./LayoutSequenceFlowSpec.boundaryEventsLoops.bpmn');
|
|
|
|
var testModules = [ coreModule, modelingModule ];
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, { modules: testModules }));
|
|
|
|
|
|
describe('in the corner', function() {
|
|
|
|
it('attached top right', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_TopRight', 'SubProcess');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 550, y: 200 }, x: 550, y: 182 },
|
|
{ x: 550, y: 162 },
|
|
{ x: 375, y: 162 },
|
|
{ original: { x: 375, y: 300 }, x: 375, y: 200 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached bottom right', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_BottomRight', 'SubProcess');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 550, y: 368 } , x: 568, y: 368 },
|
|
{ x: 588, y: 368 },
|
|
{ x: 588, y: 300 },
|
|
{ original: { x: 375, y: 300 } , x: 550, y: 300 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached bottom left', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_BottomLeft', 'SubProcess');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 200, y: 500 }, x: 200, y: 418 },
|
|
{ x: 200, y: 438 },
|
|
{ x: 375, y: 438 },
|
|
{ original: { x: 375, y: 300 }, x: 375, y: 400 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached top left', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_TopLeft', 'SubProcess');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 200, y: 238 }, x: 182, y: 238 },
|
|
{ x: 162, y: 238 },
|
|
{ x: 162, y: 300 },
|
|
{ original: { x: 375, y: 300 }, x: 200, y: 300 }
|
|
]);
|
|
});
|
|
});
|
|
|
|
|
|
describe('on the side center', function() {
|
|
|
|
var host = 'SubProcess_2';
|
|
|
|
|
|
it('attached top center', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_TopCenter', host);
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 375, y: 460 }, x: 375, y: 442 },
|
|
{ x:375, y: 422 },
|
|
{ x:180, y: 422 },
|
|
{ x:180, y: 560 },
|
|
{ original:{ x: 375, y: 560 }, x: 200, y: 560 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached center right', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_CenterRight', host);
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 550, y: 560 }, x: 568, y: 560 },
|
|
{ x: 588, y: 560 },
|
|
{ x: 588, y: 680 },
|
|
{ x: 375, y: 680 },
|
|
{ original: { x: 375, y: 560 }, x: 375, y: 660 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached bottom center', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_BottomCenter', host);
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 375, y: 660 }, x: 375, y: 678 },
|
|
{ x: 375, y: 698 },
|
|
{ x: 180, y: 698 },
|
|
{ x: 180, y: 560 },
|
|
{ original: { x: 375, y: 560 }, x: 200, y: 560 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached center left', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_CenterLeft', host);
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 200, y: 560 }, x: 182, y: 560 },
|
|
{ x: 162, y: 560 },
|
|
{ x: 162, y: 680 },
|
|
{ x: 375, y: 680 },
|
|
{ original: { x: 375, y: 560 }, x: 375, y: 660 }
|
|
]);
|
|
});
|
|
});
|
|
});
|
|
|
|
|
|
describe('non-loops', function() {
|
|
|
|
var diagramXML = require('./LayoutSequenceFlowSpec.boundaryEvents.bpmn');
|
|
|
|
var testModules = [ coreModule, modelingModule ];
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, { modules: testModules }));
|
|
|
|
|
|
it('attached top right, orientation top', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_TopRight', 'Task_Top');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 650, y: 300 }, x: 650, y: 282 },
|
|
{ x: 650, y: 40 },
|
|
{ original: { x: 450, y: 40 }, x: 500, y: 40 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached top right, orientation right', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_TopRight', 'Task_Right');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 650, y: 300 }, x: 668, y: 300 },
|
|
{ x: 900, y: 300 },
|
|
{ original: { x: 900, y: 390 }, x: 900, y: 350 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached top right, orientation bottom', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_TopRight', 'Task_Bottom');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 650, y: 300 }, x: 650, y: 282 },
|
|
{ x: 650, y: 262 },
|
|
{ x: 450, y: 262 },
|
|
{ original: { x: 450, y: 690 }, x: 450, y: 650 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached top right, orientation left', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_TopRight', 'Task_Left');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 650, y: 300 }, x: 650, y: 282 },
|
|
{ x: 650, y: 262 },
|
|
{ x: 50, y: 262 },
|
|
{ original: { x: 50, y: 390 }, x: 50, y: 350 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached bottom center, orientation bottom', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_BottomCenter', 'Task_Bottom');
|
|
|
|
expect(connection).to.have.waypoints([
|
|
{ x: 450, y: 518 },
|
|
{ x: 450, y: 650 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached top center, orientation top', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_TopCenter', 'Task_Top');
|
|
|
|
expect(connection).to.have.waypoints([
|
|
{ x: 450, y: 282 },
|
|
{ x: 450, y: 80 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached right center, orientation right', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_RightCenter', 'Task_Right');
|
|
|
|
expect(connection).to.have.waypoints([
|
|
{ x: 668, y: 390 },
|
|
{ x: 850, y: 390 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('attached right center, orientation left', function() {
|
|
|
|
// when
|
|
var connection = connect('BoundaryEvent_RightCenter', 'Task_Left');
|
|
|
|
expect(connection).to.have.waypoints([
|
|
{ x: 668, y: 390 },
|
|
{ x: 688, y: 390 },
|
|
{ x: 688, y: 410 },
|
|
{ x: 536, y: 410 },
|
|
{ x: 536, y: 390 },
|
|
{ x: 100, y: 390 }
|
|
]);
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
describe('flow elements', function() {
|
|
|
|
var diagramXML = require('./LayoutSequenceFlowSpec.flowElements.bpmn');
|
|
|
|
var testModules = [ coreModule, modelingModule ];
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, { modules: testModules }));
|
|
|
|
|
|
describe('loops', function() {
|
|
|
|
it('should layout loop', function() {
|
|
|
|
// when
|
|
var connection = connect('Task_1', 'Task_1');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ x: 332, y: 260 },
|
|
{ x: 332, y: 280 },
|
|
{ x: 262, y: 280 },
|
|
{ x: 262, y: 220 },
|
|
{ x: 282, y: 220 }
|
|
]);
|
|
});
|
|
|
|
|
|
it('should NOT relayout loop', inject(function(elementRegistry) {
|
|
|
|
// given
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
task = elementRegistry.get('Task_1');
|
|
|
|
// when
|
|
reconnectEnd(sequenceFlow, task, getMid(task));
|
|
|
|
// then
|
|
expect(sequenceFlow).to.have.waypoints([
|
|
{ x: 382, y: 241 },
|
|
{ x: 559, y: 241 },
|
|
{ x: 559, y: 220 },
|
|
{ x: 382, y: 220 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should relayout loop (b:l)', inject(function(elementRegistry) {
|
|
|
|
// given
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_2'),
|
|
task = elementRegistry.get('Task_1');
|
|
|
|
// when
|
|
reconnectEnd(sequenceFlow, task, getMid(task));
|
|
|
|
// then
|
|
expect(sequenceFlow).to.have.waypoints([
|
|
{ x: 332, y: 260 },
|
|
{ x: 332, y: 280 },
|
|
{ x: 262, y: 280 },
|
|
{ x: 262, y: 220 },
|
|
{ x: 282, y: 220 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should relayout loop (l:t)', inject(function(elementRegistry) {
|
|
|
|
// given
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_3'),
|
|
task = elementRegistry.get('Task_1');
|
|
|
|
// when
|
|
reconnectEnd(sequenceFlow, task, getMid(task));
|
|
|
|
// then
|
|
expect(sequenceFlow).to.have.waypoints([
|
|
{ x: 282, y: 220 },
|
|
{ x: 262, y: 220 },
|
|
{ x: 262, y: 160 },
|
|
{ x: 332, y: 160 },
|
|
{ x: 332, y: 180 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should relayout loop (t:r)', inject(function(elementRegistry) {
|
|
|
|
// given
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_4'),
|
|
task = elementRegistry.get('Task_1');
|
|
|
|
// when
|
|
reconnectEnd(sequenceFlow, task, getMid(task));
|
|
|
|
// then
|
|
expect(sequenceFlow).to.have.waypoints([
|
|
{ x: 332, y: 180 },
|
|
{ x: 332, y: 160 },
|
|
{ x: 402, y: 160 },
|
|
{ x: 402, y: 220 },
|
|
{ x: 382, y: 220 }
|
|
]);
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
describe('gateway layout', function() {
|
|
|
|
it('should layout v:h after Gateway', inject(function() {
|
|
|
|
// when
|
|
var connection = connect('ExclusiveGateway_1', 'BusinessRuleTask_1');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 678, y: 302 }, x: 678, y: 277 },
|
|
{ x: 678, y: 220 },
|
|
{ original: { x: 840, y: 220 }, x: 790, y: 220 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should layout h:v before Gateway', inject(function() {
|
|
|
|
// when
|
|
var connection = connect('BusinessRuleTask_1', 'ParallelGateway_1');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 840, y: 220 }, x: 890, y: 220 },
|
|
{ x: 1005, y: 220 },
|
|
{ original: { x: 1005, y: 302 }, x: 1005, y: 277 }
|
|
]);
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
describe('other elements layout', function() {
|
|
|
|
it('should layout h:h after StartEvent', inject(function() {
|
|
|
|
// when
|
|
var connection = connect('StartEvent_1', 'Task_1');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 170, y: 302 }, x: 188, y: 302 },
|
|
{ x: 235, y: 302 },
|
|
{ x: 235, y: 220 },
|
|
{ original: { x: 332, y: 220 }, x: 282, y: 220 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should layout h:h after Task', inject(function() {
|
|
|
|
// when
|
|
var connection = connect('ServiceTask_1', 'BusinessRuleTask_1');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 678, y: 117 }, x: 728, y: 117 },
|
|
{ x: 759, y: 117 },
|
|
{ x: 759, y: 220 },
|
|
{ original: { x: 840, y: 220 }, x: 790, y: 220 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should layout h:h after IntermediateEvent', inject(function() {
|
|
|
|
// when
|
|
var connection = connect('IntermediateThrowEvent_1', 'ServiceTask_1');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 496, y: 302 }, x: 514, y: 302 },
|
|
{ x: 571, y: 302 },
|
|
{ x: 571, y: 117 },
|
|
{ original: { x: 678, y: 117 }, x: 628, y: 117 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should layout h:h after IntermediateEvent (right to left)', inject(function() {
|
|
|
|
// when
|
|
var connection = connect('IntermediateThrowEvent_1', 'Task_1');
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ original: { x: 496, y: 302 }, x: 478, y: 302 },
|
|
{ x: 430, y: 302 },
|
|
{ x: 430, y: 220 },
|
|
{ original: { x: 332, y: 220 }, x: 382, y: 220 }
|
|
]);
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
describe('relayout', function() {
|
|
|
|
it('should repair after reconnect end', inject(function() {
|
|
|
|
// given
|
|
var newDocking = { x: 660, y: 300 };
|
|
var connection = element('SequenceFlow_1');
|
|
|
|
// when
|
|
reconnectEnd(connection, 'ExclusiveGateway_1', newDocking);
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ x: 382, y: 241 },
|
|
{ x: 559, y: 241 },
|
|
{ x: 559, y: 300 },
|
|
{ x: 655, y: 300 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should repair after target move', inject(function() {
|
|
|
|
// given
|
|
var delta = { x: -30, y: 20 };
|
|
var connection = element('SequenceFlow_1');
|
|
|
|
// when
|
|
move('ServiceTask_1', delta);
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ x: 382, y: 241 },
|
|
{ x: 559, y: 241 },
|
|
{ x: 559, y: 158 },
|
|
{ x: 598, y: 158 }
|
|
]);
|
|
}));
|
|
|
|
|
|
it('should repair after source move', inject(function() {
|
|
|
|
// given
|
|
var delta = { x: -30, y: 20 };
|
|
var connection = element('SequenceFlow_1');
|
|
|
|
// when
|
|
move('Task_1', delta);
|
|
|
|
// then
|
|
expect(connection).to.have.waypoints([
|
|
{ x: 352, y: 261 },
|
|
{ x: 559, y: 261 },
|
|
{ x: 559, y: 138 },
|
|
{ x: 628, y: 138 }
|
|
]);
|
|
}));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|