2014-06-11 14:41:55 +02:00
|
|
|
'use strict';
|
|
|
|
|
2014-06-18 11:45:30 +02:00
|
|
|
var Matchers = require('../Matchers'),
|
|
|
|
TestHelper = require('../TestHelper');
|
|
|
|
|
2014-08-05 08:17:22 +02:00
|
|
|
/* global bootstrapViewer, inject */
|
2014-06-18 11:45:30 +02:00
|
|
|
|
|
|
|
|
2014-03-13 16:06:30 +01:00
|
|
|
var fs = require('fs');
|
|
|
|
|
2014-08-01 07:16:59 +02:00
|
|
|
var Viewer = require('../../lib/Viewer');
|
2014-03-13 16:06:30 +01:00
|
|
|
|
|
|
|
|
2014-06-18 11:45:30 +02:00
|
|
|
describe('viewer', function() {
|
2014-03-13 16:06:30 +01:00
|
|
|
|
2014-07-30 16:06:32 +02:00
|
|
|
beforeEach(Matchers.addDeepEquals);
|
2014-03-13 16:06:30 +01:00
|
|
|
|
2014-06-18 11:45:30 +02:00
|
|
|
|
2014-03-13 16:06:30 +01:00
|
|
|
var container;
|
|
|
|
|
|
|
|
beforeEach(function() {
|
2014-06-18 11:45:30 +02:00
|
|
|
container = jasmine.getEnv().getTestContainer();
|
2014-03-13 16:06:30 +01:00
|
|
|
});
|
|
|
|
|
2014-06-18 11:45:30 +02:00
|
|
|
|
2014-06-11 14:41:55 +02:00
|
|
|
function createViewer(xml, done) {
|
2014-08-01 07:55:47 +02:00
|
|
|
var viewer = new Viewer({ container: container });
|
2014-06-11 14:41:55 +02:00
|
|
|
|
2014-10-28 15:09:17 +01:00
|
|
|
viewer.importXML(xml, function(err, warnings) {
|
|
|
|
done(err, warnings, viewer);
|
2014-06-11 14:41:55 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2014-03-21 21:10:01 +01:00
|
|
|
|
2014-03-13 16:06:30 +01:00
|
|
|
it('should import simple process', function(done) {
|
|
|
|
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/simple.bpmn', 'utf8');
|
|
|
|
|
2014-06-11 14:41:55 +02:00
|
|
|
createViewer(xml, done);
|
2014-03-13 16:06:30 +01:00
|
|
|
});
|
2014-03-17 11:11:25 +01:00
|
|
|
|
2014-03-21 21:10:01 +01:00
|
|
|
|
2014-03-17 11:11:25 +01:00
|
|
|
it('should import empty definitions', function(done) {
|
|
|
|
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/empty-definitions.bpmn', 'utf8');
|
|
|
|
|
2014-06-11 14:41:55 +02:00
|
|
|
createViewer(xml, done);
|
2014-03-21 21:10:01 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-08-05 08:34:54 +02:00
|
|
|
describe('import events', function() {
|
|
|
|
|
2014-08-05 17:02:03 +02:00
|
|
|
it('should fire <import.*> events', function(done) {
|
2014-08-05 08:34:54 +02:00
|
|
|
|
|
|
|
// given
|
|
|
|
var viewer = new Viewer({ container: container });
|
|
|
|
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/empty-definitions.bpmn', 'utf8');
|
|
|
|
|
|
|
|
var events = [];
|
|
|
|
|
|
|
|
viewer.on('import.start', function() {
|
|
|
|
events.push('import.start');
|
|
|
|
});
|
|
|
|
|
|
|
|
viewer.on('import.success', function() {
|
|
|
|
events.push('import.success');
|
|
|
|
});
|
|
|
|
|
|
|
|
viewer.on('import.error', function() {
|
|
|
|
events.push('import.error');
|
|
|
|
});
|
|
|
|
|
|
|
|
// when
|
|
|
|
viewer.importXML(xml, function(err) {
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(events).toEqual([
|
|
|
|
'import.start',
|
|
|
|
'import.success'
|
|
|
|
]);
|
|
|
|
|
|
|
|
done(err);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-08-05 17:02:03 +02:00
|
|
|
describe('overlay support', function() {
|
|
|
|
|
|
|
|
it('should allow to add overlays', function(done) {
|
|
|
|
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/simple.bpmn', 'utf8');
|
|
|
|
|
2014-10-28 15:09:17 +01:00
|
|
|
createViewer(xml, function(err, warnings, viewer) {
|
2014-08-05 17:02:03 +02:00
|
|
|
|
|
|
|
// when
|
|
|
|
var overlays = viewer.get('overlays'),
|
|
|
|
elementRegistry = viewer.get('elementRegistry');
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(overlays).toBeDefined();
|
|
|
|
expect(elementRegistry).toBeDefined();
|
|
|
|
|
|
|
|
// given
|
2014-11-17 17:36:22 +01:00
|
|
|
var subProcessShape = elementRegistry.get('SubProcess_1');
|
2014-08-05 17:02:03 +02:00
|
|
|
|
|
|
|
// when
|
|
|
|
overlays.add('SubProcess_1', {
|
|
|
|
position: {
|
|
|
|
bottom: 0,
|
|
|
|
right: 0
|
|
|
|
},
|
|
|
|
html: '<div style="max-width: 50px">YUP GREAT STUFF!</div>'
|
|
|
|
});
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(overlays.get({ element: 'SubProcess_1' }).length).toBe(1);
|
|
|
|
|
|
|
|
done(err);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-04-03 21:20:13 +02:00
|
|
|
describe('error handling', function() {
|
2014-03-21 21:10:01 +01:00
|
|
|
|
2014-05-23 16:31:28 +02:00
|
|
|
it('should handle non-bpmn input', function(done) {
|
2014-03-17 11:11:25 +01:00
|
|
|
|
2014-04-03 21:20:13 +02:00
|
|
|
var xml = 'invalid stuff';
|
|
|
|
|
2014-06-11 14:41:55 +02:00
|
|
|
createViewer(xml, function(err) {
|
2014-04-03 21:20:13 +02:00
|
|
|
|
|
|
|
expect(err).toBeDefined();
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-05-23 16:31:28 +02:00
|
|
|
|
|
|
|
it('should handle invalid BPMNPlane#bpmnElement', function(done) {
|
|
|
|
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/error/di-plane-no-bpmn-element.bpmn', 'utf8');
|
|
|
|
|
2014-10-28 15:09:17 +01:00
|
|
|
createViewer(xml, function(err, warnings) {
|
|
|
|
|
|
|
|
expect(err).not.toBeDefined();
|
|
|
|
expect(warnings.length).toBe(2);
|
|
|
|
|
|
|
|
expect(warnings[0].message).toEqual('no bpmnElement referenced in <bpmndi:BPMNPlane id="BPMNPlane_1" />');
|
|
|
|
expect(warnings[1].message).toEqual('correcting missing bpmnElement on <bpmndi:BPMNPlane id="BPMNPlane_1" /> to <bpmn:Process id="Process_1" />');
|
2014-05-23 16:31:28 +02:00
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-06-30 19:04:40 +02:00
|
|
|
|
|
|
|
it('should handle missing namespace', function(done) {
|
|
|
|
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/error/missing-namespace.bpmn', 'utf8');
|
|
|
|
|
|
|
|
createViewer(xml, function(err) {
|
|
|
|
expect(err).toBeDefined();
|
|
|
|
expect(err.message).toEqual(
|
|
|
|
'unparsable content <collaboration> detected; this may indicate an invalid BPMN 2.0 diagram file\n' +
|
|
|
|
'\tline: 2\n' +
|
|
|
|
'\tcolumn: 29\n' +
|
|
|
|
'\tnested error: unrecognized element <collaboration>');
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-04-03 21:20:13 +02:00
|
|
|
});
|
2014-03-21 21:10:01 +01:00
|
|
|
|
|
|
|
|
2014-06-17 11:19:31 +02:00
|
|
|
describe('dependency injection', function() {
|
|
|
|
|
|
|
|
it('should be available via di as <bpmnjs>', function(done) {
|
|
|
|
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/simple.bpmn', 'utf8');
|
|
|
|
|
2014-10-28 15:09:17 +01:00
|
|
|
createViewer(xml, function(err, warnings, viewer) {
|
2014-06-17 11:19:31 +02:00
|
|
|
|
|
|
|
expect(viewer.get('bpmnjs')).toBe(viewer);
|
|
|
|
|
|
|
|
done(err);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-04-03 21:20:13 +02:00
|
|
|
describe('export', function() {
|
2014-03-21 21:10:01 +01:00
|
|
|
|
2014-08-06 15:21:55 +02:00
|
|
|
function currentTime() {
|
|
|
|
return new Date().getTime();
|
|
|
|
}
|
|
|
|
|
|
|
|
function isValid(svg) {
|
|
|
|
var expectedStart = '<?xml version="1.0" encoding="utf-8"?>';
|
|
|
|
var expectedEnd = '</svg>';
|
|
|
|
|
|
|
|
expect(svg.indexOf(expectedStart)).toEqual(0);
|
|
|
|
expect(svg.indexOf(expectedEnd)).toEqual(svg.length - expectedEnd.length);
|
|
|
|
|
|
|
|
// ensure correct rendering of SVG contents
|
|
|
|
expect(svg.indexOf('undefined')).toBe(-1);
|
|
|
|
|
|
|
|
// expect header to be written only once
|
|
|
|
expect(svg.indexOf('<svg width="100%" height="100%">')).toBe(-1);
|
|
|
|
expect(svg.indexOf('<g class="viewport"')).toBe(-1);
|
|
|
|
|
|
|
|
// FIXME(nre): make matcher
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-04-03 21:20:13 +02:00
|
|
|
it('should export svg', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/empty-definitions.bpmn', 'utf8');
|
|
|
|
|
2014-10-28 15:09:17 +01:00
|
|
|
createViewer(xml, function(err, warnings, viewer) {
|
2014-04-03 21:20:13 +02:00
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
// when
|
2014-08-01 07:55:47 +02:00
|
|
|
viewer.saveSVG(function(err, svg) {
|
2014-04-03 21:20:13 +02:00
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
// then
|
2014-08-06 15:21:55 +02:00
|
|
|
expect(isValid(svg)).toBe(true);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('should export complex svg', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/complex.bpmn', 'utf8');
|
|
|
|
|
2014-10-28 15:09:17 +01:00
|
|
|
createViewer(xml, function(err, warnings, viewer) {
|
2014-08-06 15:21:55 +02:00
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
var time = currentTime();
|
2014-04-03 21:20:13 +02:00
|
|
|
|
2014-08-06 15:21:55 +02:00
|
|
|
// when
|
|
|
|
viewer.saveSVG(function(err, svg) {
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(isValid(svg)).toBe(true);
|
2014-05-23 10:58:44 +02:00
|
|
|
|
2014-08-06 15:21:55 +02:00
|
|
|
// no svg export should take more than 500ms
|
|
|
|
expect(currentTime() - time).toBeLessThan(500);
|
2014-05-28 12:19:35 +02:00
|
|
|
|
2014-08-17 12:17:15 +02:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should remove outer-makers on export', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/complex.bpmn', 'utf8');
|
|
|
|
function appendTestRect(svgDoc) {
|
|
|
|
var rect = document.createElementNS(svgDoc.namespaceURI, 'rect');
|
|
|
|
rect.setAttribute('class', 'outer-bound-marker');
|
|
|
|
rect.setAttribute('width', 500);
|
|
|
|
rect.setAttribute('height', 500);
|
|
|
|
rect.setAttribute('x', 10000);
|
|
|
|
rect.setAttribute('y', 10000);
|
|
|
|
svgDoc.appendChild(rect);
|
|
|
|
}
|
|
|
|
|
2014-10-28 15:09:17 +01:00
|
|
|
createViewer(xml, function(err, warnings, viewer) {
|
2014-08-17 12:17:15 +02:00
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
var svgDoc = viewer.container.childNodes[1].childNodes[1];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
appendTestRect(svgDoc);
|
|
|
|
appendTestRect(svgDoc);
|
|
|
|
|
|
|
|
expect(svgDoc.querySelectorAll('.outer-bound-marker')).toBeDefined();
|
|
|
|
|
|
|
|
// when
|
|
|
|
viewer.saveSVG(function(err, svg) {
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
var svgDoc = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
|
|
|
|
svgDoc.innerHTML = svg;
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(isValid(svg)).toBe(true);
|
|
|
|
expect(svgDoc.querySelector('.outer-bound-marker')).toBeNull();
|
|
|
|
|
2014-04-03 21:20:13 +02:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2014-03-17 11:11:25 +01:00
|
|
|
});
|
2014-04-03 21:20:13 +02:00
|
|
|
|
2014-03-17 11:11:25 +01:00
|
|
|
});
|
2014-03-21 21:10:01 +01:00
|
|
|
|
2014-08-01 07:55:47 +02:00
|
|
|
describe('configuration', function() {
|
|
|
|
|
|
|
|
var testModules = [
|
|
|
|
{ logger: [ 'type', function() { this.called = true; } ] }
|
|
|
|
];
|
|
|
|
|
|
|
|
// given
|
|
|
|
var xml = fs.readFileSync('test/fixtures/bpmn/empty-definitions.bpmn', 'utf8');
|
|
|
|
|
|
|
|
|
|
|
|
it('should override default modules', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var viewer = new Viewer({ container: container, modules: testModules });
|
|
|
|
|
|
|
|
// when
|
|
|
|
viewer.importXML(xml, function(err) {
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(err.message).toBe('No provider for "bpmnImporter"! (Resolving: bpmnImporter)');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('should add module to default modules', function(done) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var viewer = new Viewer({ container: container, additionalModules: testModules });
|
|
|
|
|
|
|
|
// when
|
|
|
|
viewer.importXML(xml, function(err) {
|
|
|
|
|
|
|
|
// then
|
|
|
|
var logger = viewer.get('logger');
|
|
|
|
expect(logger.called).toBe(true);
|
|
|
|
|
|
|
|
done(err);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2014-03-13 16:06:30 +01:00
|
|
|
});
|