2018-04-02 19:01:53 +00:00
|
|
|
import {
|
|
|
|
bootstrapModeler,
|
|
|
|
inject
|
|
|
|
} from 'test/TestHelper';
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2021-08-06 08:49:45 +00:00
|
|
|
import { getDi } from 'lib/util/ModelUtil';
|
|
|
|
|
2022-01-26 13:27:54 +00:00
|
|
|
import { pick } from 'min-dash';
|
|
|
|
|
2018-04-02 19:01:53 +00:00
|
|
|
import coreModule from 'lib/core';
|
2022-01-26 13:27:54 +00:00
|
|
|
import modelingModule from 'lib/features/modeling';
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2022-01-26 13:27:54 +00:00
|
|
|
var testModules = [ coreModule, modelingModule ];
|
2018-05-16 06:57:33 +00:00
|
|
|
|
2016-10-28 15:42:42 +00:00
|
|
|
|
|
|
|
describe('features - bpmn-updater', function() {
|
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
describe('connection di', function() {
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
var diagramXML = require('./BpmnUpdater.bpmn');
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: testModules
|
|
|
|
}));
|
2016-10-28 15:42:42 +00:00
|
|
|
|
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
it('should update after deleting intermediate element', inject(
|
|
|
|
function(modeling, elementRegistry) {
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
// given
|
|
|
|
// sequence flow with existing sourceElement and targetElement di information
|
|
|
|
var task = elementRegistry.get('Task_1'),
|
2021-08-06 08:49:45 +00:00
|
|
|
sequenceFlowDi = getDi(elementRegistry.get('SequenceFlow_1')),
|
|
|
|
startEventDi = getDi(elementRegistry.get('StartEvent_1')),
|
|
|
|
endEventDi = getDi(elementRegistry.get('EndEvent_1'));
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
// when
|
|
|
|
modeling.removeElements([ task ]);
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
// then
|
|
|
|
expect(sequenceFlowDi.sourceElement).to.equal(startEventDi);
|
|
|
|
expect(sequenceFlowDi.targetElement).to.equal(endEventDi);
|
|
|
|
}
|
|
|
|
));
|
2016-10-28 15:42:42 +00:00
|
|
|
|
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
it('should update on drop on flow', inject(
|
|
|
|
function(modeling, elementRegistry, elementFactory) {
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
// given
|
|
|
|
// sequence flow with existing sourceElement and targetElement di information
|
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_3'),
|
2021-08-06 08:49:45 +00:00
|
|
|
startEventDi = getDi(elementRegistry.get('StartEvent_2')),
|
|
|
|
sequenceFlowDi = getDi(sequenceFlow);
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
var intermediateThrowEvent = elementFactory.createShape({
|
|
|
|
type: 'bpmn:IntermediateThrowEvent'
|
|
|
|
});
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
var dropPosition = { x: 320, y: 260 };
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
// when
|
|
|
|
var event = modeling.createShape(intermediateThrowEvent, dropPosition, sequenceFlow);
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
// then
|
2021-08-06 08:49:45 +00:00
|
|
|
expect(sequenceFlowDi.sourceElement).to.equal(startEventDi);
|
|
|
|
expect(sequenceFlowDi.targetElement).to.equal(getDi(event));
|
2018-05-16 06:57:33 +00:00
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
|
|
it('should not create new di refs', inject(
|
|
|
|
function(modeling, elementRegistry, elementFactory) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
// sequence flow without any sourceElement and targetElement di information
|
2021-08-06 08:49:45 +00:00
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_4'),
|
|
|
|
sequenceFlowDi = getDi(sequenceFlow);
|
2018-05-16 06:57:33 +00:00
|
|
|
|
|
|
|
var intermediateThrowEvent = elementFactory.createShape({
|
|
|
|
type: 'bpmn:IntermediateThrowEvent'
|
|
|
|
});
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
var dropPosition = { x: 320, y: 260 };
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
// when
|
|
|
|
modeling.createShape(intermediateThrowEvent, dropPosition, sequenceFlow);
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
// then
|
2021-08-06 08:49:45 +00:00
|
|
|
expect(sequenceFlowDi.sourceElement).not.to.exist;
|
|
|
|
expect(sequenceFlowDi.targetElement).not.to.exist;
|
2018-05-16 06:57:33 +00:00
|
|
|
}
|
|
|
|
));
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
2019-04-09 12:06:49 +00:00
|
|
|
describe('connection cropping', function() {
|
|
|
|
|
|
|
|
var diagramXML = require('./BpmnUpdater.bpmn');
|
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: testModules
|
|
|
|
}));
|
|
|
|
|
|
|
|
afterEach(sinon.restore);
|
|
|
|
|
|
|
|
|
|
|
|
it('should crop connection only once per reconnect', inject(
|
|
|
|
function(modeling, elementRegistry, connectionDocking) {
|
2019-08-19 08:39:20 +00:00
|
|
|
|
2019-04-09 12:06:49 +00:00
|
|
|
// given
|
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_1'),
|
|
|
|
target = elementRegistry.get('EndEvent_2'),
|
|
|
|
cropSpy = sinon.spy(connectionDocking, 'getCroppedWaypoints');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.reconnectEnd(sequenceFlow, target, { x: 418, y: 260 });
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(cropSpy).to.have.been.calledOnce;
|
|
|
|
expect(cropSpy).to.have.been.calledWith(sequenceFlow);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2019-12-11 11:02:36 +00:00
|
|
|
|
|
|
|
it('should not crop connection after pasting', inject(
|
|
|
|
function(canvas, copyPaste, elementRegistry, connectionDocking) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var sequenceFlow = elementRegistry.get('SequenceFlow_5'),
|
|
|
|
target = elementRegistry.get('Task_2'),
|
|
|
|
cropSpy = sinon.spy(connectionDocking, 'getCroppedWaypoints');
|
|
|
|
|
|
|
|
copyPaste.copy([
|
|
|
|
target,
|
|
|
|
sequenceFlow
|
|
|
|
]);
|
|
|
|
|
|
|
|
// when
|
|
|
|
copyPaste.paste({
|
|
|
|
element: canvas.getRootElement(),
|
|
|
|
point: {
|
|
|
|
x: 500,
|
|
|
|
y: 500
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(cropSpy).not.to.have.been.calledOnce;
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2019-04-09 12:06:49 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
2018-05-16 11:12:18 +00:00
|
|
|
describe('incomplete DI', function() {
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 11:12:18 +00:00
|
|
|
var diagramXML = require('./BpmnUpdater.incompleteDi.bpmn');
|
2016-10-28 15:42:42 +00:00
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: testModules
|
2016-10-28 15:42:42 +00:00
|
|
|
}));
|
|
|
|
|
2018-05-16 06:57:33 +00:00
|
|
|
|
2018-05-16 11:12:18 +00:00
|
|
|
it('should add missing label bpmndi:Bounds', inject(
|
2018-05-16 06:57:33 +00:00
|
|
|
function(modeling, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var event = elementRegistry.get('StartEvent'),
|
|
|
|
label = event.label,
|
2021-08-06 08:49:45 +00:00
|
|
|
di = getDi(event);
|
2018-05-16 06:57:33 +00:00
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.moveElements([ label ], { x: 20, y: 20 });
|
|
|
|
|
|
|
|
var labelBounds = di.label.bounds;
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(labelBounds).to.exist;
|
|
|
|
|
|
|
|
expect(labelBounds).to.include.keys(
|
|
|
|
'x', 'y',
|
|
|
|
'width', 'height'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2018-05-16 11:12:18 +00:00
|
|
|
|
|
|
|
it('should add missing bpmndi:BPMNLabel', inject(
|
|
|
|
function(modeling, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var event = elementRegistry.get('StartEvent_2'),
|
|
|
|
label = event.label,
|
2021-08-06 08:49:45 +00:00
|
|
|
di = getDi(event);
|
2018-05-16 11:12:18 +00:00
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.moveElements([ label ], { x: 20, y: 20 });
|
|
|
|
|
|
|
|
var diLabel = di.label;
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(diLabel).to.exist;
|
|
|
|
|
|
|
|
expect(diLabel.bounds).to.exist;
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2016-10-28 15:42:42 +00:00
|
|
|
});
|
|
|
|
|
2022-01-26 13:27:54 +00:00
|
|
|
|
|
|
|
describe('update embedded label bounds', function() {
|
|
|
|
|
|
|
|
var diagramXML = require('./BpmnUpdater.bpmn');
|
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: testModules
|
|
|
|
}));
|
|
|
|
|
|
|
|
var bounds,
|
|
|
|
di;
|
|
|
|
|
|
|
|
beforeEach(inject(function(elementRegistry, modeling) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_3');
|
|
|
|
|
|
|
|
di = getDi(task);
|
|
|
|
|
|
|
|
bounds = pick(di.get('label').get('bounds'), [ 'x', 'y', 'width', 'height' ]);
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.moveShape(task, {
|
|
|
|
x: 100,
|
|
|
|
y: 100
|
|
|
|
});
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('<do>', function() {
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(di.get('label').get('bounds')).to.include({
|
|
|
|
x: bounds.x + 100,
|
|
|
|
y: bounds.y + 100,
|
|
|
|
width: bounds.width,
|
|
|
|
height: bounds.height
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('<undo>', inject(function(commandStack) {
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(di.get('label').get('bounds')).to.include({
|
|
|
|
x: bounds.x,
|
|
|
|
y: bounds.y,
|
|
|
|
width: bounds.width,
|
|
|
|
height: bounds.height
|
|
|
|
});
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('<redo>', inject(function(commandStack) {
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(di.get('label').get('bounds')).to.include({
|
|
|
|
x: bounds.x + 100,
|
|
|
|
y: bounds.y + 100,
|
|
|
|
width: bounds.width,
|
|
|
|
height: bounds.height
|
|
|
|
});
|
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2016-10-28 15:42:42 +00:00
|
|
|
});
|