2020-08-05 02:32:10 +03:00
|
|
|
/**
|
|
|
|
* Copyright 2018 Google Inc. All rights reserved.
|
|
|
|
* Modifications copyright (c) Microsoft Corporation.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2020-08-20 07:32:12 +03:00
|
|
|
|
2021-05-06 17:08:22 +03:00
|
|
|
import { test as it, expect } from './pageTest';
|
2021-10-11 17:52:17 +03:00
|
|
|
import { globToRegex } from 'playwright-core/lib/client/clientHelper';
|
2020-08-12 01:50:53 +03:00
|
|
|
import vm from 'vm';
|
2020-08-05 02:32:10 +03:00
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should work with navigation', async ({ page, server }) => {
|
2020-08-05 02:32:10 +03:00
|
|
|
const requests = new Map();
|
|
|
|
await page.route('**/*', route => {
|
|
|
|
requests.set(route.request().url().split('/').pop(), route.request());
|
|
|
|
route.continue();
|
|
|
|
});
|
|
|
|
server.setRedirect('/rrredirect', '/frames/one-frame.html');
|
|
|
|
await page.goto(server.PREFIX + '/rrredirect');
|
|
|
|
expect(requests.get('rrredirect').isNavigationRequest()).toBe(true);
|
|
|
|
expect(requests.get('frame.html').isNavigationRequest()).toBe(true);
|
|
|
|
expect(requests.get('script.js').isNavigationRequest()).toBe(false);
|
|
|
|
expect(requests.get('style.css').isNavigationRequest()).toBe(false);
|
|
|
|
});
|
|
|
|
|
2021-10-02 05:40:47 +03:00
|
|
|
it('should intercept after a service worker', async ({ page, server, isAndroid, isElectron }) => {
|
2021-04-09 17:59:09 +03:00
|
|
|
it.skip(isAndroid);
|
2021-10-02 05:40:47 +03:00
|
|
|
it.skip(isElectron);
|
2021-04-05 05:32:14 +03:00
|
|
|
|
2020-08-05 02:32:10 +03:00
|
|
|
await page.goto(server.PREFIX + '/serviceworkers/fetchdummy/sw.html');
|
2020-08-28 14:20:29 +03:00
|
|
|
await page.evaluate(() => window['activationPromise']);
|
2020-08-05 02:32:10 +03:00
|
|
|
|
|
|
|
// Sanity check.
|
2020-08-28 14:20:29 +03:00
|
|
|
const swResponse = await page.evaluate(() => window['fetchDummy']('foo'));
|
2020-08-05 02:32:10 +03:00
|
|
|
expect(swResponse).toBe('responseFromServiceWorker:foo');
|
|
|
|
|
|
|
|
await page.route('**/foo', route => {
|
|
|
|
const slash = route.request().url().lastIndexOf('/');
|
|
|
|
const name = route.request().url().substring(slash + 1);
|
|
|
|
route.fulfill({
|
|
|
|
status: 200,
|
|
|
|
contentType: 'text/css',
|
|
|
|
body: 'responseFromInterception:' + name
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// Page route is applied after service worker fetch event.
|
2020-08-28 14:20:29 +03:00
|
|
|
const swResponse2 = await page.evaluate(() => window['fetchDummy']('foo'));
|
2020-08-05 02:32:10 +03:00
|
|
|
expect(swResponse2).toBe('responseFromServiceWorker:foo');
|
|
|
|
|
|
|
|
// Page route is not applied to service worker initiated fetch.
|
2020-08-28 14:20:29 +03:00
|
|
|
const nonInterceptedResponse = await page.evaluate(() => window['fetchDummy']('passthrough'));
|
2020-08-05 02:32:10 +03:00
|
|
|
expect(nonInterceptedResponse).toBe('FAILURE: Not Found');
|
|
|
|
});
|
|
|
|
|
2020-08-28 14:20:29 +03:00
|
|
|
it('should work with glob', async () => {
|
2020-08-19 23:27:58 +03:00
|
|
|
expect(globToRegex('**/*.js').test('https://localhost:8080/foo.js')).toBeTruthy();
|
|
|
|
expect(globToRegex('**/*.css').test('https://localhost:8080/foo.js')).toBeFalsy();
|
|
|
|
expect(globToRegex('*.js').test('https://localhost:8080/foo.js')).toBeFalsy();
|
|
|
|
expect(globToRegex('https://**/*.js').test('https://localhost:8080/foo.js')).toBeTruthy();
|
|
|
|
expect(globToRegex('http://localhost:8080/simple/path.js').test('http://localhost:8080/simple/path.js')).toBeTruthy();
|
|
|
|
expect(globToRegex('http://localhost:8080/?imple/path.js').test('http://localhost:8080/Simple/path.js')).toBeTruthy();
|
|
|
|
expect(globToRegex('**/{a,b}.js').test('https://localhost:8080/a.js')).toBeTruthy();
|
|
|
|
expect(globToRegex('**/{a,b}.js').test('https://localhost:8080/b.js')).toBeTruthy();
|
|
|
|
expect(globToRegex('**/{a,b}.js').test('https://localhost:8080/c.js')).toBeFalsy();
|
2020-08-05 02:32:10 +03:00
|
|
|
|
2020-08-19 23:27:58 +03:00
|
|
|
expect(globToRegex('**/*.{png,jpg,jpeg}').test('https://localhost:8080/c.jpg')).toBeTruthy();
|
|
|
|
expect(globToRegex('**/*.{png,jpg,jpeg}').test('https://localhost:8080/c.jpeg')).toBeTruthy();
|
|
|
|
expect(globToRegex('**/*.{png,jpg,jpeg}').test('https://localhost:8080/c.png')).toBeTruthy();
|
|
|
|
expect(globToRegex('**/*.{png,jpg,jpeg}').test('https://localhost:8080/c.css')).toBeFalsy();
|
2021-06-04 23:33:45 +03:00
|
|
|
expect(globToRegex('foo*').test('foo.js')).toBeTruthy();
|
|
|
|
expect(globToRegex('foo*').test('foo/bar.js')).toBeFalsy();
|
|
|
|
expect(globToRegex('http://localhost:3000/signin-oidc*').test('http://localhost:3000/signin-oidc/foo')).toBeFalsy();
|
|
|
|
expect(globToRegex('http://localhost:3000/signin-oidc*').test('http://localhost:3000/signin-oidcnice')).toBeTruthy();
|
2020-08-05 02:32:10 +03:00
|
|
|
});
|
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should intercept network activity from worker', async function({ page, server, isAndroid }) {
|
2021-04-09 17:59:09 +03:00
|
|
|
it.skip(isAndroid);
|
2021-04-05 05:32:14 +03:00
|
|
|
|
2020-11-24 02:03:34 +03:00
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
server.setRoute('/data_for_worker', (req, res) => res.end('failed to intercept'));
|
|
|
|
const url = server.PREFIX + '/data_for_worker';
|
2020-12-11 02:04:57 +03:00
|
|
|
await page.route(url, route => {
|
|
|
|
route.fulfill({
|
2020-11-24 02:03:34 +03:00
|
|
|
status: 200,
|
|
|
|
body: 'intercepted',
|
2020-12-11 02:04:57 +03:00
|
|
|
}).catch(e => null);
|
2020-11-24 02:03:34 +03:00
|
|
|
});
|
|
|
|
const [msg] = await Promise.all([
|
|
|
|
page.waitForEvent('console'),
|
|
|
|
page.evaluate(url => new Worker(URL.createObjectURL(new Blob([`
|
|
|
|
fetch("${url}").then(response => response.text()).then(console.log);
|
2021-09-27 19:58:08 +03:00
|
|
|
`], { type: 'application/javascript' }))), url),
|
2020-11-24 02:03:34 +03:00
|
|
|
]);
|
|
|
|
expect(msg.text()).toBe('intercepted');
|
|
|
|
});
|
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should intercept network activity from worker 2', async function({ page, server, isElectron, isAndroid }) {
|
2021-04-09 17:59:09 +03:00
|
|
|
it.skip(isAndroid);
|
|
|
|
it.fixme(isElectron);
|
2021-04-05 05:32:14 +03:00
|
|
|
|
2020-12-11 02:04:57 +03:00
|
|
|
const url = server.PREFIX + '/worker/worker.js';
|
|
|
|
await page.route(url, route => {
|
|
|
|
route.fulfill({
|
|
|
|
status: 200,
|
|
|
|
body: 'console.log("intercepted");',
|
|
|
|
contentType: 'application/javascript',
|
|
|
|
}).catch(e => null);
|
|
|
|
});
|
|
|
|
const [msg] = await Promise.all([
|
|
|
|
page.waitForEvent('console'),
|
|
|
|
page.goto(server.PREFIX + '/worker/worker.html'),
|
|
|
|
]);
|
|
|
|
expect(msg.text()).toBe('intercepted');
|
|
|
|
});
|
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should work with regular expression passed from a different context', async ({ page, server, isElectron }) => {
|
2021-04-09 17:59:09 +03:00
|
|
|
it.skip(isElectron);
|
2021-04-08 20:26:26 +03:00
|
|
|
|
2020-08-05 02:32:10 +03:00
|
|
|
const ctx = vm.createContext();
|
|
|
|
const regexp = vm.runInContext('new RegExp("empty\\.html")', ctx);
|
|
|
|
let intercepted = false;
|
|
|
|
|
|
|
|
await page.route(regexp, (route, request) => {
|
|
|
|
expect(route.request()).toBe(request);
|
|
|
|
expect(request.url()).toContain('empty.html');
|
|
|
|
expect(request.headers()['user-agent']).toBeTruthy();
|
|
|
|
expect(request.method()).toBe('GET');
|
|
|
|
expect(request.postData()).toBe(null);
|
|
|
|
expect(request.isNavigationRequest()).toBe(true);
|
|
|
|
expect(request.resourceType()).toBe('document');
|
|
|
|
expect(request.frame() === page.mainFrame()).toBe(true);
|
|
|
|
expect(request.frame().url()).toBe('about:blank');
|
|
|
|
route.continue();
|
|
|
|
intercepted = true;
|
|
|
|
});
|
|
|
|
|
|
|
|
const response = await page.goto(server.EMPTY_PAGE);
|
|
|
|
expect(response.ok()).toBe(true);
|
|
|
|
expect(intercepted).toBe(true);
|
|
|
|
});
|
2021-03-26 03:16:41 +03:00
|
|
|
|
2021-05-13 20:22:23 +03:00
|
|
|
it('should not break remote worker importScripts', async ({ page, server, browserName, browserMajorVersion }) => {
|
|
|
|
it.fixme(browserName && browserMajorVersion < 91);
|
2021-04-05 05:32:14 +03:00
|
|
|
|
2021-04-29 21:11:32 +03:00
|
|
|
await page.route('**', async route => {
|
|
|
|
await route.continue();
|
2021-03-26 03:16:41 +03:00
|
|
|
});
|
|
|
|
await page.goto(server.PREFIX + '/worker/worker-http-import.html');
|
|
|
|
await page.waitForSelector("#status:has-text('finished')");
|
|
|
|
});
|