From 8b110fdc513141e99848ae236860741e48cc31ff Mon Sep 17 00:00:00 2001 From: Jukka Kurkela Date: Sun, 20 Jan 2019 09:09:21 +0200 Subject: [PATCH] Handle any element in triggerMouseEvent in tests (#5994) --- test/specs/controller.polarArea.tests.js | 16 ++++++++-------- test/utils.js | 19 +++++++++++++++++-- 2 files changed, 25 insertions(+), 10 deletions(-) diff --git a/test/specs/controller.polarArea.tests.js b/test/specs/controller.polarArea.tests.js index fed7979e939..d439251fa4f 100644 --- a/test/specs/controller.polarArea.tests.js +++ b/test/specs/controller.polarArea.tests.js @@ -281,12 +281,12 @@ describe('Chart.controllers.polarArea', function() { var chart = this.chart; var arc = chart.getDatasetMeta(0).data[0]; - jasmine.triggerMouseEvent(chart, 'mousemove', {_model: arc.getCenterPoint()}); + jasmine.triggerMouseEvent(chart, 'mousemove', arc); expect(arc._model.backgroundColor).toBe('rgb(49, 135, 221)'); expect(arc._model.borderColor).toBe('rgb(22, 89, 156)'); expect(arc._model.borderWidth).toBe(2); - jasmine.triggerMouseEvent(chart, 'mouseout', {_model: arc.getCenterPoint()}); + jasmine.triggerMouseEvent(chart, 'mouseout', arc); expect(arc._model.backgroundColor).toBe('rgb(100, 150, 200)'); expect(arc._model.borderColor).toBe('rgb(50, 100, 150)'); expect(arc._model.borderWidth).toBe(2); @@ -304,12 +304,12 @@ describe('Chart.controllers.polarArea', function() { chart.update(); - jasmine.triggerMouseEvent(chart, 'mousemove', {_model: arc.getCenterPoint()}); + jasmine.triggerMouseEvent(chart, 'mousemove', arc); expect(arc._model.backgroundColor).toBe('rgb(200, 100, 150)'); expect(arc._model.borderColor).toBe('rgb(150, 50, 100)'); expect(arc._model.borderWidth).toBe(8.4); - jasmine.triggerMouseEvent(chart, 'mouseout', {_model: arc.getCenterPoint()}); + jasmine.triggerMouseEvent(chart, 'mouseout', arc); expect(arc._model.backgroundColor).toBe('rgb(100, 150, 200)'); expect(arc._model.borderColor).toBe('rgb(50, 100, 150)'); expect(arc._model.borderWidth).toBe(2); @@ -327,12 +327,12 @@ describe('Chart.controllers.polarArea', function() { chart.update(); - jasmine.triggerMouseEvent(chart, 'mousemove', {_model: arc.getCenterPoint()}); + jasmine.triggerMouseEvent(chart, 'mousemove', arc); expect(arc._model.backgroundColor).toBe('rgb(200, 100, 150)'); expect(arc._model.borderColor).toBe('rgb(150, 50, 100)'); expect(arc._model.borderWidth).toBe(8.4); - jasmine.triggerMouseEvent(chart, 'mouseout', {_model: arc.getCenterPoint()}); + jasmine.triggerMouseEvent(chart, 'mouseout', arc); expect(arc._model.backgroundColor).toBe('rgb(100, 150, 200)'); expect(arc._model.borderColor).toBe('rgb(50, 100, 150)'); expect(arc._model.borderWidth).toBe(2); @@ -350,12 +350,12 @@ describe('Chart.controllers.polarArea', function() { chart.update(); - jasmine.triggerMouseEvent(chart, 'mousemove', {_model: arc.getCenterPoint()}); + jasmine.triggerMouseEvent(chart, 'mousemove', arc); expect(arc._model.backgroundColor).toBe('rgb(200, 100, 150)'); expect(arc._model.borderColor).toBe('rgb(150, 50, 100)'); expect(arc._model.borderWidth).toBe(8.4); - jasmine.triggerMouseEvent(chart, 'mouseout', {_model: arc.getCenterPoint()}); + jasmine.triggerMouseEvent(chart, 'mouseout', arc); expect(arc._model.backgroundColor).toBe('rgb(100, 150, 200)'); expect(arc._model.borderColor).toBe('rgb(50, 100, 150)'); expect(arc._model.borderWidth).toBe(2); diff --git a/test/utils.js b/test/utils.js index c9e9ae012fa..5cc361bb86f 100644 --- a/test/utils.js +++ b/test/utils.js @@ -106,12 +106,27 @@ function waitForResize(chart, callback) { }; } +function _resolveElementPoint(el) { + var point = {x: 0, y: 0}; + if (el) { + if (typeof el.getCenterPoint === 'function') { + point = el.getCenterPoint(); + } else if (el.x !== undefined && el.y !== undefined) { + point = el; + } else if (el._model && el._model.x !== undefined && el._model.y !== undefined) { + point = el._model; + } + } + return point; +} + function triggerMouseEvent(chart, type, el) { var node = chart.canvas; var rect = node.getBoundingClientRect(); + var point = _resolveElementPoint(el); var event = new MouseEvent(type, { - clientX: rect.left + el._model.x, - clientY: rect.top + el._model.y, + clientX: rect.left + point.x, + clientY: rect.top + point.y, cancelable: true, bubbles: true, view: window