playwright/tests/page/page-event-pageerror.spec.ts
Dmitry Gozman 8b6b894dd8
test: prepare test to use options as passed (#6557)
This changes `headful` to `headless` to align with launch options.
Also replaces `isChromium` and friends with `browserName`.
2021-05-13 10:22:23 -07:00

106 lines
3.3 KiB
TypeScript

/**
* Copyright 2017 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.
*/
import { test as it, expect } from './pageTest';
it('should fire', async ({page, server, browserName}) => {
const [error] = await Promise.all([
page.waitForEvent('pageerror'),
page.goto(server.PREFIX + '/error.html'),
]);
expect(error.name).toBe('Error');
expect(error.message).toBe('Fancy error!');
let stack = await page.evaluate(() => window['e'].stack);
// Note that WebKit reports the stack of the 'throw' statement instead of the Error constructor call.
if (browserName === 'webkit')
stack = stack.replace('14:25', '15:19');
expect(error.stack).toBe(stack);
});
it('should contain sourceURL', async ({page, server, browserName}) => {
it.fail(browserName === 'webkit');
const [error] = await Promise.all([
page.waitForEvent('pageerror'),
page.goto(server.PREFIX + '/error.html'),
]);
expect(error.stack).toContain('myscript.js');
});
it('should contain the Error.name property', async ({ page }) => {
const [error] = await Promise.all([
page.waitForEvent('pageerror'),
page.evaluate(() => {
setTimeout(() => {
const error = new Error('my-message');
error.name = 'my-name';
throw error;
}, 0);
})
]);
expect(error.name).toBe('my-name');
expect(error.message).toBe('my-message');
});
it('should support an empty Error.name property', async ({ page }) => {
const [error] = await Promise.all([
page.waitForEvent('pageerror'),
page.evaluate(() => {
setTimeout(() => {
const error = new Error('my-message');
error.name = '';
throw error;
}, 0);
})
]);
expect(error.name).toBe('');
expect(error.message).toBe('my-message');
});
it('should handle odd values', async ({page}) => {
const cases = [
[null, 'null'],
[undefined, 'undefined'],
[0, '0'],
['', ''],
];
for (const [value, message] of cases) {
const [error] = await Promise.all([
page.waitForEvent('pageerror'),
page.evaluate(value => setTimeout(() => { throw value; }, 0), value),
]);
expect(error.message).toBe(message);
}
});
it('should handle object', async ({page, browserName}) => {
const [error] = await Promise.all([
page.waitForEvent('pageerror'),
page.evaluate(() => setTimeout(() => { throw {}; }, 0)),
]);
expect(error.message).toBe(browserName === 'chromium' ? 'Object' : '[object Object]');
});
it('should handle window', async ({page, browserName, isElectron}) => {
it.skip(isElectron);
const [error] = await Promise.all([
page.waitForEvent('pageerror'),
page.evaluate(() => setTimeout(() => { throw window; }, 0)),
]);
expect(error.message).toBe(browserName === 'chromium' ? 'Window' : '[object Window]');
});