2019-06-04 12:07:55 +02:00
|
|
|
/* global sinon */
|
|
|
|
|
2019-05-17 14:26:13 +02:00
|
|
|
import {
|
|
|
|
bootstrapModeler,
|
|
|
|
inject
|
|
|
|
} from 'test/TestHelper';
|
|
|
|
|
|
|
|
import modelingModule from 'lib/features/modeling';
|
|
|
|
import coreModule from 'lib/core';
|
|
|
|
|
|
|
|
|
|
|
|
describe('features/modeling/behavior - attach events', function() {
|
|
|
|
|
|
|
|
var testModules = [ coreModule, modelingModule ];
|
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
var processDiagramXML = require('test/spec/features/rules/BpmnRules.attaching.bpmn');
|
2019-05-17 14:26:13 +02:00
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(processDiagramXML, { modules: testModules }));
|
|
|
|
|
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
describe('basics', function() {
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
it('should execute on attach', inject(function(elementRegistry, modeling) {
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
// given
|
|
|
|
var eventId = 'IntermediateThrowEvent',
|
|
|
|
intermediateThrowEvent = elementRegistry.get(eventId),
|
|
|
|
subProcess = elementRegistry.get('SubProcess_1'),
|
|
|
|
boundaryEvent;
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
var elements = [ intermediateThrowEvent ];
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
// when
|
|
|
|
modeling.moveElements(elements, { x: 0, y: -90 }, subProcess, { attach: true });
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
// then
|
|
|
|
boundaryEvent = elementRegistry.get(eventId);
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
expect(intermediateThrowEvent.parent).to.not.exist;
|
|
|
|
expect(boundaryEvent).to.exist;
|
|
|
|
expect(boundaryEvent.type).to.equal('bpmn:BoundaryEvent');
|
|
|
|
expect(boundaryEvent.businessObject.attachedToRef).to.equal(subProcess.businessObject);
|
|
|
|
}));
|
2019-05-17 14:26:13 +02:00
|
|
|
|
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
it('should NOT execute on drop', inject(function(elementRegistry, modeling) {
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
// given
|
|
|
|
var eventId = 'IntermediateThrowEvent',
|
|
|
|
intermediateThrowEvent = elementRegistry.get(eventId),
|
|
|
|
subProcess = elementRegistry.get('SubProcess_1');
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
var elements = [ intermediateThrowEvent ];
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-22 10:42:07 +02:00
|
|
|
// when
|
|
|
|
modeling.moveElements(elements, { x: 0, y: -150 }, subProcess);
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(intermediateThrowEvent.parent).to.eql(subProcess);
|
|
|
|
expect(intermediateThrowEvent.type).to.equal('bpmn:IntermediateThrowEvent');
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('event definition', function() {
|
|
|
|
|
|
|
|
it('should copy event definitions', inject(function(elementRegistry, modeling) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var attachableEvents = [
|
|
|
|
'IntermediateThrowEvent',
|
|
|
|
'MessageCatchEvent',
|
|
|
|
'TimerCatchEvent',
|
|
|
|
'SignalCatchEvent',
|
|
|
|
'ConditionalCatchEvent'
|
|
|
|
];
|
|
|
|
|
|
|
|
attachableEvents.forEach(function(eventId) {
|
|
|
|
|
|
|
|
var event = elementRegistry.get(eventId),
|
|
|
|
subProcess = elementRegistry.get('SubProcess_1'),
|
|
|
|
eventDefinitions = event.businessObject.eventDefinitions,
|
|
|
|
boundaryEvent, bo;
|
|
|
|
|
|
|
|
var elements = [ event ];
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.moveElements(elements, { x: 0, y: -90 }, subProcess, { attach: true });
|
|
|
|
|
|
|
|
// then
|
|
|
|
boundaryEvent = elementRegistry.get(eventId);
|
|
|
|
bo = boundaryEvent.businessObject;
|
|
|
|
|
|
|
|
expect(boundaryEvent.type).to.equal('bpmn:BoundaryEvent');
|
|
|
|
expect(bo.eventDefinitions).to.jsonEqual(eventDefinitions, skipId);
|
|
|
|
});
|
|
|
|
}));
|
|
|
|
});
|
2019-05-17 14:26:13 +02:00
|
|
|
|
2019-05-23 08:38:18 +02:00
|
|
|
|
|
|
|
describe('connections', function() {
|
|
|
|
|
|
|
|
var eventId = 'IntermediateThrowEventWithConnections';
|
|
|
|
|
|
|
|
it('should remove incoming connection', inject(function(elementRegistry, modeling) {
|
|
|
|
|
2019-06-04 12:07:55 +02:00
|
|
|
// given
|
2019-05-23 08:38:18 +02:00
|
|
|
var event = elementRegistry.get(eventId),
|
|
|
|
subProcess = elementRegistry.get('SubProcess_1'),
|
|
|
|
gateway = elementRegistry.get('Gateway_1'),
|
|
|
|
boundaryEvent;
|
|
|
|
|
|
|
|
var elements = [ event ];
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.moveElements(elements, { x: 0, y: -90 }, subProcess, { attach: true });
|
|
|
|
|
|
|
|
// then
|
|
|
|
boundaryEvent = elementRegistry.get(eventId);
|
|
|
|
|
|
|
|
expect(boundaryEvent.incoming).to.have.lengthOf(0);
|
|
|
|
expect(gateway.outgoing).to.have.lengthOf(0);
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should keep outgoing connection', inject(function(elementRegistry, modeling) {
|
|
|
|
|
2019-06-04 12:07:55 +02:00
|
|
|
// given
|
2019-05-23 08:38:18 +02:00
|
|
|
var event = elementRegistry.get(eventId),
|
|
|
|
subProcess = elementRegistry.get('SubProcess_1'),
|
|
|
|
task = elementRegistry.get('Task_1'),
|
|
|
|
boundaryEvent;
|
|
|
|
|
|
|
|
var elements = [ event ];
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.moveElements(elements, { x: 0, y: -90 }, subProcess, { attach: true });
|
|
|
|
|
|
|
|
// then
|
|
|
|
boundaryEvent = elementRegistry.get(eventId);
|
|
|
|
|
|
|
|
expect(boundaryEvent.outgoing).to.have.lengthOf(1);
|
|
|
|
expect(task.incoming).to.have.lengthOf(1);
|
|
|
|
}));
|
2019-06-04 12:07:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
it('should lay out connection once', inject(function(eventBus, elementRegistry, modeling) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var layoutSpy = sinon.spy(),
|
|
|
|
event = elementRegistry.get(eventId),
|
|
|
|
subProcess = elementRegistry.get('SubProcess_1');
|
|
|
|
|
|
|
|
eventBus.on('commandStack.connection.layout.execute', layoutSpy);
|
|
|
|
|
|
|
|
var elements = [ event ];
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.moveElements(elements, { x: 0, y: -90 }, subProcess, { attach: true });
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(layoutSpy).to.be.calledOnce;
|
|
|
|
}));
|
2019-05-23 08:38:18 +02:00
|
|
|
});
|
|
|
|
|
2019-05-17 14:26:13 +02:00
|
|
|
});
|
2019-05-22 10:42:07 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// helper //////
|
|
|
|
function skipId(key, value) {
|
|
|
|
|
|
|
|
if (key === 'id') {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
return value;
|
|
|
|
}
|