fix: EventSource undefined in Renderer/Worker (#44497)
Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com>
This commit is contained in:
parent
6356cdf49f
commit
85272b00a4
6 changed files with 52 additions and 6 deletions
|
@ -6,7 +6,7 @@ wrapFsWithAsar(require('fs'));
|
||||||
|
|
||||||
// See ElectronRendererClient::DidCreateScriptContext.
|
// See ElectronRendererClient::DidCreateScriptContext.
|
||||||
if ((globalThis as any).blinkfetch) {
|
if ((globalThis as any).blinkfetch) {
|
||||||
const keys = ['fetch', 'Response', 'FormData', 'Request', 'Headers'];
|
const keys = ['fetch', 'Response', 'FormData', 'Request', 'Headers', 'EventSource'];
|
||||||
for (const key of keys) {
|
for (const key of keys) {
|
||||||
(globalThis as any)[key] = (globalThis as any)[`blink${key}`];
|
(globalThis as any)[key] = (globalThis as any)[`blink${key}`];
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ global.require = makeRequireFunction(global.module);
|
||||||
|
|
||||||
// See WebWorkerObserver::WorkerScriptReadyForEvaluation.
|
// See WebWorkerObserver::WorkerScriptReadyForEvaluation.
|
||||||
if ((globalThis as any).blinkfetch) {
|
if ((globalThis as any).blinkfetch) {
|
||||||
const keys = ['fetch', 'Response', 'FormData', 'Request', 'Headers'];
|
const keys = ['fetch', 'Response', 'FormData', 'Request', 'Headers', 'EventSource'];
|
||||||
for (const key of keys) {
|
for (const key of keys) {
|
||||||
(globalThis as any)[key] = (globalThis as any)[`blink${key}`];
|
(globalThis as any)[key] = (globalThis as any)[`blink${key}`];
|
||||||
}
|
}
|
||||||
|
|
|
@ -117,8 +117,8 @@ void ElectronRendererClient::DidCreateScriptContext(
|
||||||
v8::Isolate* isolate = env->isolate();
|
v8::Isolate* isolate = env->isolate();
|
||||||
v8::Local<v8::Object> global = renderer_context->Global();
|
v8::Local<v8::Object> global = renderer_context->Global();
|
||||||
|
|
||||||
std::vector<std::string> keys = {"fetch", "Response", "FormData", "Request",
|
std::vector<std::string> keys = {"fetch", "Response", "FormData",
|
||||||
"Headers"};
|
"Request", "Headers", "EventSource"};
|
||||||
for (const auto& key : keys) {
|
for (const auto& key : keys) {
|
||||||
v8::MaybeLocal<v8::Value> value =
|
v8::MaybeLocal<v8::Value> value =
|
||||||
global->Get(renderer_context, gin::StringToV8(isolate, key));
|
global->Get(renderer_context, gin::StringToV8(isolate, key));
|
||||||
|
|
|
@ -72,8 +72,8 @@ void WebWorkerObserver::WorkerScriptReadyForEvaluation(
|
||||||
// is loaded. See corresponding change in node/init.ts.
|
// is loaded. See corresponding change in node/init.ts.
|
||||||
v8::Local<v8::Object> global = worker_context->Global();
|
v8::Local<v8::Object> global = worker_context->Global();
|
||||||
|
|
||||||
std::vector<std::string> keys = {"fetch", "Response", "FormData", "Request",
|
std::vector<std::string> keys = {"fetch", "Response", "FormData",
|
||||||
"Headers"};
|
"Request", "Headers", "EventSource"};
|
||||||
for (const auto& key : keys) {
|
for (const auto& key : keys) {
|
||||||
v8::MaybeLocal<v8::Value> value =
|
v8::MaybeLocal<v8::Value> value =
|
||||||
global->Get(worker_context, gin::StringToV8(isolate, key.c_str()));
|
global->Get(worker_context, gin::StringToV8(isolate, key.c_str()));
|
||||||
|
|
|
@ -1030,6 +1030,43 @@ describe('chromium features', () => {
|
||||||
expect(code).to.equal(0);
|
expect(code).to.equal(0);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
itremote('Worker with nodeIntegrationInWorker has access to EventSource', () => {
|
||||||
|
const es = new EventSource('https://example.com');
|
||||||
|
expect(es).to.have.property('url').that.is.a('string');
|
||||||
|
expect(es).to.have.property('readyState').that.is.a('number');
|
||||||
|
expect(es).to.have.property('withCredentials').that.is.a('boolean');
|
||||||
|
});
|
||||||
|
|
||||||
|
itremote('Worker with nodeIntegrationInWorker has access to fetch-dependent interfaces', async (fixtures: string) => {
|
||||||
|
const file = require('node:path').join(fixtures, 'hello.txt');
|
||||||
|
expect(() => {
|
||||||
|
fetch('file://' + file);
|
||||||
|
}).to.not.throw();
|
||||||
|
|
||||||
|
expect(() => {
|
||||||
|
const formData = new FormData();
|
||||||
|
formData.append('username', 'Groucho');
|
||||||
|
}).not.to.throw();
|
||||||
|
|
||||||
|
expect(() => {
|
||||||
|
const request = new Request('https://example.com', {
|
||||||
|
method: 'POST',
|
||||||
|
body: JSON.stringify({ foo: 'bar' })
|
||||||
|
});
|
||||||
|
expect(request.method).to.equal('POST');
|
||||||
|
}).not.to.throw();
|
||||||
|
|
||||||
|
expect(() => {
|
||||||
|
const response = new Response('Hello, world!');
|
||||||
|
expect(response.status).to.equal(200);
|
||||||
|
}).not.to.throw();
|
||||||
|
|
||||||
|
expect(() => {
|
||||||
|
const headers = new Headers();
|
||||||
|
headers.append('Content-Type', 'text/xml');
|
||||||
|
}).not.to.throw();
|
||||||
|
}, [path.join(__dirname, 'fixtures')]);
|
||||||
|
|
||||||
it('Worker can work', async () => {
|
it('Worker can work', async () => {
|
||||||
const w = new BrowserWindow({ show: false });
|
const w = new BrowserWindow({ show: false });
|
||||||
await w.loadURL(`file://${fixturesPath}/pages/blank.html`);
|
await w.loadURL(`file://${fixturesPath}/pages/blank.html`);
|
||||||
|
|
|
@ -162,6 +162,15 @@ describe('node feature', () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('EventSource', () => {
|
||||||
|
itremote('works correctly when nodeIntegration is enabled in the renderer', () => {
|
||||||
|
const es = new EventSource('https://example.com');
|
||||||
|
expect(es).to.have.property('url').that.is.a('string');
|
||||||
|
expect(es).to.have.property('readyState').that.is.a('number');
|
||||||
|
expect(es).to.have.property('withCredentials').that.is.a('boolean');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('fetch', () => {
|
describe('fetch', () => {
|
||||||
itremote('works correctly when nodeIntegration is enabled in the renderer', async (fixtures: string) => {
|
itremote('works correctly when nodeIntegration is enabled in the renderer', async (fixtures: string) => {
|
||||||
const file = require('node:path').join(fixtures, 'hello.txt');
|
const file = require('node:path').join(fixtures, 'hello.txt');
|
||||||
|
|
Loading…
Reference in a new issue