test: re-enable extensions test with http server (#38129)
This commit is contained in:
parent
ba8887f586
commit
a2d35e9cf5
1 changed files with 23 additions and 10 deletions
|
@ -590,17 +590,32 @@ describe('chrome extensions', () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
// FIXME(nornagon): real extensions don't load on file: urls, so this
|
describe('supports "all_frames" option', () => {
|
||||||
// test needs to be updated to serve its content over http.
|
|
||||||
xdescribe('supports "all_frames" option', () => {
|
|
||||||
const contentScript = path.resolve(fixtures, 'extensions/content-script');
|
const contentScript = path.resolve(fixtures, 'extensions/content-script');
|
||||||
|
const contentPath = path.join(contentScript, 'frame-with-frame.html');
|
||||||
|
|
||||||
// Computed style values
|
// Computed style values
|
||||||
const COLOR_RED = 'rgb(255, 0, 0)';
|
const COLOR_RED = 'rgb(255, 0, 0)';
|
||||||
const COLOR_BLUE = 'rgb(0, 0, 255)';
|
const COLOR_BLUE = 'rgb(0, 0, 255)';
|
||||||
const COLOR_TRANSPARENT = 'rgba(0, 0, 0, 0)';
|
const COLOR_TRANSPARENT = 'rgba(0, 0, 0, 0)';
|
||||||
|
|
||||||
before(() => {
|
let server: http.Server;
|
||||||
|
let port: number;
|
||||||
|
before(async () => {
|
||||||
|
server = http.createServer((_, res) => {
|
||||||
|
fs.readFile(contentPath, (error, content) => {
|
||||||
|
if (error) {
|
||||||
|
res.writeHead(500);
|
||||||
|
res.end(`Failed to load ${contentPath} : ${error.code}`);
|
||||||
|
} else {
|
||||||
|
res.writeHead(200, { 'Content-Type': 'text/html' });
|
||||||
|
res.end(content, 'utf-8');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
({ port, url } = await listen(server));
|
||||||
|
|
||||||
session.defaultSession.loadExtension(contentScript);
|
session.defaultSession.loadExtension(contentScript);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -627,7 +642,8 @@ describe('chrome extensions', () => {
|
||||||
|
|
||||||
it('applies matching rules in subframes', async () => {
|
it('applies matching rules in subframes', async () => {
|
||||||
const detailsPromise = emittedNTimes(w.webContents, 'did-frame-finish-load', 2);
|
const detailsPromise = emittedNTimes(w.webContents, 'did-frame-finish-load', 2);
|
||||||
w.loadFile(path.join(contentScript, 'frame-with-frame.html'));
|
|
||||||
|
w.loadURL(`http://127.0.0.1:${port}`);
|
||||||
const frameEvents = await detailsPromise;
|
const frameEvents = await detailsPromise;
|
||||||
await Promise.all(
|
await Promise.all(
|
||||||
frameEvents.map(async frameEvent => {
|
frameEvents.map(async frameEvent => {
|
||||||
|
@ -644,12 +660,9 @@ describe('chrome extensions', () => {
|
||||||
}
|
}
|
||||||
})()`
|
})()`
|
||||||
);
|
);
|
||||||
|
|
||||||
expect(result.enabledColor).to.equal(COLOR_RED);
|
expect(result.enabledColor).to.equal(COLOR_RED);
|
||||||
if (isMainFrame) {
|
expect(result.disabledColor).to.equal(isMainFrame ? COLOR_BLUE : COLOR_TRANSPARENT);
|
||||||
expect(result.disabledColor).to.equal(COLOR_BLUE);
|
|
||||||
} else {
|
|
||||||
expect(result.disabledColor).to.equal(COLOR_TRANSPARENT); // null color
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue