From dc34dff498d37b7b13afefd071c5c9c67101d227 Mon Sep 17 00:00:00 2001 From: Nico Rehwaldt Date: Fri, 10 Dec 2021 11:35:34 +0100 Subject: [PATCH] test(drilldown): verify back and forth persistent viewboxes --- test/spec/features/drilldown/DrilldownSpec.js | 45 +++++++++++++++++++ 1 file changed, 45 insertions(+) diff --git a/test/spec/features/drilldown/DrilldownSpec.js b/test/spec/features/drilldown/DrilldownSpec.js index ad35ba47..43c137c0 100644 --- a/test/spec/features/drilldown/DrilldownSpec.js +++ b/test/spec/features/drilldown/DrilldownSpec.js @@ -20,6 +20,7 @@ describe('features - drilldown', function() { beforeEach(bootstrapViewer(multiLayerXML, { modules: testModules })); + describe('Overlays', function() { it('should show overlay on Subprocess with content', inject(function(elementRegistry, overlays) { @@ -209,6 +210,50 @@ describe('features - drilldown', function() { expect(newViewbox.scale).to.eql(zoomedAndScrolledViewbox.scale); })); + + it('should remember scroll and zoom', inject(function(canvas) { + + // given + var rootRoot = canvas.getRootElement(); + var planeRoot = canvas.findRoot('collapsedProcess_plane'); + + canvas.scroll({ dx: 500, dy: 500 }); + canvas.zoom(0.5); + + var rootViewbox = canvas.viewbox(); + + canvas.setRootElement(planeRoot); + canvas.scroll({ dx: 100, dy: 100 }); + + var planeViewbox = canvas.viewbox(); + + // when + canvas.setRootElement(rootRoot); + + // then + expectViewbox(rootViewbox); + + // but when + canvas.setRootElement(planeRoot); + + // then + expectViewbox(planeViewbox); + })); + + + // helpers ////////// + + function expectViewbox(expectedViewbox) { + return getBpmnJS().invoke(function(canvas) { + + var viewbox = canvas.viewbox(); + + expect(viewbox.x).to.eql(expectedViewbox.x); + expect(viewbox.y).to.eql(expectedViewbox.y); + expect(viewbox.scale).to.eql(expectedViewbox.scale); + }); + } + });