mirror of
https://github.com/sartography/bpmn-js.git
synced 2025-01-17 20:41:32 +00:00
194b963959
* use <copyPaste.canCopyProperty> event to copy category value when copying group * add camunda-bpmn-moddle for integration tests BREAKING CHANGES * CopyPaste: remove <property.clone>, add <moddleCopy.canCopyProperties>, <moddleCopy.canCopyProperty>, <moddleCopy.canSetCopiedProperty> * BpmnRules: removed <elements.paste> rule in favor of <elements.create> rule * BpmnRules: removed <element.paste> rule * ElementFactory: use <attrs.di> property instead of <attrs.colors> for fill and stroke when creating element through ElementFactory#createBpmnElement
270 lines
7.3 KiB
JavaScript
270 lines
7.3 KiB
JavaScript
import {
|
|
bootstrapModeler,
|
|
inject
|
|
} from 'test/TestHelper';
|
|
|
|
import modelingModule from 'lib/features/modeling';
|
|
import coreModule from 'lib/core';
|
|
|
|
|
|
describe('features/modeling - lanes - flowNodeRefs', function() {
|
|
|
|
var diagramXML = require('./flowNodeRefs.bpmn');
|
|
|
|
var testModules = [ coreModule, modelingModule ];
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, { modules: testModules }));
|
|
|
|
|
|
describe('should unwire during move', function() {
|
|
|
|
it('execute', inject(function(elementRegistry, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_A'),
|
|
task = taskShape.businessObject,
|
|
sourceLaneShape = elementRegistry.get('Lane'),
|
|
sourceLane = sourceLaneShape.businessObject,
|
|
targetParticipantShape = elementRegistry.get('Participant_B');
|
|
|
|
// when
|
|
modeling.moveElements([ taskShape ], { x: 0, y: +200 }, targetParticipantShape);
|
|
|
|
// then
|
|
expect(sourceLane.flowNodeRef).not.to.contain(task);
|
|
}));
|
|
|
|
|
|
it('undo', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_A'),
|
|
task = taskShape.businessObject,
|
|
sourceLaneShape = elementRegistry.get('Lane'),
|
|
sourceLane = sourceLaneShape.businessObject,
|
|
targetParticipantShape = elementRegistry.get('Participant_B');
|
|
|
|
modeling.moveElements([ taskShape ], { x: 0, y: +200 }, targetParticipantShape);
|
|
|
|
// when
|
|
commandStack.undo();
|
|
|
|
// then
|
|
expect(sourceLane.flowNodeRef).to.contain(task);
|
|
}));
|
|
|
|
|
|
it('redo', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_A'),
|
|
task = taskShape.businessObject,
|
|
sourceLaneShape = elementRegistry.get('Lane'),
|
|
sourceLane = sourceLaneShape.businessObject,
|
|
targetParticipantShape = elementRegistry.get('Participant_B');
|
|
|
|
modeling.moveElements([ taskShape ], { x: 0, y: +200 }, targetParticipantShape);
|
|
|
|
// when
|
|
commandStack.undo();
|
|
commandStack.redo();
|
|
|
|
// then
|
|
expect(sourceLane.flowNodeRef).not.to.contain(task);
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
describe('should wire during move', function() {
|
|
|
|
it('execute', inject(function(elementRegistry, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_B'),
|
|
task = taskShape.businessObject,
|
|
targetLaneShape = elementRegistry.get('Lane'),
|
|
targetLane = targetLaneShape.businessObject;
|
|
|
|
// when
|
|
modeling.moveElements([ taskShape ], { x: 0, y: -200 }, targetLaneShape);
|
|
|
|
// then
|
|
expect(targetLane.flowNodeRef).to.contain(task);
|
|
}));
|
|
|
|
|
|
it('undo', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_B'),
|
|
task = taskShape.businessObject,
|
|
targetLaneShape = elementRegistry.get('Lane'),
|
|
targetLane = targetLaneShape.businessObject;
|
|
|
|
modeling.moveElements([ taskShape ], { x: 0, y: -200 }, targetLaneShape);
|
|
|
|
// when
|
|
commandStack.undo();
|
|
|
|
// then
|
|
expect(targetLane.flowNodeRef).not.to.contain(task);
|
|
}));
|
|
|
|
|
|
it('redo', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_B'),
|
|
task = taskShape.businessObject,
|
|
targetLaneShape = elementRegistry.get('Lane'),
|
|
targetLane = targetLaneShape.businessObject;
|
|
|
|
modeling.moveElements([ taskShape ], { x: 0, y: -200 }, targetLaneShape);
|
|
|
|
// when
|
|
commandStack.undo();
|
|
commandStack.redo();
|
|
|
|
// then
|
|
expect(targetLane.flowNodeRef).to.contain(task);
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
describe('should unwire during delete', function() {
|
|
|
|
it('execute', inject(function(elementRegistry, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_A'),
|
|
task = taskShape.businessObject,
|
|
parentLaneShape = elementRegistry.get('Lane'),
|
|
parentLane = parentLaneShape.businessObject;
|
|
|
|
// when
|
|
modeling.removeElements([ taskShape ]);
|
|
|
|
// then
|
|
expect(parentLane.flowNodeRef).not.to.contain(task);
|
|
}));
|
|
|
|
|
|
it('undo', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_A'),
|
|
task = taskShape.businessObject,
|
|
parentLaneShape = elementRegistry.get('Lane'),
|
|
parentLane = parentLaneShape.businessObject;
|
|
|
|
modeling.removeElements([ taskShape ]);
|
|
|
|
// when
|
|
commandStack.undo();
|
|
|
|
// then
|
|
expect(parentLane.flowNodeRef).to.contain(task);
|
|
}));
|
|
|
|
|
|
it('redo', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_A'),
|
|
task = taskShape.businessObject,
|
|
parentLaneShape = elementRegistry.get('Lane'),
|
|
parentLane = parentLaneShape.businessObject;
|
|
|
|
modeling.removeElements([ taskShape ]);
|
|
|
|
// when
|
|
commandStack.undo();
|
|
commandStack.redo();
|
|
|
|
// then
|
|
expect(parentLane.flowNodeRef).not.to.contain(task);
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
describe('should wire during create', function() {
|
|
|
|
it('execute', inject(function(elementRegistry, modeling) {
|
|
|
|
// given
|
|
var taskShape, task,
|
|
parentLaneShape = elementRegistry.get('Lane'),
|
|
parentLane = parentLaneShape.businessObject;
|
|
|
|
// when
|
|
taskShape = modeling.createShape({ type: 'bpmn:Task' }, { x: 500, y: 150 }, parentLaneShape);
|
|
task = taskShape.businessObject;
|
|
|
|
// then
|
|
expect(parentLane.flowNodeRef).to.contain(task);
|
|
}));
|
|
|
|
|
|
it('undo', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
// given
|
|
var taskShape, task,
|
|
parentLaneShape = elementRegistry.get('Lane'),
|
|
parentLane = parentLaneShape.businessObject;
|
|
|
|
taskShape = modeling.createShape({ type: 'bpmn:Task' }, { x: 500, y: 150 }, parentLaneShape);
|
|
task = taskShape.businessObject;
|
|
|
|
// when
|
|
commandStack.undo();
|
|
|
|
// then
|
|
expect(parentLane.flowNodeRef).not.to.contain(task);
|
|
}));
|
|
|
|
|
|
it('redo', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
// given
|
|
var taskShape, task,
|
|
parentLaneShape = elementRegistry.get('Lane'),
|
|
parentLane = parentLaneShape.businessObject;
|
|
|
|
taskShape = modeling.createShape({ type: 'bpmn:Task' }, { x: 500, y: 150 }, parentLaneShape);
|
|
task = taskShape.businessObject;
|
|
|
|
// when
|
|
commandStack.undo();
|
|
commandStack.redo();
|
|
|
|
// then
|
|
expect(parentLane.flowNodeRef).to.contain(task);
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
it('should unwire moving multiple', inject(function(elementRegistry, modeling) {
|
|
|
|
// given
|
|
var taskShape = elementRegistry.get('Task_A'),
|
|
task = taskShape.businessObject,
|
|
eventShape = elementRegistry.get('Event'),
|
|
event = eventShape.businessObject,
|
|
targetParticipantShape = elementRegistry.get('Participant_B'),
|
|
sourceLaneShape = elementRegistry.get('Lane'),
|
|
sourceLane = sourceLaneShape.businessObject;
|
|
|
|
// when
|
|
modeling.moveElements([ taskShape, eventShape ], { x: 0, y: +200 }, targetParticipantShape);
|
|
|
|
// then
|
|
expect(sourceLane.flowNodeRef).not.to.contain(task);
|
|
expect(sourceLane.flowNodeRef).not.to.contain(event);
|
|
}));
|
|
|
|
});
|