2021-12-15 11:45:45 +01:00
|
|
|
import {
|
|
|
|
bootstrapModeler,
|
|
|
|
inject
|
|
|
|
} from 'test/TestHelper';
|
|
|
|
|
|
|
|
import coreModule from 'lib/core';
|
|
|
|
import modelingModule from 'lib/features/modeling';
|
|
|
|
import replaceModule from 'lib/features/replace';
|
2022-01-25 11:39:16 +01:00
|
|
|
import bpmnCopyPasteModule from 'lib/features/copy-paste';
|
|
|
|
import copyPasteModule from 'diagram-js/lib/features/copy-paste';
|
|
|
|
|
2021-12-15 11:45:45 +01:00
|
|
|
import { is } from 'lib/util/ModelUtil';
|
2022-01-25 11:39:16 +01:00
|
|
|
import { keys } from 'min-dash';
|
2021-12-15 11:45:45 +01:00
|
|
|
|
|
|
|
describe('features/modeling/behavior - subprocess planes', function() {
|
|
|
|
|
|
|
|
var diagramXML = require('./SubProcessBehavior.planes.bpmn');
|
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: [
|
|
|
|
coreModule,
|
|
|
|
modelingModule,
|
|
|
|
replaceModule
|
|
|
|
]
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
describe('create', function() {
|
|
|
|
|
|
|
|
it('should create new diagram for collapsed subprocess', inject(function(elementFactory, modeling, canvas, bpmnjs) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementFactory.createShape({
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: false
|
|
|
|
});
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.createShape(subProcess, { x: 300, y: 300 }, canvas.getRootElement());
|
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(2);
|
2021-12-15 11:45:45 +01:00
|
|
|
expect(canvas.findRoot(planeId(subProcess))).to.exist;
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should not create new plane for expanded subprocess', inject(function(elementFactory, modeling, canvas, bpmnjs) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementFactory.createShape({
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: true
|
|
|
|
});
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.createShape(subProcess, { x: 300, y: 300 }, canvas.getRootElement());
|
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(1);
|
2021-12-15 11:45:45 +01:00
|
|
|
expect(canvas.findRoot(planeId(subProcess))).to.not.exist;
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
2022-01-25 11:39:16 +01:00
|
|
|
it('should move children to plane for collapsed subprocess', inject(function(elementFactory, modeling, canvas, bpmnjs) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementFactory.createShape({
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: false
|
|
|
|
});
|
|
|
|
|
|
|
|
var child = elementFactory.createShape({
|
|
|
|
type: 'bpmn:Task',
|
|
|
|
parent: subProcess
|
|
|
|
});
|
|
|
|
|
|
|
|
// when
|
2022-01-30 20:18:33 +01:00
|
|
|
modeling.createElements([ subProcess, child ], { x: 300, y: 300 }, canvas.getRootElement());
|
2022-01-25 11:39:16 +01:00
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
|
|
|
var newPlane = canvas.findRoot(planeId(subProcess));
|
|
|
|
expect(diagrams.length).to.equal(2);
|
|
|
|
expect(newPlane).to.exist;
|
|
|
|
expect(child.parent).to.equal(newPlane);
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
2021-12-15 11:45:45 +01:00
|
|
|
it('should undo', inject(function(elementFactory, modeling, commandStack, canvas, bpmnjs) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementFactory.createShape({
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: false
|
|
|
|
});
|
|
|
|
modeling.createShape(subProcess, { x: 300, y: 300 }, canvas.getRootElement());
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(1);
|
2021-12-15 11:45:45 +01:00
|
|
|
expect(canvas.findRoot(planeId(subProcess))).to.not.exist;
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should redo', inject(function(elementFactory, modeling, commandStack, canvas, bpmnjs) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementFactory.createShape({
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: false
|
|
|
|
});
|
|
|
|
modeling.createShape(subProcess, { x: 300, y: 300 }, canvas.getRootElement());
|
|
|
|
var plane = canvas.findRoot(planeId(subProcess));
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(2);
|
2021-12-15 11:45:45 +01:00
|
|
|
expect(canvas.findRoot(planeId(subProcess))).to.exist;
|
|
|
|
expect(canvas.findRoot(planeId(subProcess))).to.equal(plane);
|
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('replace', function() {
|
|
|
|
|
|
|
|
describe('task -> collapsed subprocess', function() {
|
|
|
|
|
|
|
|
it('should add new diagram for collapsed subprocess', inject(
|
|
|
|
function(elementRegistry, bpmnReplace, bpmnjs, canvas) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_1'),
|
|
|
|
collapsedSubProcess;
|
|
|
|
|
|
|
|
// when
|
|
|
|
collapsedSubProcess = bpmnReplace.replaceElement(task, {
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: false
|
|
|
|
});
|
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(2);
|
2021-12-15 11:45:45 +01:00
|
|
|
expect(canvas.findRoot(planeId(collapsedSubProcess))).to.exist;
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
|
|
it('should undo', inject(
|
|
|
|
function(elementRegistry, bpmnReplace, bpmnjs, canvas, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_1'),
|
|
|
|
collapsedSubProcess = bpmnReplace.replaceElement(task, {
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: false
|
|
|
|
});
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(1);
|
2021-12-15 11:45:45 +01:00
|
|
|
expect(canvas.findRoot(planeId(collapsedSubProcess))).to.not.exist;
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
|
|
it('should redo', inject(
|
|
|
|
function(elementRegistry, bpmnReplace, bpmnjs, canvas, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_1'),
|
|
|
|
collapsedSubProcess = bpmnReplace.replaceElement(task, {
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: false
|
|
|
|
});
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(2);
|
2021-12-15 11:45:45 +01:00
|
|
|
expect(canvas.findRoot(planeId(collapsedSubProcess))).to.exist;
|
|
|
|
}
|
|
|
|
));
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('task -> expanded subprocess', function() {
|
|
|
|
|
|
|
|
it('should not add new diagram for collapsed subprocess', inject(
|
|
|
|
function(elementRegistry, bpmnReplace, bpmnjs, canvas) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_1'),
|
|
|
|
collapsedSubProcess;
|
|
|
|
|
|
|
|
// when
|
|
|
|
collapsedSubProcess = bpmnReplace.replaceElement(task, {
|
|
|
|
type: 'bpmn:SubProcess',
|
|
|
|
isExpanded: true
|
|
|
|
});
|
|
|
|
|
|
|
|
// then
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(1);
|
2021-12-15 11:45:45 +01:00
|
|
|
expect(canvas.findRoot(planeId(collapsedSubProcess))).to.not.exist;
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2021-12-15 17:37:43 +01:00
|
|
|
|
|
|
|
describe('remove', function() {
|
|
|
|
|
|
|
|
var multipleDiagramXML = require('./SubProcessBehavior.multiple-planes.bpmn');
|
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(multipleDiagramXML, {
|
|
|
|
modules: [
|
|
|
|
coreModule,
|
|
|
|
modelingModule,
|
|
|
|
replaceModule
|
|
|
|
]
|
|
|
|
}));
|
|
|
|
|
|
|
|
it('should recursively remove diagrams', inject(function(elementRegistry, modeling, bpmnjs) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.removeShape(subProcess);
|
|
|
|
|
|
|
|
// then
|
|
|
|
var nestedTask = elementRegistry.get('nested_task');
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(1);
|
2021-12-15 17:37:43 +01:00
|
|
|
expect(nestedTask).to.not.exist;
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should undo', inject(function(elementRegistry, modeling, bpmnjs, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2');
|
|
|
|
modeling.removeShape(subProcess);
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var nestedTask = elementRegistry.get('nested_task');
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(3);
|
2021-12-15 17:37:43 +01:00
|
|
|
expect(nestedTask).to.exist;
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should undo', inject(function(elementRegistry, modeling, bpmnjs, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2');
|
|
|
|
modeling.removeShape(subProcess);
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
var nestedTask = elementRegistry.get('nested_task');
|
|
|
|
var diagrams = bpmnjs.getDefinitions().diagrams;
|
2022-01-07 09:26:40 +01:00
|
|
|
expect(diagrams).to.have.length(1);
|
2021-12-15 17:37:43 +01:00
|
|
|
expect(nestedTask).to.not.exist;
|
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2022-01-21 15:24:49 +01:00
|
|
|
|
|
|
|
describe('update', function() {
|
|
|
|
|
|
|
|
var multipleDiagramXML = require('./SubProcessBehavior.multiple-planes.bpmn');
|
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(multipleDiagramXML, {
|
|
|
|
modules: [
|
|
|
|
coreModule,
|
|
|
|
modelingModule,
|
|
|
|
replaceModule
|
|
|
|
]
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
2022-02-14 14:20:29 +01:00
|
|
|
describe('do', function() {
|
2022-01-21 15:24:49 +01:00
|
|
|
|
2022-02-14 14:20:29 +01:00
|
|
|
it('should update plane id when primary shape is changed',
|
|
|
|
inject(function(modeling, elementRegistry) {
|
2022-01-21 15:24:49 +01:00
|
|
|
|
2022-02-14 14:20:29 +01:00
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2'),
|
|
|
|
plane = elementRegistry.get('SubProcess_2_plane');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.updateProperties(subProcess, { id: 'new_name' });
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(subProcess.id).to.equal('new_name');
|
|
|
|
expect(plane.id).to.equal('new_name_plane');
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should update primary shape id when plane is changed',
|
|
|
|
inject(function(modeling, elementRegistry) {
|
2022-01-21 15:24:49 +01:00
|
|
|
|
2022-02-14 14:20:29 +01:00
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2'),
|
|
|
|
plane = elementRegistry.get('SubProcess_2_plane');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.updateProperties(plane, { id: 'new_name' });
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(subProcess.id).to.equal('new_name');
|
|
|
|
expect(plane.id).to.equal('new_name_plane');
|
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
2022-01-21 15:24:49 +01:00
|
|
|
|
|
|
|
|
2022-02-14 14:20:29 +01:00
|
|
|
describe('undo', function() {
|
2022-01-21 15:24:49 +01:00
|
|
|
|
2022-02-14 14:20:29 +01:00
|
|
|
it('should update plane id when primary shape is changed',
|
|
|
|
inject(function(modeling, elementRegistry, commandStack) {
|
2022-01-21 15:24:49 +01:00
|
|
|
|
2022-02-14 14:20:29 +01:00
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2'),
|
|
|
|
plane = elementRegistry.get('SubProcess_2_plane');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.updateProperties(subProcess, { id: 'new_name' });
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(subProcess.id).to.equal('SubProcess_2');
|
|
|
|
expect(plane.id).to.equal('SubProcess_2_plane');
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should update primary shape id when plane is changed',
|
|
|
|
inject(function(modeling, elementRegistry, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2'),
|
|
|
|
plane = elementRegistry.get('SubProcess_2_plane');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.updateProperties(plane, { id: 'new_name' });
|
|
|
|
commandStack.undo();
|
2022-01-21 15:24:49 +01:00
|
|
|
|
2022-02-14 14:20:29 +01:00
|
|
|
// then
|
|
|
|
expect(subProcess.id).to.equal('SubProcess_2');
|
|
|
|
expect(plane.id).to.equal('SubProcess_2_plane');
|
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('redo', function() {
|
|
|
|
|
|
|
|
it('should update plane id when primary shape is changed',
|
|
|
|
inject(function(modeling, elementRegistry, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2'),
|
|
|
|
plane = elementRegistry.get('SubProcess_2_plane');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.updateProperties(subProcess, { id: 'new_name' });
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(subProcess.id).to.equal('new_name');
|
|
|
|
expect(plane.id).to.equal('new_name_plane');
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should update primary shape id when plane is changed',
|
|
|
|
inject(function(modeling, elementRegistry, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2'),
|
|
|
|
plane = elementRegistry.get('SubProcess_2_plane');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.updateProperties(plane, { id: 'new_name' });
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(subProcess.id).to.equal('new_name');
|
|
|
|
expect(plane.id).to.equal('new_name_plane');
|
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
2022-01-21 15:24:49 +01:00
|
|
|
|
2022-02-09 08:22:33 +01:00
|
|
|
|
|
|
|
it('should rerender primary shape name when plane is changed',
|
|
|
|
inject(function(modeling, elementRegistry, eventBus) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_2'),
|
|
|
|
plane = elementRegistry.get('SubProcess_2_plane');
|
|
|
|
|
|
|
|
var changedSpy = sinon.spy();
|
|
|
|
|
|
|
|
eventBus.on('element.changed', 5000, changedSpy);
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.updateProperties(plane, { name: 'new name' });
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(changedSpy).to.have.been.calledTwice;
|
|
|
|
expect(changedSpy.secondCall.args[0].element).to.eql(subProcess);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
2022-01-21 15:24:49 +01:00
|
|
|
});
|
|
|
|
|
2022-01-25 11:39:16 +01:00
|
|
|
|
|
|
|
describe('copy/paste', function() {
|
|
|
|
|
|
|
|
var copyXML = require('./SubProcessBehavior.copy-paste.bpmn');
|
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(copyXML, {
|
|
|
|
modules: [
|
|
|
|
coreModule,
|
|
|
|
modelingModule,
|
|
|
|
bpmnCopyPasteModule,
|
|
|
|
copyPasteModule
|
|
|
|
]
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should copy collapsed sub process', inject(function(copyPaste, elementRegistry) {
|
|
|
|
|
|
|
|
var subprcoess = elementRegistry.get('SubProcess_3');
|
|
|
|
|
|
|
|
|
|
|
|
// when
|
2022-01-30 20:18:33 +01:00
|
|
|
var tree = copyPaste.copy([ subprcoess ]);
|
2022-01-25 11:39:16 +01:00
|
|
|
|
|
|
|
// then
|
|
|
|
expect(keys(tree)).to.have.length(3);
|
|
|
|
|
|
|
|
|
2022-01-30 20:18:33 +01:00
|
|
|
expect(tree[ 0 ]).to.have.length(1);
|
|
|
|
expect(tree[ 1 ]).to.have.length(3);
|
|
|
|
expect(tree[ 2 ]).to.have.length(12);
|
2022-01-25 11:39:16 +01:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should paste subprocess plane', inject(
|
|
|
|
function(canvas, copyPaste, elementRegistry) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subprcoess = elementRegistry.get('SubProcess_3'),
|
|
|
|
rootElement = canvas.getRootElement();
|
|
|
|
|
|
|
|
copyPaste.copy(subprcoess);
|
|
|
|
|
|
|
|
// when
|
|
|
|
var elements = copyPaste.paste({
|
|
|
|
element: rootElement,
|
|
|
|
point: {
|
|
|
|
x: 300,
|
|
|
|
y: 300
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
// then
|
|
|
|
var subprocess = elements[0];
|
|
|
|
var newRoot = canvas.findRoot(planeId(subprocess));
|
|
|
|
|
|
|
|
expect(newRoot).to.exist;
|
|
|
|
expect(newRoot.children).to.have.length(6);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2021-12-15 11:45:45 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
function planeId(element) {
|
|
|
|
if (is(element, 'bpmn:SubProcess')) {
|
|
|
|
return element.id + '_plane';
|
|
|
|
}
|
|
|
|
|
|
|
|
return element.id;
|
|
|
|
}
|