From e3efa16415ac090b38bd87d6b509ccecc90cefa0 Mon Sep 17 00:00:00 2001 From: Frank Pian Date: Thu, 8 Sep 2022 05:47:06 +0800 Subject: [PATCH] fix: session.getBlobData never resolves with blob sizes > 65536 (#35277) * fix: session.getBlobData never resolves with blob sizes > 65536 (#34398) * Add unit test case for session.getBlobData Co-authored-by: John Kleinschmidt --- .../api/electron_api_data_pipe_holder.cc | 5 ++- spec/api-session-spec.ts | 44 +++++++++++++++++++ 2 files changed, 48 insertions(+), 1 deletion(-) diff --git a/shell/browser/api/electron_api_data_pipe_holder.cc b/shell/browser/api/electron_api_data_pipe_holder.cc index f33f1d9b85b..67fe81959a1 100644 --- a/shell/browser/api/electron_api_data_pipe_holder.cc +++ b/shell/browser/api/electron_api_data_pipe_holder.cc @@ -86,8 +86,11 @@ class DataPipeReader { if (result == MOJO_RESULT_OK) { // success remaining_size_ -= length; head_ += length; - if (remaining_size_ == 0) + if (remaining_size_ == 0) { OnSuccess(); + } else { + handle_watcher_.ArmOrNotify(); + } } else if (result == MOJO_RESULT_SHOULD_WAIT) { // IO pending handle_watcher_.ArmOrNotify(); } else { // error diff --git a/spec/api-session-spec.ts b/spec/api-session-spec.ts index 1aa8fdc6fd3..019317a5100 100644 --- a/spec/api-session-spec.ts +++ b/spec/api-session-spec.ts @@ -529,6 +529,50 @@ describe('session module', () => { }); }); + describe('ses.getBlobData2()', () => { + const scheme = 'cors-blob'; + const protocol = session.defaultSession.protocol; + const url = `${scheme}://host`; + after(async () => { + await protocol.unregisterProtocol(scheme); + }); + afterEach(closeAllWindows); + + it('returns blob data for uuid', (done) => { + const content = ` + + `; + + protocol.registerStringProtocol(scheme, (request, callback) => { + try { + if (request.method === 'GET') { + callback({ data: content, mimeType: 'text/html' }); + } else if (request.method === 'POST') { + const uuid = request.uploadData![1].blobUUID; + expect(uuid).to.be.a('string'); + session.defaultSession.getBlobData(uuid!).then(result => { + try { + const data = new Array(65_537).fill('a'); + expect(result.toString()).to.equal(data.join('')); + done(); + } catch (e) { + done(e); + } + }); + } + } catch (e) { + done(e); + } + }); + const w = new BrowserWindow({ show: false }); + w.loadURL(url); + }); + }); + describe('ses.setCertificateVerifyProc(callback)', () => { let server: http.Server;