test: intercept request from css variable (#20422)

#19158
This commit is contained in:
Yury Semikhatsky 2023-01-26 14:20:24 -08:00 committed by GitHub
parent 332dbc5bf6
commit 0a9cf85653
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -374,3 +374,38 @@ it('should continue preload link requests', async ({ page, server, browserName }
const color = await page.evaluate(() => window.getComputedStyle(document.body).backgroundColor); const color = await page.evaluate(() => window.getComputedStyle(document.body).backgroundColor);
expect(color).toBe('rgb(255, 192, 203)'); expect(color).toBe('rgb(255, 192, 203)');
}); });
it('should intercept css variable with background url', async ({ page, server, browserName }) => {
it.fixme(browserName === 'webkit');
it.info().annotations.push({ type: 'issue', description: 'https://github.com/microsoft/playwright/issues/19158' });
server.setRoute('/test.html', (request, response) => {
response.setHeader('Content-Type', 'text/html');
response.end(`
<style>
@keyframes JNDzq {
0% { background-position: 0 0 }
to { background-position: 100 0 }
}
div {
--background: url(/pptr.png);
background-image: var(--background);
animation: JNDzq 1s linear infinite;
}
</style>
<div>Yo!</div>`);
});
let interceptCallback;
const interceptPromise = new Promise(f => interceptCallback = f);
let interceptedRequests = 0;
await page.route(server.PREFIX + '/pptr.png', async (route, request) => {
++interceptedRequests;
interceptCallback();
route.continue();
});
await page.goto(server.PREFIX + '/test.html');
expect(await page.locator('div').textContent()).toBe('Yo!');
await interceptPromise;
await page.waitForTimeout(1000);
expect(interceptedRequests).toBe(1);
});