Attempt to fix tests to not throw targetClosed exception

The exception happens due to some of the tests initiating
operation and not waiting for the operation to finish.
This commit is contained in:
Andrey Lushnikov 2017-07-27 17:20:02 -07:00
parent bd898b7f56
commit d1f2c01db5

View File

@ -733,17 +733,17 @@ describe('Puppeteer', function() {
}); });
describe('Page.Events.PageError', function() { describe('Page.Events.PageError', function() {
it('should fire', function(done) { it('should fire', SX(async function() {
page.on('pageerror', error => { let error = null;
expect(error.message).toContain('Fancy'); page.once('pageerror', e => error = e);
done();
});
page.navigate(PREFIX + '/error.html'); page.navigate(PREFIX + '/error.html');
}); await waitForEvents(page, 'pageerror');
expect(error.message).toContain('Fancy');
}));
}); });
describe('Page.Events.Request', function() { describe('Page.Events.Request', function() {
it('should fire', SX(async function(done) { it('should fire', SX(async function() {
let requests = []; let requests = [];
page.on('request', request => requests.push(request)); page.on('request', request => requests.push(request));
await page.navigate(EMPTY_PAGE); await page.navigate(EMPTY_PAGE);
@ -882,17 +882,16 @@ describe('Puppeteer', function() {
it('should move with the arrow keys', SX(async function(){ it('should move with the arrow keys', SX(async function(){
await page.navigate(PREFIX + '/input/textarea.html'); await page.navigate(PREFIX + '/input/textarea.html');
await page.focus('textarea'); await page.focus('textarea');
let keyboard = page.keyboard;
await page.type('Hello World!'); await page.type('Hello World!');
expect(await page.evaluate(() => document.querySelector('textarea').value)).toBe('Hello World!'); expect(await page.evaluate(() => document.querySelector('textarea').value)).toBe('Hello World!');
for (let i = 0; i < 'World!'.length; i++) for (let i = 0; i < 'World!'.length; i++)
page.press('ArrowLeft'); page.press('ArrowLeft');
await page.type('inserted '); await page.type('inserted ');
expect(await page.evaluate(() => document.querySelector('textarea').value)).toBe('Hello inserted World!'); expect(await page.evaluate(() => document.querySelector('textarea').value)).toBe('Hello inserted World!');
keyboard.down('Shift'); page.keyboard.down('Shift');
for (let i = 0; i < 'inserted '.length; i++) for (let i = 0; i < 'inserted '.length; i++)
page.press('ArrowLeft'); page.press('ArrowLeft');
keyboard.up('Shift'); page.keyboard.up('Shift');
await page.press('Backspace'); await page.press('Backspace');
expect(await page.evaluate(() => document.querySelector('textarea').value)).toBe('Hello World!'); expect(await page.evaluate(() => document.querySelector('textarea').value)).toBe('Hello World!');
})); }));
@ -991,12 +990,12 @@ describe('Puppeteer', function() {
it('keyboard.modifiers()', SX(async function(){ it('keyboard.modifiers()', SX(async function(){
let keyboard = page.keyboard; let keyboard = page.keyboard;
expect(keyboard._modifiers).toBe(0); expect(keyboard._modifiers).toBe(0);
keyboard.down('Shift'); await keyboard.down('Shift');
expect(keyboard._modifiers).toBe(8); expect(keyboard._modifiers).toBe(8);
keyboard.down('Alt'); await keyboard.down('Alt');
expect(keyboard._modifiers).toBe(9); expect(keyboard._modifiers).toBe(9);
keyboard.up('Shift'); await keyboard.up('Shift');
keyboard.up('Alt'); await keyboard.up('Alt');
expect(keyboard._modifiers).toBe(0); expect(keyboard._modifiers).toBe(0);
})); }));
it('should resize the textarea', SX(async function(){ it('should resize the textarea', SX(async function(){