fix(tracing): rewrite blob urls so that we can intercept them (#8423)
This commit is contained in:
parent
338d3c8fd4
commit
b188468fa4
|
|
@ -62,6 +62,7 @@ export class SnapshotServer {
|
|||
|
||||
private _serveServiceWorker(request: http.IncomingMessage, response: http.ServerResponse): boolean {
|
||||
function serviceWorkerMain(self: any /* ServiceWorkerGlobalScope */) {
|
||||
const kBlobUrlPrefix = 'http://playwright.bloburl/#';
|
||||
const snapshotIds = new Map<string, { frameId: string, index: number }>();
|
||||
|
||||
self.addEventListener('install', function(event: any) {
|
||||
|
|
@ -105,7 +106,7 @@ export class SnapshotServer {
|
|||
}
|
||||
|
||||
const { frameId, index } = snapshotIds.get(snapshotUrl)!;
|
||||
const url = removeHash(request.url);
|
||||
const url = request.url.startsWith(kBlobUrlPrefix) ? request.url.substring(kBlobUrlPrefix.length) : removeHash(request.url);
|
||||
const complexUrl = btoa(JSON.stringify({ frameId, index, url }));
|
||||
const fetchUrl = `/resources/${complexUrl}`;
|
||||
const fetchedResponse = await fetch(fetchUrl);
|
||||
|
|
|
|||
|
|
@ -41,6 +41,7 @@ export function frameSnapshotStreamer(snapshotStreamer: string) {
|
|||
const kScrollTopAttribute = '__playwright_scroll_top_';
|
||||
const kScrollLeftAttribute = '__playwright_scroll_left_';
|
||||
const kStyleSheetAttribute = '__playwright_style_sheet_';
|
||||
const kBlobUrlPrefix = 'http://playwright.bloburl/#';
|
||||
|
||||
// Symbols for our own info on Nodes/StyleSheets.
|
||||
const kSnapshotFrameId = Symbol('__playwright_snapshot_frameid_');
|
||||
|
|
@ -184,6 +185,9 @@ export function frameSnapshotStreamer(snapshotStreamer: string) {
|
|||
private _sanitizeUrl(url: string): string {
|
||||
if (url.startsWith('javascript:'))
|
||||
return '';
|
||||
// Rewrite blob urls so that Service Worker can intercept them.
|
||||
if (url.startsWith('blob:'))
|
||||
return kBlobUrlPrefix + url;
|
||||
return url;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -300,6 +300,27 @@ it.describe('snapshots', () => {
|
|||
const padding = await frame.$eval('body', body => window.getComputedStyle(body).paddingLeft);
|
||||
expect(padding).toBe('42px');
|
||||
});
|
||||
|
||||
it('should handle src=blob', async ({ page, server, showSnapshot, toImpl, snapshotter, browserName }) => {
|
||||
it.skip(browserName === 'firefox');
|
||||
|
||||
await page.goto(server.EMPTY_PAGE);
|
||||
await page.evaluate(async () => {
|
||||
const dataUrl = '';
|
||||
const blob = await fetch(dataUrl).then(res => res.blob());
|
||||
const url = window.URL.createObjectURL(blob);
|
||||
const img = document.createElement('img');
|
||||
img.src = url;
|
||||
const loaded = new Promise(f => img.onload = f);
|
||||
document.body.appendChild(img);
|
||||
await loaded;
|
||||
});
|
||||
|
||||
const snapshot = await snapshotter.captureSnapshot(toImpl(page), 'snapshot');
|
||||
const frame = await showSnapshot(snapshot);
|
||||
const img = await frame.waitForSelector('img');
|
||||
expect(await img.screenshot()).toMatchSnapshot('blob-src.png');
|
||||
});
|
||||
});
|
||||
|
||||
function distillSnapshot(snapshot) {
|
||||
|
|
|
|||
BIN
tests/snapshotter.spec.ts-snapshots/blob-src-chromium.png
Normal file
BIN
tests/snapshotter.spec.ts-snapshots/blob-src-chromium.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 301 B |
BIN
tests/snapshotter.spec.ts-snapshots/blob-src-webkit.png
Normal file
BIN
tests/snapshotter.spec.ts-snapshots/blob-src-webkit.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 407 B |
Loading…
Reference in a new issue