2014-06-18 09:45:30 +00:00
|
|
|
'use strict';
|
|
|
|
|
2018-01-24 10:41:21 +00:00
|
|
|
var Modeler = require('lib/Modeler');
|
2014-03-13 15:06:30 +00:00
|
|
|
|
2015-07-15 15:22:19 +00:00
|
|
|
var TestContainer = require('mocha-test-container-support');
|
2014-03-13 15:06:30 +00:00
|
|
|
|
2018-04-02 07:12:44 +00:00
|
|
|
|
2014-12-18 08:45:45 +00:00
|
|
|
describe('Modeler', function() {
|
2014-03-13 15:06:30 +00:00
|
|
|
|
|
|
|
var container;
|
|
|
|
|
2018-04-02 07:12:44 +00:00
|
|
|
var modeler;
|
|
|
|
|
2014-03-13 15:06:30 +00:00
|
|
|
beforeEach(function() {
|
2015-07-15 15:22:19 +00:00
|
|
|
container = TestContainer.get(this);
|
2014-03-13 15:06:30 +00:00
|
|
|
});
|
|
|
|
|
2018-04-02 07:12:44 +00:00
|
|
|
afterEach(function() {
|
|
|
|
if (modeler) {
|
|
|
|
modeler.destroy();
|
|
|
|
}
|
|
|
|
|
|
|
|
modeler = null;
|
|
|
|
});
|
2014-03-21 20:10:01 +00:00
|
|
|
|
2014-06-17 09:19:31 +00:00
|
|
|
function createModeler(xml, done) {
|
2018-04-02 07:12:44 +00:00
|
|
|
|
|
|
|
modeler = new Modeler({
|
|
|
|
container: container,
|
|
|
|
keyboard: {
|
|
|
|
bindTo: document
|
|
|
|
}
|
|
|
|
});
|
2014-06-17 09:19:31 +00:00
|
|
|
|
2015-02-17 11:03:27 +00:00
|
|
|
modeler.importXML(xml, function(err, warnings) {
|
|
|
|
done(err, warnings, modeler);
|
2014-06-17 09:19:31 +00:00
|
|
|
});
|
|
|
|
}
|
2014-03-13 15:06:30 +00:00
|
|
|
|
2014-06-18 09:45:30 +00:00
|
|
|
|
2014-06-17 09:19:31 +00:00
|
|
|
it('should import simple process', function(done) {
|
2015-03-31 12:17:15 +00:00
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
2014-06-17 09:19:31 +00:00
|
|
|
createModeler(xml, done);
|
|
|
|
});
|
2014-03-13 15:06:30 +00:00
|
|
|
|
|
|
|
|
2015-04-16 07:11:04 +00:00
|
|
|
it('should import collaboration', function(done) {
|
|
|
|
var xml = require('../fixtures/bpmn/collaboration-message-flows.bpmn');
|
|
|
|
createModeler(xml, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2015-10-09 23:40:52 +00:00
|
|
|
it('should import nested lanes', function(done) {
|
|
|
|
var xml = require('./features/modeling/lanes/lanes.bpmn');
|
|
|
|
createModeler(xml, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2016-09-23 10:55:57 +00:00
|
|
|
it.skip('should import complex', function(done) {
|
2016-06-27 12:14:07 +00:00
|
|
|
var xml = require('../fixtures/bpmn/complex.bpmn');
|
|
|
|
createModeler(xml, done);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2015-11-24 11:53:18 +00:00
|
|
|
it('should not import empty definitions', function(done) {
|
2015-03-31 12:17:15 +00:00
|
|
|
var xml = require('../fixtures/bpmn/empty-definitions.bpmn');
|
2015-11-24 11:53:18 +00:00
|
|
|
|
|
|
|
// given
|
|
|
|
createModeler(xml, function(err, warnings, modeler) {
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeler.importXML(xml, function(err, warnings) {
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(err.message).to.equal('no diagram to display');
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
2014-03-13 15:06:30 +00:00
|
|
|
});
|
2014-04-25 11:30:10 +00:00
|
|
|
|
|
|
|
|
2015-02-18 12:25:20 +00:00
|
|
|
it('should re-import simple process', function(done) {
|
2015-02-17 11:03:27 +00:00
|
|
|
|
2015-03-31 12:17:15 +00:00
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
2015-02-17 11:03:27 +00:00
|
|
|
|
|
|
|
// given
|
|
|
|
createModeler(xml, function(err, warnings, modeler) {
|
|
|
|
|
|
|
|
// when
|
|
|
|
// mimic re-import of same diagram
|
|
|
|
modeler.importXML(xml, function(err, warnings) {
|
|
|
|
|
|
|
|
// then
|
2015-07-15 15:22:19 +00:00
|
|
|
expect(warnings.length).to.equal(0);
|
2015-02-17 11:03:27 +00:00
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2016-02-25 16:40:56 +00:00
|
|
|
describe('translate support', function() {
|
|
|
|
|
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
|
|
|
|
|
|
|
it('should allow translation of multi-lingual strings', function(done) {
|
|
|
|
|
|
|
|
createModeler(xml, function(err, warnings, modeler) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var translate = modeler.get('translate');
|
|
|
|
|
|
|
|
// assume
|
|
|
|
expect(translate).to.exist;
|
|
|
|
|
|
|
|
// when
|
|
|
|
var interpolatedString = translate('HELLO {you}!', { you: 'WALT' });
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(interpolatedString).to.eql('HELLO WALT!');
|
|
|
|
|
|
|
|
done(err);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-08-05 15:02:03 +00:00
|
|
|
describe('overlay support', function() {
|
|
|
|
|
|
|
|
it('should allow to add overlays', function(done) {
|
|
|
|
|
2015-03-31 12:17:15 +00:00
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
2014-08-05 15:02:03 +00:00
|
|
|
|
2016-02-25 16:40:56 +00:00
|
|
|
createModeler(xml, function(err, warnings, modeler) {
|
2014-08-05 15:02:03 +00:00
|
|
|
|
2014-08-07 20:09:12 +00:00
|
|
|
// given
|
2016-02-25 16:40:56 +00:00
|
|
|
var overlays = modeler.get('overlays'),
|
|
|
|
elementRegistry = modeler.get('elementRegistry');
|
2014-08-05 15:02:03 +00:00
|
|
|
|
2014-08-07 20:09:12 +00:00
|
|
|
// assume
|
2015-12-01 07:27:45 +00:00
|
|
|
expect(overlays).to.exist;
|
|
|
|
expect(elementRegistry).to.exist;
|
2014-08-05 15:02:03 +00:00
|
|
|
|
|
|
|
|
|
|
|
// when
|
2014-08-12 09:53:38 +00:00
|
|
|
overlays.add('SubProcess_1', 'badge', {
|
2014-08-05 15:02:03 +00:00
|
|
|
position: {
|
|
|
|
bottom: 0,
|
|
|
|
right: 0
|
|
|
|
},
|
|
|
|
html: '<div style="max-width: 50px">YUP GREAT STUFF!</div>'
|
|
|
|
});
|
|
|
|
|
2014-08-12 09:53:38 +00:00
|
|
|
overlays.add('StartEvent_1', 'badge', {
|
2014-08-07 20:09:12 +00:00
|
|
|
position: {
|
|
|
|
top: 0,
|
|
|
|
left: 0
|
|
|
|
},
|
|
|
|
html: '<div style="max-width: 50px">YUP GREAT STUFF!</div>'
|
|
|
|
});
|
|
|
|
|
2014-08-05 15:02:03 +00:00
|
|
|
// then
|
2018-04-02 07:24:21 +00:00
|
|
|
expect(overlays.get({ element: 'SubProcess_1', type: 'badge' })).to.have.length(1);
|
|
|
|
expect(overlays.get({ element: 'StartEvent_1', type: 'badge' })).to.have.length(1);
|
2014-08-05 15:02:03 +00:00
|
|
|
|
|
|
|
done(err);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2015-01-14 17:48:06 +00:00
|
|
|
describe('bendpoint editing support', function() {
|
|
|
|
|
2015-08-24 13:31:47 +00:00
|
|
|
var createEvent = require('../util/MockEvents').createEvent;
|
|
|
|
|
2015-01-14 17:48:06 +00:00
|
|
|
|
|
|
|
it('should allow to edit bendpoints', function(done) {
|
|
|
|
|
2015-03-31 12:17:15 +00:00
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
2015-01-14 17:48:06 +00:00
|
|
|
|
2016-02-25 16:40:56 +00:00
|
|
|
createModeler(xml, function(err, warnings, modeler) {
|
2015-01-14 17:48:06 +00:00
|
|
|
|
|
|
|
// given
|
2016-02-25 16:40:56 +00:00
|
|
|
var bendpointMove = modeler.get('bendpointMove'),
|
|
|
|
dragging = modeler.get('dragging'),
|
|
|
|
elementRegistry = modeler.get('elementRegistry'),
|
|
|
|
canvas = modeler.get('canvas');
|
2015-01-14 17:48:06 +00:00
|
|
|
|
|
|
|
// assume
|
2015-12-01 07:27:45 +00:00
|
|
|
expect(bendpointMove).to.exist;
|
2015-01-14 17:48:06 +00:00
|
|
|
|
|
|
|
// when
|
2018-04-02 07:24:21 +00:00
|
|
|
bendpointMove.start(
|
|
|
|
createEvent(canvas, { x: 0, y: 0 }),
|
|
|
|
elementRegistry.get('SequenceFlow_1'),
|
|
|
|
1
|
|
|
|
);
|
2015-08-24 13:31:47 +00:00
|
|
|
dragging.move(createEvent(canvas, { x: 200, y: 200 }));
|
2015-01-14 17:48:06 +00:00
|
|
|
|
|
|
|
done(err);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2018-01-31 11:07:18 +00:00
|
|
|
describe('color support', function() {
|
|
|
|
|
|
|
|
it('should allow color changes', function(done) {
|
|
|
|
|
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
|
|
|
|
|
|
|
createModeler(xml, function(err, warnings, modeler) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var modeling = modeler.get('modeling'),
|
|
|
|
elementRegistry = modeler.get('elementRegistry'),
|
|
|
|
eventShape = elementRegistry.get('StartEvent_2');
|
|
|
|
|
|
|
|
// when
|
|
|
|
// set color for StartEvent_2
|
|
|
|
modeling.setColor(eventShape, {
|
|
|
|
fill: 'FUCHSIA',
|
|
|
|
stroke: 'YELLOW'
|
|
|
|
});
|
|
|
|
|
|
|
|
// test saving process to get XML
|
|
|
|
modeler.saveXML({ format: true }, function(err, xml) {
|
|
|
|
expect(xml).not.to.contain('di="[object Object]"');
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2016-01-08 13:41:58 +00:00
|
|
|
describe('configuration', function() {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
|
|
|
|
|
|
|
it('should configure Canvas', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var modeler = new Modeler({
|
|
|
|
container: container,
|
|
|
|
canvas: {
|
|
|
|
deferUpdate: true
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeler.importXML(xml, function(err) {
|
|
|
|
|
|
|
|
var canvasConfig = modeler.get('config.canvas');
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(canvasConfig.deferUpdate).to.be.true;
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2016-03-16 22:11:05 +00:00
|
|
|
describe('ids', function() {
|
|
|
|
|
|
|
|
it('should provide ids with moddle', function() {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var modeler = new Modeler({ container: container });
|
|
|
|
|
|
|
|
// when
|
|
|
|
var moddle = modeler.get('moddle');
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(moddle.ids).to.exist;
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('should populate ids on import', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
|
|
|
|
|
|
|
var modeler = new Modeler({ container: container });
|
|
|
|
|
|
|
|
var moddle = modeler.get('moddle');
|
|
|
|
var elementRegistry = modeler.get('elementRegistry');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeler.importXML(xml, function(err) {
|
|
|
|
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_1').businessObject;
|
|
|
|
var bpmnEdge = elementRegistry.get('SequenceFlow_3').businessObject.di;
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(moddle.ids.assigned('SubProcess_1')).to.eql(subProcess);
|
|
|
|
expect(moddle.ids.assigned('BPMNEdge_SequenceFlow_3')).to.eql(bpmnEdge);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('should clear ids before re-import', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var someXML = require('../fixtures/bpmn/simple.bpmn'),
|
|
|
|
otherXML = require('../fixtures/bpmn/basic.bpmn');
|
|
|
|
|
|
|
|
var modeler = new Modeler({ container: container });
|
|
|
|
|
|
|
|
var moddle = modeler.get('moddle');
|
|
|
|
var elementRegistry = modeler.get('elementRegistry');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeler.importXML(someXML, function() {
|
|
|
|
|
|
|
|
modeler.importXML(otherXML, function() {
|
|
|
|
|
|
|
|
var task = elementRegistry.get('Task_1').businessObject;
|
|
|
|
|
|
|
|
// then
|
|
|
|
// not in other.bpmn
|
|
|
|
expect(moddle.ids.assigned('SubProcess_1')).to.be.false;
|
|
|
|
|
|
|
|
// in other.bpmn
|
|
|
|
expect(moddle.ids.assigned('Task_1')).to.eql(task);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-06-17 09:19:31 +00:00
|
|
|
it('should handle errors', function(done) {
|
2014-03-17 10:11:25 +00:00
|
|
|
|
2014-06-17 09:19:31 +00:00
|
|
|
var xml = 'invalid stuff';
|
2014-03-17 10:11:25 +00:00
|
|
|
|
2014-06-24 13:50:51 +00:00
|
|
|
var modeler = new Modeler({ container: container });
|
2014-03-21 20:10:01 +00:00
|
|
|
|
2014-06-24 13:50:51 +00:00
|
|
|
modeler.importXML(xml, function(err) {
|
2014-04-03 09:47:26 +00:00
|
|
|
|
2015-12-01 07:27:45 +00:00
|
|
|
expect(err).to.exist;
|
2014-06-17 09:19:31 +00:00
|
|
|
|
|
|
|
done();
|
2014-03-21 20:10:01 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-06-24 13:50:51 +00:00
|
|
|
it('should create new diagram', function(done) {
|
|
|
|
var modeler = new Modeler({ container: container });
|
2015-11-11 10:31:58 +00:00
|
|
|
modeler.createDiagram(done);
|
2014-06-24 13:50:51 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-06-17 09:19:31 +00:00
|
|
|
describe('dependency injection', function() {
|
2014-03-21 20:10:01 +00:00
|
|
|
|
2016-03-16 22:11:05 +00:00
|
|
|
it('should provide self as <bpmnjs>', function(done) {
|
2014-03-17 10:11:25 +00:00
|
|
|
|
2015-03-31 12:17:15 +00:00
|
|
|
var xml = require('../fixtures/bpmn/simple.bpmn');
|
2014-03-21 20:10:01 +00:00
|
|
|
|
2015-02-17 11:03:27 +00:00
|
|
|
createModeler(xml, function(err, warnings, modeler) {
|
2014-03-21 20:10:01 +00:00
|
|
|
|
2015-07-15 15:22:19 +00:00
|
|
|
expect(modeler.get('bpmnjs')).to.equal(modeler);
|
2014-10-27 11:07:57 +00:00
|
|
|
|
2014-06-17 09:19:31 +00:00
|
|
|
done(err);
|
|
|
|
});
|
2014-03-17 10:11:25 +00:00
|
|
|
});
|
2014-06-17 09:19:31 +00:00
|
|
|
|
2016-03-16 22:11:05 +00:00
|
|
|
|
|
|
|
it('should allow Diagram#get before import', function() {
|
|
|
|
|
|
|
|
// when
|
|
|
|
var modeler = new Modeler({ container: container });
|
|
|
|
|
|
|
|
// then
|
|
|
|
var eventBus = modeler.get('eventBus');
|
|
|
|
|
|
|
|
expect(eventBus).to.exist;
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('should keep references to services across re-import', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var someXML = require('../fixtures/bpmn/simple.bpmn'),
|
|
|
|
otherXML = require('../fixtures/bpmn/basic.bpmn');
|
|
|
|
|
|
|
|
var modeler = new Modeler({ container: container });
|
|
|
|
|
|
|
|
var eventBus = modeler.get('eventBus'),
|
|
|
|
canvas = modeler.get('canvas');
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeler.importXML(someXML, function() {
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(modeler.get('canvas')).to.equal(canvas);
|
|
|
|
expect(modeler.get('eventBus')).to.equal(eventBus);
|
|
|
|
|
|
|
|
modeler.importXML(otherXML, function() {
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(modeler.get('canvas')).to.equal(canvas);
|
|
|
|
expect(modeler.get('eventBus')).to.equal(eventBus);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2014-03-17 10:11:25 +00:00
|
|
|
});
|
2014-03-21 20:10:01 +00:00
|
|
|
|
2016-05-12 11:15:32 +00:00
|
|
|
|
|
|
|
it('should expose Viewer and NavigatedViewer', function() {
|
|
|
|
|
|
|
|
// given
|
2018-01-24 10:41:21 +00:00
|
|
|
var Viewer = require('lib/Viewer');
|
|
|
|
var NavigatedViewer = require('lib/NavigatedViewer');
|
2016-05-12 11:15:32 +00:00
|
|
|
|
|
|
|
// then
|
|
|
|
expect(Modeler.Viewer).to.equal(Viewer);
|
|
|
|
expect(Modeler.NavigatedViewer).to.equal(NavigatedViewer);
|
|
|
|
});
|
|
|
|
|
2014-10-27 11:07:57 +00:00
|
|
|
});
|