test: verify file url interception works as expected (#2451)
This was fixed upstream: https://crrev.com/550319 Rolled into pptr: https://github.com/GoogleChrome/puppeteer/pull/2393 Fixes #1506.
This commit is contained in:
parent
8a62b10fd0
commit
eded38c82a
@ -459,6 +459,18 @@ module.exports.addTests = function({testRunner, expect}) {
|
|||||||
await page.goto(server.EMPTY_PAGE);
|
await page.goto(server.EMPTY_PAGE);
|
||||||
expect(error.message).toContain('Request Interception is not enabled');
|
expect(error.message).toContain('Request Interception is not enabled');
|
||||||
});
|
});
|
||||||
|
it('should work with file URLs', async({page, server}) => {
|
||||||
|
await page.setRequestInterception(true);
|
||||||
|
const urls = new Set();
|
||||||
|
page.on('request', request => {
|
||||||
|
urls.add(request.url().split('/').pop());
|
||||||
|
request.continue();
|
||||||
|
});
|
||||||
|
await page.goto(pathToFileURL(path.join(__dirname, 'assets', 'one-style.html')));
|
||||||
|
expect(urls.size).toBe(2);
|
||||||
|
expect(urls.has('one-style.html')).toBe(true);
|
||||||
|
expect(urls.has('one-style.css')).toBe(true);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('Request.respond', function() {
|
describe('Request.respond', function() {
|
||||||
@ -573,5 +585,16 @@ module.exports.addTests = function({testRunner, expect}) {
|
|||||||
expect(response.status()).toBe(401);
|
expect(response.status()).toBe(401);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {string} path
|
||||||
|
* @return {string}
|
||||||
|
*/
|
||||||
|
function pathToFileURL(path) {
|
||||||
|
let pathName = path.replace(/\\/g, '/');
|
||||||
|
// Windows drive letter must be prefixed with a slash.
|
||||||
|
if (!pathName.startsWith('/'))
|
||||||
|
pathName = '/' + pathName;
|
||||||
|
return 'file://' + pathName;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user