/** * 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. */ const {FFOX, CHROMIUM, WEBKIT, MAC} = require('./utils').testOptions(browserType); describe('ignoreHTTPSErrors', function() { it('should work', async({browser, httpsServer}) => { let error = null; const context = await browser.newContext({ ignoreHTTPSErrors: true }); const page = await context.newPage(); const response = await page.goto(httpsServer.EMPTY_PAGE).catch(e => error = e); expect(error).toBe(null); expect(response.ok()).toBe(true); await context.close(); }); it('should isolate contexts', async({browser, httpsServer}) => { { let error = null; const context = await browser.newContext({ ignoreHTTPSErrors: true }); const page = await context.newPage(); const response = await page.goto(httpsServer.EMPTY_PAGE).catch(e => error = e); expect(error).toBe(null); expect(response.ok()).toBe(true); await context.close(); } { let error = null; const context = await browser.newContext(); const page = await context.newPage(); await page.goto(httpsServer.EMPTY_PAGE).catch(e => error = e); expect(error).not.toBe(null); await context.close(); } }); it('should work with mixed content', async({browser, server, httpsServer}) => { httpsServer.setRoute('/mixedcontent.html', (req, res) => { res.end(``); }); const context = await browser.newContext({ ignoreHTTPSErrors: true }); const page = await context.newPage(); await page.goto(httpsServer.PREFIX + '/mixedcontent.html', {waitUntil: 'domcontentloaded'}); expect(page.frames().length).toBe(2); // Make sure blocked iframe has functional execution context // @see https://github.com/GoogleChrome/puppeteer/issues/2709 expect(await page.frames()[0].evaluate('1 + 2')).toBe(3); expect(await page.frames()[1].evaluate('2 + 3')).toBe(5); await context.close(); }); it('should work with WebSocket', async({browser, httpsServer}) => { const context = await browser.newContext({ ignoreHTTPSErrors: true }); const page = await context.newPage(); const value = await page.evaluate(endpoint => { let cb; const result = new Promise(f => cb = f); const ws = new WebSocket(endpoint); ws.addEventListener('message', data => { ws.close(); cb(data.data); }); ws.addEventListener('error', error => cb('Error')); return result; }, httpsServer.PREFIX.replace(/https/, 'wss') + '/ws'); expect(value).toBe('incoming'); await context.close(); }); it('should fail with WebSocket if not ignored', async({browser, httpsServer}) => { const context = await browser.newContext(); const page = await context.newPage(); const value = await page.evaluate(endpoint => { let cb; const result = new Promise(f => cb = f); const ws = new WebSocket(endpoint); ws.addEventListener('message', data => { ws.close(); cb(data.data); }); ws.addEventListener('error', error => cb('Error')); return result; }, httpsServer.PREFIX.replace(/https/, 'wss') + '/ws'); expect(value).toBe('Error'); await context.close(); }); });