123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308 |
- import {
- bootstrapDiagram,
- inject
- } from 'test/TestHelper';
- import modelingModule from 'lib/features/modeling';
- describe('features/modeling - attach shape', function() {
- beforeEach(bootstrapDiagram({ modules: [ modelingModule ] }));
- var rootShape, oldHostShape, hostShape, attachedShape, detachedShape;
- beforeEach(inject(function(elementFactory, canvas) {
- rootShape = elementFactory.createRoot({
- id: 'root'
- });
- canvas.setRootElement(rootShape);
- oldHostShape = elementFactory.createShape({
- id: 'parent',
- x: 100, y: 100,
- width: 300, height: 300
- });
- canvas.addShape(oldHostShape, rootShape);
- hostShape = elementFactory.createShape({
- id: 'hostShape',
- x: 700, y: 100,
- width: 100, height: 100
- });
- canvas.addShape(hostShape, rootShape);
- attachedShape = elementFactory.createShape({
- id: 'attachedShape',
- x: 400, y: 110,
- width: 50, height: 50,
- host: oldHostShape
- });
- canvas.addShape(attachedShape, rootShape);
- detachedShape = elementFactory.createShape({
- id: 'detachedShape',
- x: 400, y: 400,
- width: 50, height: 50
- });
- canvas.addShape(detachedShape, rootShape);
- }));
- describe('initial state', function() {
- it('should have wired host <-> attachers', inject(function() {
- // assume
- expect(oldHostShape.attachers).to.contain(attachedShape);
- expect(oldHostShape.attachers).not.to.contain(detachedShape);
- expect(attachedShape.host).to.eql(oldHostShape);
- expect(detachedShape.host).not.to.exist;
- }));
- });
- describe('detach attached shape', function() {
- it('should execute', inject(function(modeling) {
- // when
- modeling.updateAttachment(attachedShape, null);
- // then
- expect(attachedShape.host).not.to.exist;
- expect(oldHostShape.attachers).not.to.include(attachedShape);
- }));
- it('should undo', inject(function(modeling, commandStack) {
- // given
- modeling.updateAttachment(attachedShape, null);
- // when
- commandStack.undo();
- // then
- expect(attachedShape.host).to.equal(oldHostShape);
- expect(oldHostShape.attachers).to.include(attachedShape);
- }));
- it('should redo', inject(function(modeling, commandStack) {
- // given
- modeling.updateAttachment(attachedShape, null);
- commandStack.undo();
- // when
- commandStack.redo();
- // then
- expect(attachedShape.host).not.to.exist;
- expect(oldHostShape.attachers).not.to.include(attachedShape);
- }));
- });
- describe('attach detached shape', function() {
- it('should execute', inject(function(modeling) {
- // when
- modeling.updateAttachment(detachedShape, hostShape);
- // then
- expect(detachedShape.host).to.equal(hostShape);
- expect(hostShape.attachers).to.include(detachedShape);
- }));
- it('should undo', inject(function(modeling, commandStack) {
- // given
- modeling.updateAttachment(detachedShape, hostShape);
- // when
- commandStack.undo();
- // then
- expect(detachedShape.host).not.to.exist;
- expect(hostShape.attachers).not.to.include(detachedShape);
- }));
- it('should redo', inject(function(modeling, commandStack) {
- // given
- modeling.updateAttachment(detachedShape, hostShape);
- commandStack.undo();
- // when
- commandStack.redo();
- // then
- expect(detachedShape.host).to.equal(hostShape);
- expect(hostShape.attachers).to.include(detachedShape);
- }));
- });
- describe('reattach attached shape', function() {
- it('should execute', inject(function(modeling) {
- // when
- modeling.updateAttachment(attachedShape, hostShape);
- // then
- expect(attachedShape.host).to.equal(hostShape);
- expect(hostShape.attachers).to.include(attachedShape);
- expect(oldHostShape.attachers).not.to.include(attachedShape);
- }));
- it('should undo', inject(function(modeling, commandStack) {
- // given
- modeling.updateAttachment(attachedShape, hostShape);
- // when
- commandStack.undo();
- // then
- expect(attachedShape.host).to.equal(oldHostShape);
- expect(oldHostShape.attachers).to.include(attachedShape);
- expect(hostShape.attachers).not.to.include(attachedShape);
- }));
- it('should redo', inject(function(modeling, commandStack) {
- // given
- modeling.updateAttachment(attachedShape, hostShape);
- commandStack.undo();
- // when
- commandStack.redo();
- // then
- expect(attachedShape.host).to.equal(hostShape);
- expect(hostShape.attachers).to.include(attachedShape);
- expect(oldHostShape.attachers).not.to.include(attachedShape);
- }));
- });
- describe('connection handling', function() {
- var connectedShape, connectionToAttached, connectionToDetached;
- beforeEach(inject(function(canvas, elementFactory) {
- connectedShape = elementFactory.createShape({
- id: 'connectedShape',
- x: 700, y: 400,
- width: 100, height: 100
- });
- canvas.addShape(connectedShape, rootShape);
- connectionToAttached = elementFactory.createConnection({
- id: 'connectionToAttached',
- waypoints: [
- { x: 400, y: 110 },
- { x: 750, y: 450 }
- ],
- source: attachedShape,
- target: connectedShape
- });
- canvas.addConnection(connectionToAttached, rootShape);
- connectionToDetached = elementFactory.createConnection({
- id: 'connectionToDetached',
- waypoints: [
- { x: 425, y: 425 },
- { x: 750, y: 450 }
- ],
- source: detachedShape,
- target: connectedShape
- });
- canvas.addConnection(connectionToDetached, rootShape);
- }));
- it('should keep connection when reattaching', inject(function(modeling) {
- // when
- modeling.updateAttachment(attachedShape, hostShape);
- // then
- expect(attachedShape.outgoing).to.have.lengthOf(1);
- expect(connectedShape.incoming).to.have.lengthOf(2);
- }));
- it('should keep connection when detaching', inject(function(modeling) {
- // when
- modeling.updateAttachment(attachedShape, null);
- // then
- expect(attachedShape.outgoing).to.have.lengthOf(1);
- expect(connectedShape.incoming).to.have.lengthOf(2);
- }));
- it('should keep connection when attaching', inject(function(modeling) {
- // when
- modeling.updateAttachment(detachedShape, hostShape);
- // then
- expect(detachedShape.outgoing).to.have.lengthOf(1);
- expect(connectedShape.incoming).to.have.lengthOf(2);
- }));
- it('should keep connection when undoing detach', inject(function(modeling, commandStack) {
- // given
- modeling.updateAttachment(attachedShape, null);
- // when
- commandStack.undo();
- // then
- expect(attachedShape.outgoing).to.have.lengthOf(1);
- expect(connectedShape.incoming).to.have.lengthOf(2);
- }));
- });
- });
|