fix: only check loading iframe in lifecycling (#8348)
This commit is contained in:
parent
3ef02a3cc6
commit
74380303ac
@ -108,6 +108,9 @@ export class FrameManager extends EventEmitter {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
session.on('Page.frameStartedLoading', (event) => {
|
||||||
|
this._onFrameStartedLoading(event.frameId);
|
||||||
|
});
|
||||||
session.on('Page.frameStoppedLoading', (event) => {
|
session.on('Page.frameStoppedLoading', (event) => {
|
||||||
this._onFrameStoppedLoading(event.frameId);
|
this._onFrameStoppedLoading(event.frameId);
|
||||||
});
|
});
|
||||||
@ -287,6 +290,12 @@ export class FrameManager extends EventEmitter {
|
|||||||
this.emit(FrameManagerEmittedEvents.LifecycleEvent, frame);
|
this.emit(FrameManagerEmittedEvents.LifecycleEvent, frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_onFrameStartedLoading(frameId: string): void {
|
||||||
|
const frame = this._frames.get(frameId);
|
||||||
|
if (!frame) return;
|
||||||
|
frame._onLoadingStarted();
|
||||||
|
}
|
||||||
|
|
||||||
_onFrameStoppedLoading(frameId: string): void {
|
_onFrameStoppedLoading(frameId: string): void {
|
||||||
const frame = this._frames.get(frameId);
|
const frame = this._frames.get(frameId);
|
||||||
if (!frame) return;
|
if (!frame) return;
|
||||||
@ -650,6 +659,10 @@ export class Frame {
|
|||||||
* @internal
|
* @internal
|
||||||
*/
|
*/
|
||||||
_name?: string;
|
_name?: string;
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
_hasStartedLoading = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @internal
|
* @internal
|
||||||
@ -1416,6 +1429,13 @@ export class Frame {
|
|||||||
this._lifecycleEvents.add('load');
|
this._lifecycleEvents.add('load');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @internal
|
||||||
|
*/
|
||||||
|
_onLoadingStarted(): void {
|
||||||
|
this._hasStartedLoading = true;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @internal
|
* @internal
|
||||||
*/
|
*/
|
||||||
|
@ -255,7 +255,12 @@ export class LifecycleWatcher {
|
|||||||
if (!frame._lifecycleEvents.has(event)) return false;
|
if (!frame._lifecycleEvents.has(event)) return false;
|
||||||
}
|
}
|
||||||
for (const child of frame.childFrames()) {
|
for (const child of frame.childFrames()) {
|
||||||
if (!checkLifecycle(child, expectedLifecycle)) return false;
|
if (
|
||||||
|
child._hasStartedLoading &&
|
||||||
|
!checkLifecycle(child, expectedLifecycle)
|
||||||
|
) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
3
test/assets/frames/lazy-frame.html
Normal file
3
test/assets/frames/lazy-frame.html
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
<iframe width="100%" height="300" src="about:blank"></iframe>
|
||||||
|
<div style="height: 800vh"></div>
|
||||||
|
<iframe width="100%" height="300" src='./frame.html' loading="lazy"></iframe>
|
3
test/assets/lazy-oopif-frame.html
Normal file
3
test/assets/lazy-oopif-frame.html
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
<iframe width="100%" height="300" src="about:blank"></iframe>
|
||||||
|
<div style="height: 800vh"></div>
|
||||||
|
<iframe width="100%" height="300" src='www.example.com' loading="lazy"></iframe>
|
@ -278,6 +278,18 @@ describe('Frame specs', function () {
|
|||||||
server.PREFIX + '/frames/frame.html?param=value#fragment'
|
server.PREFIX + '/frames/frame.html?param=value#fragment'
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
itFailsFirefox('should support lazy frames', async () => {
|
||||||
|
const { page, server } = getTestState();
|
||||||
|
|
||||||
|
await page.setViewport({ width: 1000, height: 1000 });
|
||||||
|
await page.goto(server.PREFIX + '/frames/lazy-frame.html');
|
||||||
|
|
||||||
|
expect(page.frames().map((frame) => frame._hasStartedLoading)).toEqual([
|
||||||
|
true,
|
||||||
|
true,
|
||||||
|
false,
|
||||||
|
]);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('Frame.client', function () {
|
describe('Frame.client', function () {
|
||||||
|
@ -16,7 +16,11 @@
|
|||||||
|
|
||||||
import utils from './utils.js';
|
import utils from './utils.js';
|
||||||
import expect from 'expect';
|
import expect from 'expect';
|
||||||
import { getTestState, describeChromeOnly } from './mocha-utils'; // eslint-disable-line import/extensions
|
import {
|
||||||
|
getTestState,
|
||||||
|
describeChromeOnly,
|
||||||
|
itFailsFirefox,
|
||||||
|
} from './mocha-utils'; // eslint-disable-line import/extensions
|
||||||
|
|
||||||
describeChromeOnly('OOPIF', function () {
|
describeChromeOnly('OOPIF', function () {
|
||||||
/* We use a special browser for this test as we need the --site-per-process flag */
|
/* We use a special browser for this test as we need the --site-per-process flag */
|
||||||
@ -386,6 +390,18 @@ describeChromeOnly('OOPIF', function () {
|
|||||||
await target.page();
|
await target.page();
|
||||||
browser1.disconnect();
|
browser1.disconnect();
|
||||||
});
|
});
|
||||||
|
itFailsFirefox('should support lazy OOP frames', async () => {
|
||||||
|
const { server } = getTestState();
|
||||||
|
|
||||||
|
await page.goto(server.PREFIX + '/lazy-oopif-frame.html');
|
||||||
|
await page.setViewport({ width: 1000, height: 1000 });
|
||||||
|
|
||||||
|
expect(page.frames().map((frame) => frame._hasStartedLoading)).toEqual([
|
||||||
|
true,
|
||||||
|
true,
|
||||||
|
false,
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
describe('waitForFrame', () => {
|
describe('waitForFrame', () => {
|
||||||
it('should resolve immediately if the frame already exists', async () => {
|
it('should resolve immediately if the frame already exists', async () => {
|
||||||
|
Loading…
Reference in New Issue
Block a user