From 71926ed1d40fb2469839c2695055d2641d516886 Mon Sep 17 00:00:00 2001 From: Sumedha Pramod Date: Wed, 20 Dec 2017 14:14:22 -0800 Subject: [PATCH] Fix: Uncaught errors in drawingModeController.handleSelection() (#87) --- src/controllers/DrawingModeController.js | 2 +- .../__tests__/DrawingModeController-test.js | 12 ++++++++++++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/src/controllers/DrawingModeController.js b/src/controllers/DrawingModeController.js index 92ec283c3..438b17305 100644 --- a/src/controllers/DrawingModeController.js +++ b/src/controllers/DrawingModeController.js @@ -324,7 +324,7 @@ class DrawingModeController extends AnnotationModeController { } const location = this.annotator.getLocationFromEvent(event, TYPES.point); - if (!location) { + if (!location || Object.keys(this.threads).length === 0) { return; } diff --git a/src/controllers/__tests__/DrawingModeController-test.js b/src/controllers/__tests__/DrawingModeController-test.js index 56ed3c3be..b0546e443 100644 --- a/src/controllers/__tests__/DrawingModeController-test.js +++ b/src/controllers/__tests__/DrawingModeController-test.js @@ -410,6 +410,18 @@ describe('controllers/DrawingModeController', () => { expect(stubs.clean).to.not.be.called; }); + it('should do nothing if no drawing threads exist', () => { + stubs.clean = sandbox.stub(controller, 'removeSelection'); + stubs.getLoc.returns({ + x: 15, + y: 15, + page: 1 + }); + controller.threads = {}; + controller.handleSelection('event'); + expect(stubs.clean).to.not.be.called; + }); + it('should call select on an thread found in the data store', () => { stubs.select = sandbox.stub(controller, 'select'); stubs.clean = sandbox.stub(controller, 'removeSelection');