From bc12c534037c7e3c1972bd103d5130bf746ff633 Mon Sep 17 00:00:00 2001 From: Jeremy Press Date: Tue, 14 Nov 2017 13:19:22 -0800 Subject: [PATCH] Fix: Correctly revoke objectURL for print blob in office viewer (#482) --- src/lib/viewers/office/OfficeViewer.js | 14 ++++++++++---- .../viewers/office/__tests__/OfficeViewer-test.js | 9 +++++++-- 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/src/lib/viewers/office/OfficeViewer.js b/src/lib/viewers/office/OfficeViewer.js index d294dd978..f1da2fa08 100644 --- a/src/lib/viewers/office/OfficeViewer.js +++ b/src/lib/viewers/office/OfficeViewer.js @@ -50,6 +50,11 @@ class OfficeViewer extends BaseViewer { if (this.printPopup) { this.printPopup.destroy(); } + + if (this.printURL) { + URL.revokeObjectURL(this.printURL); + } + super.destroy(); } @@ -331,8 +336,11 @@ class OfficeViewer extends BaseViewer { // For other browsers, open and print in a new tab } else { - const printURL = URL.createObjectURL(this.printBlob); - const printResult = window.open(printURL); + if (!this.printURL) { + this.printURL = URL.createObjectURL(this.printBlob); + } + + const printResult = window.open(this.printURL); // Open print popup if possible if (printResult && typeof printResult.print === 'function') { @@ -360,8 +368,6 @@ class OfficeViewer extends BaseViewer { } else { this.emit('printsuccess'); } - - URL.revokeObjectURL(printURL); } } } diff --git a/src/lib/viewers/office/__tests__/OfficeViewer-test.js b/src/lib/viewers/office/__tests__/OfficeViewer-test.js index b472f6c48..a80b3ef70 100644 --- a/src/lib/viewers/office/__tests__/OfficeViewer-test.js +++ b/src/lib/viewers/office/__tests__/OfficeViewer-test.js @@ -92,6 +92,13 @@ describe('lib/viewers/office/OfficeViewer', () => { office.destroy(); expect(office.printBlob).to.equal(null); }); + + it('should revoke the printURL object', () => { + sandbox.stub(URL, 'revokeObjectURL'); + office.printURL = 'someblob'; + office.destroy(); + expect(URL.revokeObjectURL).to.be.calledWith(office.printURL); + }); }); describe('load()', () => { @@ -382,7 +389,6 @@ describe('lib/viewers/office/OfficeViewer', () => { stubs.createObject = sandbox.stub(URL, 'createObjectURL'); stubs.open = sandbox.stub(window, 'open').returns(false); stubs.browser = sandbox.stub(Browser, 'getName').returns('Chrome'); - stubs.revokeObjectURL = sandbox.stub(URL, 'revokeObjectURL'); stubs.printResult = { print: sandbox.stub(), addEventListener: sandbox.stub() @@ -429,7 +435,6 @@ describe('lib/viewers/office/OfficeViewer', () => { expect(stubs.open).to.be.called.with; expect(stubs.browser).to.be.called; expect(stubs.emit).to.be.called; - expect(stubs.revokeObjectURL).to.be.called; }); it('should use a timeout in safari', () => {