From 7d7ae34e34f4b8863277e1e5170032d00ba83ab5 Mon Sep 17 00:00:00 2001 From: Calixte Denizet Date: Thu, 20 Jun 2024 10:52:28 +0200 Subject: [PATCH] [Editor] Don't create an observer for the stamp annotation after the viewer has been closed --- src/display/editor/stamp.js | 5 +++++ test/integration/stamp_editor_spec.mjs | 27 ++++++++++++++------------ 2 files changed, 20 insertions(+), 12 deletions(-) diff --git a/src/display/editor/stamp.js b/src/display/editor/stamp.js index 7d159357d0251..6b150471c6fbf 100644 --- a/src/display/editor/stamp.js +++ b/src/display/editor/stamp.js @@ -538,6 +538,11 @@ class StampEditor extends AnnotationEditor { * Create the resize observer. */ #createObserver() { + if (!this._uiManager._signal) { + // This method is called after the canvas has been created but the canvas + // creation is async, so it's possible that the viewer has been closed. + return; + } this.#observer = new ResizeObserver(entries => { const rect = entries[0].contentRect; if (rect.width && rect.height) { diff --git a/test/integration/stamp_editor_spec.mjs b/test/integration/stamp_editor_spec.mjs index 62438dc6dbf12..ba3d53f062d19 100644 --- a/test/integration/stamp_editor_spec.mjs +++ b/test/integration/stamp_editor_spec.mjs @@ -597,18 +597,19 @@ describe("Stamp Editor", () => { await Promise.all( pages.map(async ([browserName, page]) => { await switchToStamp(page); + const selector = getEditorSelector(0); await copyImage(page, "../images/firefox_logo.png", 0); - await page.waitForSelector(getEditorSelector(0)); + await page.waitForSelector(selector); await waitForSerialized(page, 1); - await page.waitForSelector(`${getEditorSelector(0)} button.delete`); - await page.click(`${getEditorSelector(0)} button.delete`); + await page.waitForSelector(`${selector} button.delete`); + await page.click(`${selector} button.delete`); await waitForSerialized(page, 0); await kbUndo(page); await waitForSerialized(page, 1); - await page.waitForSelector(getEditorSelector(0)); + await page.waitForSelector(`${selector} canvas`); }) ); }); @@ -629,13 +630,14 @@ describe("Stamp Editor", () => { await Promise.all( pages.map(async ([browserName, page]) => { await switchToStamp(page); + const selector = getEditorSelector(0); await copyImage(page, "../images/firefox_logo.png", 0); - await page.waitForSelector(getEditorSelector(0)); + await page.waitForSelector(selector); await waitForSerialized(page, 1); - await page.waitForSelector(`${getEditorSelector(0)} button.delete`); - await page.click(`${getEditorSelector(0)} button.delete`); + await page.waitForSelector(`${selector} button.delete`); + await page.click(`${selector} button.delete`); await waitForSerialized(page, 0); const twoToFourteen = Array.from(new Array(13).keys(), n => n + 2); @@ -653,7 +655,7 @@ describe("Stamp Editor", () => { await scrollIntoView(page, pageSelector); } - await page.waitForSelector(getEditorSelector(0)); + await page.waitForSelector(`${selector} canvas`); }) ); }); @@ -674,13 +676,14 @@ describe("Stamp Editor", () => { await Promise.all( pages.map(async ([browserName, page]) => { await switchToStamp(page); + const selector = getEditorSelector(0); await copyImage(page, "../images/firefox_logo.png", 0); - await page.waitForSelector(getEditorSelector(0)); + await page.waitForSelector(selector); await waitForSerialized(page, 1); - await page.waitForSelector(`${getEditorSelector(0)} button.delete`); - await page.click(`${getEditorSelector(0)} button.delete`); + await page.waitForSelector(`${selector} button.delete`); + await page.click(`${selector} button.delete`); await waitForSerialized(page, 0); const twoToOne = Array.from(new Array(13).keys(), n => n + 2).concat( @@ -693,7 +696,7 @@ describe("Stamp Editor", () => { await kbUndo(page); await waitForSerialized(page, 1); - await page.waitForSelector(getEditorSelector(0)); + await page.waitForSelector(`${selector} canvas`); }) ); });