bpmn-js/test/spec/features/modeling/behavior/FixHoverBehaviorSpec.js
Nico Rehwaldt 6c02ecde34 fix(modeling): if we fix hover, we gotta fix out, too
This ensures our FixHoverBehavior (that ensures we drop onto /
connect to participants, not lanes) does fix the hover element
during *.out, too.

Otherwise there is no way for other behaviors to correctly
remove hover indicators.

Closes https://github.com/bpmn-io/bpmn-js/issues/1413
2021-01-28 11:11:27 +01:00

616 lines
17 KiB
JavaScript

import {
bootstrapModeler,
inject
} from 'test/TestHelper';
import coreModule from 'lib/core';
import createModule from 'diagram-js/lib/features/create';
import modelingModule from 'lib/features/modeling';
import moveModule from 'diagram-js/lib/features/move';
import globalConnectModule from 'diagram-js/lib/features/global-connect';
import connectionPreview from 'diagram-js/lib/features/connection-preview';
import bendpointsModule from 'diagram-js/lib/features/bendpoints';
import { createCanvasEvent as canvasEvent } from '../../../../util/MockEvents';
var testModules = [
coreModule,
createModule,
moveModule,
modelingModule
];
describe('features/modeling/behavior - fix hover', function() {
describe('drop on lane', function() {
var diagramXML = require('./FixHoverBehavior.participant.bpmn');
beforeEach(bootstrapModeler(diagramXML, {
modules: testModules
}));
beforeEach(inject(function(dragging) {
dragging.setOptions({ manual: true });
}));
var lane,
laneGfx,
participant,
participantGfx;
beforeEach(inject(function(elementRegistry) {
participant = elementRegistry.get('Participant_1');
participantGfx = elementRegistry.getGraphics(participant);
lane = elementRegistry.get('Lane_1');
laneGfx = elementRegistry.getGraphics(lane);
}));
describe('create', function() {
it('should <create.hover> participant', inject(
function(create, dragging, elementFactory) {
// given
var task = elementFactory.createShape({ type: 'bpmn:Task' });
create.start(canvasEvent({ x: 0, y: 0 }), task, true);
// when
dragging.hover({ element: lane, gfx: laneGfx });
dragging.move(canvasEvent({ x: 200, y: 200 }));
dragging.end();
// then
expect(task.parent).to.equal(participant);
}
));
it('should <create.out> participant', inject(
function(create, dragging, elementFactory, eventBus) {
// given
var task = elementFactory.createShape({ type: 'bpmn:Task' });
var outSpy = sinon.spy(function(event) {
expect(event.hover).to.eql(participant);
expect(event.hoverGfx).to.eql(participantGfx);
});
eventBus.on('create.out', outSpy);
create.start(canvasEvent({ x: 0, y: 0 }), task, true);
dragging.hover({ element: lane, gfx: laneGfx });
dragging.move(canvasEvent({ x: 200, y: 200 }));
// when
dragging.out({ element: lane, gfx: laneGfx });
dragging.end();
// then
expect(outSpy).to.have.been.calledOnce;
}
));
});
describe('move', function() {
it('should <shape.move.hover> participant', inject(
function(dragging, elementRegistry, move) {
// given
var task = elementRegistry.get('Task_1');
move.start(canvasEvent({ x: 440, y: 220 }), task, true);
// when
dragging.hover({ element: lane, gfx: laneGfx });
dragging.move(canvasEvent({ x: 240, y: 220 }));
dragging.end();
// then
expect(task.parent).to.equal(participant);
}
));
it('should <shape.move.out> participant', inject(
function(dragging, elementRegistry, move, eventBus) {
// given
var task = elementRegistry.get('Task_1');
var outSpy = sinon.spy(function(event) {
expect(event.hover).to.eql(participant);
expect(event.hoverGfx).to.eql(participantGfx);
});
eventBus.on('shape.move.out', outSpy);
move.start(canvasEvent({ x: 440, y: 220 }), task, true);
dragging.hover({ element: lane, gfx: laneGfx });
dragging.move(canvasEvent({ x: 240, y: 220 }));
// when
dragging.out({ element: lane, gfx: laneGfx });
// then
expect(outSpy).to.have.been.calledOnce;
}
));
});
});
describe('label', function() {
var diagramXML = require('./FixHoverBehavior.label.bpmn');
beforeEach(bootstrapModeler(diagramXML, {
modules: testModules
}));
beforeEach(inject(function(dragging) {
dragging.setOptions({ manual: true });
}));
describe('move', function() {
it('should <shape.move.hover> root', inject(
function(dragging, elementRegistry, move, canvas) {
// given
var startEvent = elementRegistry.get('StartEvent');
var label = startEvent.label;
move.start(canvasEvent({ x: 175, y: 150 }), label, true);
// when
dragging.hover({ element: startEvent, gfx: elementRegistry.getGraphics(startEvent) });
dragging.move(canvasEvent({ x: 240, y: 220 }));
dragging.end();
// then
expect(label.parent).to.equal(canvas.getRootElement());
}
));
});
});
describe('group', function() {
var diagramXML = require('./FixHoverBehavior.group.bpmn');
beforeEach(bootstrapModeler(diagramXML, {
modules: testModules
}));
beforeEach(inject(function(dragging) {
dragging.setOptions({ manual: true });
}));
describe('create', function() {
it('should <create.hover> root', inject(
function(dragging, elementFactory, elementRegistry, create, canvas) {
// given
var task = elementRegistry.get('Task');
var group = elementFactory.createShape({ type: 'bpmn:Group' });
create.start(canvasEvent({ x: 0, y: 0 }), group, true);
// when
dragging.hover({ element: task, gfx: elementRegistry.getGraphics(task) });
dragging.move(canvasEvent({ x: 240, y: 220 }));
dragging.end();
// then
expect(group.parent).to.equal(canvas.getRootElement());
}
));
});
describe('move', function() {
it('should <shape.move.hover> root', inject(
function(dragging, elementRegistry, move, canvas) {
// given
var task = elementRegistry.get('Task');
var group = elementRegistry.get('Group');
move.start(canvasEvent({ x: 175, y: 150 }), group, true);
// when
dragging.hover({ element: task, gfx: elementRegistry.getGraphics(task) });
dragging.move(canvasEvent({ x: 240, y: 220 }));
dragging.end();
// then
expect(group.parent).to.equal(canvas.getRootElement());
}
));
});
});
describe('connect lane', function() {
var diagramXML = require('./FixHoverBehavior.lane-connect.bpmn');
beforeEach(bootstrapModeler(diagramXML, {
modules: testModules.concat([
globalConnectModule,
bendpointsModule,
connectionPreview
])
}));
beforeEach(inject(function(dragging) {
dragging.setOptions({ manual: true });
}));
describe('global-connect', function() {
it('should set global connect source to participant', inject(
function(globalConnect, elementRegistry, eventBus, dragging) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var connectSpy = sinon.spy(function(event) {
expect(event.context.startTarget).to.eql(participant_lanes);
});
eventBus.once('global-connect.end', connectSpy);
// when
globalConnect.start(canvasEvent({ x: 0, y: 0 }));
dragging.move(canvasEvent({ x: 150, y: 130 }));
dragging.hover(canvasEvent({ x: 150, y: 130 }, { element: lane_1 }));
dragging.end(canvasEvent({ x: 0, y: 0 }));
// then
expect(connectSpy).to.have.been.called;
}
));
describe('fix hover', function() {
it('on out', inject(
function(globalConnect, dragging, elementRegistry, eventBus) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var connectSpy = sinon.spy(function(event) {
expect(event.hover).to.eql(participant_lanes);
});
// when
globalConnect.start(canvasEvent({ x: 240, y: 0 }));
dragging.move(canvasEvent({ x: 240, y: 300 }));
dragging.hover(canvasEvent({ x: 240, y: 300 }, { element: lane_1 }));
eventBus.once('global-connect.out', connectSpy);
dragging.out();
// then
expect(connectSpy).to.have.been.calledOnce;
}
));
it('on end/cleanup', inject(
function(globalConnect, dragging, elementRegistry, eventBus) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var connectSpy = sinon.spy(function(event) {
expect(event.hover).to.eql(participant_lanes);
});
eventBus.on('global-connect.end', connectSpy);
eventBus.on('global-connect.cleanup', connectSpy);
// when
globalConnect.start(canvasEvent({ x: 240, y: 0 }));
dragging.move(canvasEvent({ x: 240, y: 300 }));
dragging.hover(canvasEvent({ x: 240, y: 300 }, { element: lane_1 }));
dragging.end();
// then
expect(connectSpy).to.have.been.calledTwice;
}
));
});
});
describe('reconnect', function() {
it('should set hover to participant', inject(
function(bendpointMove, elementRegistry, eventBus, dragging) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var messageFlow = elementRegistry.get('MessageFlow_2');
var connectSpy = sinon.spy(function(event) {
expect(event.context.hover).to.equal(participant_lanes);
});
eventBus.once('bendpoint.move.end', connectSpy);
// when
bendpointMove.start(canvasEvent({ x: 240, y: 200 }), messageFlow, 0);
dragging.move(canvasEvent({ x: 240, y: 280 }));
dragging.hover({ element: lane_1, gfx: elementRegistry.getGraphics(lane_1) });
dragging.end();
// then
expect(connectSpy).to.have.been.called;
}
));
it('should set end to participant', inject(
function(bendpointMove, elementRegistry, eventBus, dragging) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var messageFlow = elementRegistry.get('MessageFlow_1');
var connectSpy = sinon.spy(function(event) {
expect(event.context.target).to.eql(participant_lanes);
});
eventBus.once('bendpoint.move.end', connectSpy);
// when
bendpointMove.start(canvasEvent({ x: 240, y: 200 }), messageFlow, 1);
dragging.move(canvasEvent({ x: 240, y: 280 }));
dragging.hover({ element: lane_1, gfx: elementRegistry.getGraphics(lane_1) });
dragging.end();
// then
expect(connectSpy).to.have.been.called;
}
));
});
describe('connect', function() {
it('should set start to participant', inject(
function(connect, dragging, elementRegistry, eventBus) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var participant_no_lanes = elementRegistry.get('Participant_No_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var connectSpy = sinon.spy(function(event) {
expect(event.context.source).to.eql(participant_lanes);
});
eventBus.once('connect.end', connectSpy);
// when
connect.start(canvasEvent({ x: 240, y: 300 }), lane_1);
dragging.move(canvasEvent({ x: 240, y: 0 }));
dragging.hover(canvasEvent({ x: 240, y: 0 }, { element: participant_no_lanes }));
dragging.end();
// then
expect(connectSpy).to.have.been.called;
}
));
it('should set end to participant', inject(
function(connect, dragging, elementRegistry, eventBus) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var participant_no_lanes = elementRegistry.get('Participant_No_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var connectSpy = sinon.spy(function(event) {
var context = event.context,
target = context.target;
expect(target).to.eql(participant_lanes);
});
eventBus.once('connect.end', connectSpy);
// when
connect.start(canvasEvent({ x: 240, y: 0 }), participant_no_lanes);
dragging.move(canvasEvent({ x: 240, y: 300 }));
dragging.hover(canvasEvent({ x: 240, y: 300 }, { element: lane_1 }));
dragging.end();
// then
expect(connectSpy).to.have.been.calledOnce;
}
));
describe('fix hover', function() {
it('on out', inject(
function(connect, dragging, elementRegistry, eventBus) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var participant_no_lanes = elementRegistry.get('Participant_No_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var connectSpy = sinon.spy(function(event) {
expect(event.hover).to.eql(participant_lanes);
});
// when
connect.start(canvasEvent({ x: 240, y: 0 }), participant_no_lanes);
dragging.move(canvasEvent({ x: 240, y: 300 }));
dragging.hover(canvasEvent({ x: 240, y: 300 }, { element: lane_1 }));
eventBus.once('connect.out', connectSpy);
dragging.out();
// then
expect(connectSpy).to.have.been.calledOnce;
}
));
it('on end/cleanup', inject(
function(connect, dragging, elementRegistry, eventBus) {
// given
var participant_lanes = elementRegistry.get('Participant_Lanes');
var participant_no_lanes = elementRegistry.get('Participant_No_Lanes');
var lane_1 = elementRegistry.get('Lane_1');
var connectSpy = sinon.spy(function(event) {
expect(event.hover).to.eql(participant_lanes);
});
eventBus.on('connect.end', connectSpy);
eventBus.on('connect.cleanup', connectSpy);
// when
connect.start(canvasEvent({ x: 240, y: 0 }), participant_no_lanes);
dragging.move(canvasEvent({ x: 240, y: 300 }));
dragging.hover(canvasEvent({ x: 240, y: 300 }, { element: lane_1 }));
dragging.end();
// then
expect(connectSpy).to.have.been.calledTwice;
}
));
});
});
});
describe('participant with lane', function() {
var diagramXML = require('./FixHoverBehavior.lane-connect.bpmn');
beforeEach(bootstrapModeler(diagramXML, {
modules: testModules.concat([
globalConnectModule,
bendpointsModule
])
}));
beforeEach(inject(function(dragging) {
dragging.setOptions({ manual: true });
}));
it('should move the participant when lane is dragged', inject(
function(canvas, eventBus, elementRegistry, move, dragging) {
// given
var lane = elementRegistry.get('Lane_1'),
participant = elementRegistry.get('Participant_Lanes');
var rootElement = canvas.getRootElement(),
rootElementGfx = canvas.getGraphics(rootElement);
var moveEndSpy = sinon.spy(function(event) {
expect(event.context.shape).to.equal(participant);
});
eventBus.on('shape.move.end', moveEndSpy);
// when
move.start(canvasEvent({ x: 100, y: 100 }), lane);
dragging.move(canvasEvent({ x: 140, y: 120 }));
dragging.hover({
element: rootElement,
gfx: rootElementGfx
});
dragging.end();
// then
expect(moveEndSpy).to.have.been.calledOnce;
}
));
});
});