From 9db09fe7e977e7871c24aa41fae0d7902dca3d79 Mon Sep 17 00:00:00 2001 From: Andrey Lushnikov Date: Mon, 4 Mar 2019 17:16:04 -0800 Subject: [PATCH] test: add test to validate redirecting in request.respond (#4106) --- test/network.spec.js | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/test/network.spec.js b/test/network.spec.js index 5d92c92c47f..98bb7ac77a9 100644 --- a/test/network.spec.js +++ b/test/network.spec.js @@ -106,7 +106,6 @@ module.exports.addTests = function({testRunner, expect, CHROME}) { // Load and re-load to make sure it's cached. await page.goto(server.PREFIX + '/cached/one-style.html'); - await page.waitFor(1000); await page.reload(); expect(responses.size).toBe(2); @@ -749,6 +748,25 @@ module.exports.addTests = function({testRunner, expect, CHROME}) { expect(response.headers().foo).toBe('bar'); expect(await page.evaluate(() => document.body.textContent)).toBe('Yo, page!'); }); + it('should redirect', async({page, server}) => { + await page.setRequestInterception(true); + page.on('request', request => { + if (!request.url().includes('rrredirect')) { + request.continue(); + return; + } + request.respond({ + status: 302, + headers: { + location: server.EMPTY_PAGE, + }, + }); + }); + const response = await page.goto(server.PREFIX + '/rrredirect'); + expect(response.request().redirectChain().length).toBe(1); + expect(response.request().redirectChain()[0].url()).toBe(server.PREFIX + '/rrredirect'); + expect(response.url()).toBe(server.EMPTY_PAGE); + }); it('should allow mocking binary responses', async({page, server}) => { await page.setRequestInterception(true); page.on('request', request => {