2020-08-05 01:09:24 +03:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
2020-08-20 07:32:12 +03:00
|
|
|
|
2021-05-06 17:08:22 +03:00
|
|
|
import { test as it, expect } from './pageTest';
|
2020-08-05 01:09:24 +03:00
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should fire', async ({ page, server, browserName }) => {
|
2021-07-02 00:31:20 +03:00
|
|
|
const url = server.PREFIX + '/error.html';
|
2020-08-05 01:09:24 +03:00
|
|
|
const [error] = await Promise.all([
|
|
|
|
page.waitForEvent('pageerror'),
|
2021-07-02 00:31:20 +03:00
|
|
|
page.goto(url),
|
2020-08-05 01:09:24 +03:00
|
|
|
]);
|
|
|
|
expect(error.name).toBe('Error');
|
|
|
|
expect(error.message).toBe('Fancy error!');
|
2021-07-02 00:31:20 +03:00
|
|
|
if (browserName === 'chromium') {
|
|
|
|
expect(error.stack).toBe(`Error: Fancy error!
|
|
|
|
at c (myscript.js:14:11)
|
|
|
|
at b (myscript.js:10:5)
|
|
|
|
at a (myscript.js:6:5)
|
|
|
|
at myscript.js:3:1`);
|
|
|
|
} else if (browserName === 'webkit') {
|
|
|
|
expect(error.stack).toBe(`Error: Fancy error!
|
|
|
|
at c (${url}:14:36)
|
|
|
|
at b (${url}:10:6)
|
|
|
|
at a (${url}:6:6)
|
|
|
|
at global code (${url}:3:2)`);
|
|
|
|
} else if (browserName === 'firefox') {
|
|
|
|
expect(error.stack).toBe(`Error: Fancy error!
|
|
|
|
at c (myscript.js:14:11)
|
|
|
|
at b (myscript.js:10:5)
|
|
|
|
at a (myscript.js:6:5)
|
|
|
|
at (myscript.js:3:1)`);
|
|
|
|
}
|
2020-08-05 01:09:24 +03:00
|
|
|
});
|
|
|
|
|
2021-07-01 23:23:23 +03:00
|
|
|
it('should not receive console message for pageError', async ({ page, server, browserName }) => {
|
|
|
|
const messages = [];
|
|
|
|
page.on('console', e => messages.push(e));
|
|
|
|
await Promise.all([
|
|
|
|
page.waitForEvent('pageerror'),
|
|
|
|
page.goto(server.PREFIX + '/error.html'),
|
|
|
|
]);
|
|
|
|
expect(messages.length).toBe(1);
|
|
|
|
});
|
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should contain sourceURL', async ({ page, server, browserName }) => {
|
2021-05-13 20:22:23 +03:00
|
|
|
it.fail(browserName === 'webkit');
|
2021-04-03 00:23:42 +03:00
|
|
|
|
2020-08-05 01:09:24 +03:00
|
|
|
const [error] = await Promise.all([
|
|
|
|
page.waitForEvent('pageerror'),
|
|
|
|
page.goto(server.PREFIX + '/error.html'),
|
|
|
|
]);
|
|
|
|
expect(error.stack).toContain('myscript.js');
|
|
|
|
});
|
|
|
|
|
2021-04-19 23:37:38 +03:00
|
|
|
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');
|
|
|
|
});
|
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should handle odd values', async ({ page }) => {
|
2020-08-05 01:09:24 +03:00
|
|
|
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),
|
|
|
|
]);
|
2021-04-19 23:37:38 +03:00
|
|
|
expect(error.message).toBe(message);
|
2020-08-05 01:09:24 +03:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should handle object', async ({ page, browserName }) => {
|
2020-08-05 01:09:24 +03:00
|
|
|
const [error] = await Promise.all([
|
|
|
|
page.waitForEvent('pageerror'),
|
|
|
|
page.evaluate(() => setTimeout(() => { throw {}; }, 0)),
|
|
|
|
]);
|
2021-05-13 20:22:23 +03:00
|
|
|
expect(error.message).toBe(browserName === 'chromium' ? 'Object' : '[object Object]');
|
2020-08-05 01:09:24 +03:00
|
|
|
});
|
|
|
|
|
2021-09-27 19:58:08 +03:00
|
|
|
it('should handle window', async ({ page, browserName, isElectron }) => {
|
2021-04-09 17:59:09 +03:00
|
|
|
it.skip(isElectron);
|
2020-08-05 01:09:24 +03:00
|
|
|
const [error] = await Promise.all([
|
|
|
|
page.waitForEvent('pageerror'),
|
|
|
|
page.evaluate(() => setTimeout(() => { throw window; }, 0)),
|
|
|
|
]);
|
2021-05-13 20:22:23 +03:00
|
|
|
expect(error.message).toBe(browserName === 'chromium' ? 'Window' : '[object Window]');
|
2020-08-05 01:09:24 +03:00
|
|
|
});
|
2022-06-29 14:53:13 +03:00
|
|
|
|
|
|
|
it('should remove a listener of a non-existing event handler', async ({ page }) => {
|
|
|
|
page.removeListener('pageerror', () => {});
|
|
|
|
});
|
2022-07-06 01:46:28 +03:00
|
|
|
|
|
|
|
it('should emit error from unhandled rejects', async ({ page, browserName }) => {
|
|
|
|
it.info().annotations.push({ type: 'issue', description: 'https://github.com/microsoft/playwright/issues/14165' });
|
|
|
|
const [error] = await Promise.all([
|
|
|
|
page.waitForEvent('pageerror'),
|
|
|
|
page.setContent(`
|
|
|
|
<script>
|
|
|
|
Promise.reject(new Error('sad :('));
|
|
|
|
</script>
|
|
|
|
`),
|
|
|
|
]);
|
2022-07-06 08:15:40 +03:00
|
|
|
expect(error.message).toContain('sad :(');
|
2022-07-06 01:46:28 +03:00
|
|
|
});
|