bpmn-js/test/spec/features/modeling/MoveShapeSpec.js
2014-11-28 13:19:57 +01:00

368 lines
9.9 KiB
JavaScript

'use strict';
var Matchers = require('../../../Matchers'),
TestHelper = require('../../../TestHelper');
/* global bootstrapModeler, inject */
var _ = require('lodash');
var fs = require('fs');
var modelingModule = require('../../../../lib/features/modeling'),
coreModule = require('../../../../lib/core');
describe('features/modeling - move shape', function() {
beforeEach(Matchers.addDeepEquals);
var diagramXML = fs.readFileSync('test/fixtures/bpmn/simple.bpmn', 'utf8');
var testModules = [ coreModule, modelingModule ];
beforeEach(bootstrapModeler(diagramXML, { modules: testModules }));
describe('shape', function() {
it('should move', inject(function(elementRegistry, modeling) {
// given
var startEventElement = elementRegistry.get('StartEvent_1'),
startEvent = startEventElement.businessObject;
var sequenceFlowElement = elementRegistry.get('SequenceFlow_1'),
sequenceFlow = sequenceFlowElement.businessObject;
var oldPosition = {
x: startEventElement.x,
y: startEventElement.y
};
// when
modeling.moveShape(startEventElement, { x: 0, y: 50 });
// then
expect(startEvent.di.bounds.x).toBe(oldPosition.x);
expect(startEvent.di.bounds.y).toBe(oldPosition.y + 50);
// expect flow layout
expect(sequenceFlowElement.waypoints).toDeepEqual([
{ original: { x: 370, y: 310 }, x: 388, y: 310 },
{ x: 404, y: 310 },
{ x: 404, y: 260 },
{ original: { x: 470, y: 260 }, x: 420, y: 260 }
]);
expect(sequenceFlow.di.waypoint).toDeepEqual([
{ $type: 'dc:Point', x: 388, y: 310 },
{ $type: 'dc:Point', x: 404, y: 310 },
{ $type: 'dc:Point', x: 404, y: 260 },
{ $type: 'dc:Point', x: 420, y: 260 }
]);
}));
it('should move label', inject(function(elementRegistry, modeling) {
// given
var labelElement = elementRegistry.get('StartEvent_1_label'),
startEvent = labelElement.businessObject;
var oldPosition = {
x: labelElement.x,
y: labelElement.y
};
// when
modeling.moveShape(labelElement, { x: 0, y: 50 });
// then
expect(startEvent.di.label.bounds.x).toBe(oldPosition.x);
expect(startEvent.di.label.bounds.y).toBe(oldPosition.y + 50);
}));
it('should move label to new parent', inject(function(elementRegistry, modeling) {
// given
var startEventElement = elementRegistry.get('StartEvent_1'),
labelElement = elementRegistry.get('StartEvent_1_label'),
processElement = elementRegistry.get('Process_1'),
subProcessElement = elementRegistry.get('SubProcess_1'),
startEvent = labelElement.businessObject,
subProcess = subProcessElement.businessObject;
// when
modeling.moveShape(labelElement, { x: 0, y: 50 }, processElement);
// then
expect(labelElement.parent).toBe(processElement);
// expect actual element + businessObject to be unchanged
expect(startEventElement.parent).toBe(subProcessElement);
expect(startEvent.$parent).toBe(subProcess);
}));
describe('undo support', function() {
it('should undo', inject(function(elementRegistry, commandStack, modeling) {
// given
var startEventElement = elementRegistry.get('StartEvent_1'),
startEvent = startEventElement.businessObject;
var oldPosition = {
x: startEventElement.x,
y: startEventElement.y
};
modeling.moveShape(startEventElement, { x: 0, y: 50 });
// when
commandStack.undo();
// then
expect(startEvent.di.bounds.x).toBe(oldPosition.x);
expect(startEvent.di.bounds.y).toBe(oldPosition.y);
}));
it('should undo on label', inject(function(elementRegistry, commandStack, modeling) {
// given
var labelElement = elementRegistry.get('StartEvent_1_label'),
startEvent = labelElement.businessObject;
var oldPosition = {
x: labelElement.x,
y: labelElement.y
};
modeling.moveShape(labelElement, { x: 0, y: 50 });
// when
commandStack.undo();
// then
expect(startEvent.di.label.bounds.x).toBe(oldPosition.x);
expect(startEvent.di.label.bounds.y).toBe(oldPosition.y);
}));
});
describe('redo support', function() {
it('should redo', inject(function(elementRegistry, commandStack, modeling) {
// given
var startEventElement = elementRegistry.get('StartEvent_1'),
startEvent = startEventElement.businessObject;
modeling.moveShape(startEventElement, { x: 0, y: 50 });
var newPosition = {
x: startEventElement.x,
y: startEventElement.y
};
// when
commandStack.undo();
commandStack.redo();
// then
expect(startEvent.di.bounds.x).toBe(newPosition.x);
expect(startEvent.di.bounds.y).toBe(newPosition.y);
}));
it('should redo on label', inject(function(elementRegistry, commandStack, modeling) {
// given
var labelElement = elementRegistry.get('StartEvent_1_label'),
startEvent = labelElement.businessObject;
modeling.moveShape(labelElement, { x: 0, y: 50 });
var newPosition = {
x: labelElement.x,
y: labelElement.y
};
// when
commandStack.undo();
commandStack.redo();
// then
expect(startEvent.di.label.bounds.x).toBe(newPosition.x);
expect(startEvent.di.label.bounds.y).toBe(newPosition.y);
}));
});
});
describe('label suport', function() {
it('should move label with shape', inject(function(elementRegistry, modeling) {
// given
var startEventElement = elementRegistry.get('StartEvent_1'),
startEvent = startEventElement.businessObject;
var label = startEventElement.label;
var labelPosition = {
x: label.x,
y: label.y
};
// when
modeling.moveShapes([ startEventElement ], { x: 40, y: -80 });
// then
expect(label.x).toBe(labelPosition.x + 40);
expect(label.y).toBe(labelPosition.y - 80);
}));
it('should move label with connection', inject(function(elementRegistry, modeling) {
// given
var startEventElement = elementRegistry.get('StartEvent_2'),
startEvent = startEventElement.businessObject,
subProcessElement = elementRegistry.get('SubProcess_1'),
subProcess = startEventElement.businessObject,
flowLabel = elementRegistry.get('SequenceFlow_3_label');
var labelPosition = {
x: flowLabel.x,
y: flowLabel.y
};
// when
modeling.moveShapes([ startEventElement, subProcessElement ], { x: 40, y: -80 });
// then
expect(flowLabel.x).toBe(labelPosition.x + 40);
expect(flowLabel.y).toBe(labelPosition.y - 80);
}));
describe('undo', function() {
it('should undo label with shape', inject(function(elementRegistry, modeling, commandStack) {
// given
var startEventElement = elementRegistry.get('StartEvent_1'),
startEvent = startEventElement.businessObject;
var label = startEventElement.label;
var labelPosition = {
x: label.x,
y: label.y
};
modeling.moveShapes([ startEventElement ], { x: 40, y: -80 });
// when
commandStack.undo();
// then
expect(label.x).toBe(labelPosition.x);
expect(label.y).toBe(labelPosition.y);
}));
it('should move label with connection', inject(function(elementRegistry, modeling, commandStack) {
// given
var startEventElement = elementRegistry.get('StartEvent_2'),
startEvent = startEventElement.businessObject,
subProcessElement = elementRegistry.get('SubProcess_1'),
subProcess = startEventElement.businessObject,
flowLabel = elementRegistry.get('SequenceFlow_3_label');
var labelPosition = {
x: flowLabel.x,
y: flowLabel.y
};
modeling.moveShapes([ startEventElement, subProcessElement ], { x: 40, y: -80 });
// when
commandStack.undo();
// then
expect(flowLabel.x).toBe(labelPosition.x);
expect(flowLabel.y).toBe(labelPosition.y);
}));
});
describe('redo', function() {
it('should redo move label with shape', inject(function(elementRegistry, modeling, commandStack) {
// given
var startEventElement = elementRegistry.get('StartEvent_1'),
startEvent = startEventElement.businessObject;
var label = startEventElement.label;
var labelPosition = {
x: label.x,
y: label.y
};
modeling.moveShapes([ startEventElement ], { x: 40, y: -80 });
commandStack.undo();
// when
commandStack.redo();
// then
expect(label.x).toBe(labelPosition.x + 40);
expect(label.y).toBe(labelPosition.y - 80);
}));
it('should redo move label with connection', inject(function(elementRegistry, modeling, commandStack) {
// given
var startEventElement = elementRegistry.get('StartEvent_2'),
startEvent = startEventElement.businessObject,
subProcessElement = elementRegistry.get('SubProcess_1'),
subProcess = startEventElement.businessObject,
flowLabel = elementRegistry.get('SequenceFlow_3_label');
var labelPosition = {
x: flowLabel.x,
y: flowLabel.y
};
modeling.moveShapes([ startEventElement, subProcessElement ], { x: 40, y: -80 });
commandStack.undo();
// when
commandStack.redo();
// then
expect(flowLabel.x).toBe(labelPosition.x + 40);
expect(flowLabel.y).toBe(labelPosition.y - 80);
}));
});
});
});