mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
fix: align network conditions presets with DevTools (#12542)
This commit is contained in:
parent
cbf757efce
commit
ee1074559d
@ -1342,7 +1342,7 @@ Enum of valid mouse buttons.
|
|||||||
|
|
||||||
</td><td>
|
</td><td>
|
||||||
|
|
||||||
A list of network conditions to be used with [Page.emulateNetworkConditions()](./puppeteer.page.emulatenetworkconditions.md).
|
A list of pre-defined network conditions to be used with [Page.emulateNetworkConditions()](./puppeteer.page.emulatenetworkconditions.md).
|
||||||
|
|
||||||
</td></tr>
|
</td></tr>
|
||||||
<tr><td>
|
<tr><td>
|
||||||
|
@ -4,7 +4,7 @@ sidebar_label: PredefinedNetworkConditions
|
|||||||
|
|
||||||
# PredefinedNetworkConditions variable
|
# PredefinedNetworkConditions variable
|
||||||
|
|
||||||
A list of network conditions to be used with [Page.emulateNetworkConditions()](./puppeteer.page.emulatenetworkconditions.md).
|
A list of pre-defined network conditions to be used with [Page.emulateNetworkConditions()](./puppeteer.page.emulatenetworkconditions.md).
|
||||||
|
|
||||||
#### Signature:
|
#### Signature:
|
||||||
|
|
||||||
@ -12,6 +12,8 @@ A list of network conditions to be used with [Page.emulateNetworkConditions()](.
|
|||||||
PredefinedNetworkConditions: Readonly<{
|
PredefinedNetworkConditions: Readonly<{
|
||||||
'Slow 3G': NetworkConditions;
|
'Slow 3G': NetworkConditions;
|
||||||
'Fast 3G': NetworkConditions;
|
'Fast 3G': NetworkConditions;
|
||||||
|
'Slow 4G': NetworkConditions;
|
||||||
|
'Fast 4G': NetworkConditions;
|
||||||
}>;
|
}>;
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -19,12 +21,16 @@ PredefinedNetworkConditions: Readonly<{
|
|||||||
|
|
||||||
```ts
|
```ts
|
||||||
import {PredefinedNetworkConditions} from 'puppeteer';
|
import {PredefinedNetworkConditions} from 'puppeteer';
|
||||||
const slow3G = PredefinedNetworkConditions['Slow 3G'];
|
|
||||||
|
|
||||||
(async () => {
|
(async () => {
|
||||||
const browser = await puppeteer.launch();
|
const browser = await puppeteer.launch();
|
||||||
const page = await browser.newPage();
|
const page = await browser.newPage();
|
||||||
await page.emulateNetworkConditions(slow3G);
|
await page.emulateNetworkConditions(PredefinedNetworkConditions['Slow 3G']);
|
||||||
|
await page.goto('https://www.google.com');
|
||||||
|
await page.emulateNetworkConditions(PredefinedNetworkConditions['Fast 3G']);
|
||||||
|
await page.goto('https://www.google.com');
|
||||||
|
await page.emulateNetworkConditions(PredefinedNetworkConditions['Slow 4G']); // alias to Fast 3G.
|
||||||
|
await page.goto('https://www.google.com');
|
||||||
|
await page.emulateNetworkConditions(PredefinedNetworkConditions['Fast 4G']);
|
||||||
await page.goto('https://www.google.com');
|
await page.goto('https://www.google.com');
|
||||||
// other actions...
|
// other actions...
|
||||||
await browser.close();
|
await browser.close();
|
||||||
|
@ -7,19 +7,31 @@
|
|||||||
import type {NetworkConditions} from './NetworkManager.js';
|
import type {NetworkConditions} from './NetworkManager.js';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A list of network conditions to be used with
|
* A list of pre-defined network conditions to be used with
|
||||||
* {@link Page.emulateNetworkConditions}.
|
* {@link Page.emulateNetworkConditions}.
|
||||||
*
|
*
|
||||||
* @example
|
* @example
|
||||||
*
|
*
|
||||||
* ```ts
|
* ```ts
|
||||||
* import {PredefinedNetworkConditions} from 'puppeteer';
|
* import {PredefinedNetworkConditions} from 'puppeteer';
|
||||||
* const slow3G = PredefinedNetworkConditions['Slow 3G'];
|
|
||||||
*
|
|
||||||
* (async () => {
|
* (async () => {
|
||||||
* const browser = await puppeteer.launch();
|
* const browser = await puppeteer.launch();
|
||||||
* const page = await browser.newPage();
|
* const page = await browser.newPage();
|
||||||
* await page.emulateNetworkConditions(slow3G);
|
* await page.emulateNetworkConditions(
|
||||||
|
* PredefinedNetworkConditions['Slow 3G']
|
||||||
|
* );
|
||||||
|
* await page.goto('https://www.google.com');
|
||||||
|
* await page.emulateNetworkConditions(
|
||||||
|
* PredefinedNetworkConditions['Fast 3G']
|
||||||
|
* );
|
||||||
|
* await page.goto('https://www.google.com');
|
||||||
|
* await page.emulateNetworkConditions(
|
||||||
|
* PredefinedNetworkConditions['Slow 4G']
|
||||||
|
* ); // alias to Fast 3G.
|
||||||
|
* await page.goto('https://www.google.com');
|
||||||
|
* await page.emulateNetworkConditions(
|
||||||
|
* PredefinedNetworkConditions['Fast 4G']
|
||||||
|
* );
|
||||||
* await page.goto('https://www.google.com');
|
* await page.goto('https://www.google.com');
|
||||||
* // other actions...
|
* // other actions...
|
||||||
* await browser.close();
|
* await browser.close();
|
||||||
@ -29,14 +41,40 @@ import type {NetworkConditions} from './NetworkManager.js';
|
|||||||
* @public
|
* @public
|
||||||
*/
|
*/
|
||||||
export const PredefinedNetworkConditions = Object.freeze({
|
export const PredefinedNetworkConditions = Object.freeze({
|
||||||
|
// Generally aligned with DevTools
|
||||||
|
// https://source.chromium.org/chromium/chromium/src/+/main:third_party/devtools-frontend/src/front_end/core/sdk/NetworkManager.ts;l=398;drc=225e1240f522ca684473f541ae6dae6cd766dd33.
|
||||||
'Slow 3G': {
|
'Slow 3G': {
|
||||||
|
// ~500Kbps down
|
||||||
download: ((500 * 1000) / 8) * 0.8,
|
download: ((500 * 1000) / 8) * 0.8,
|
||||||
|
// ~500Kbps up
|
||||||
upload: ((500 * 1000) / 8) * 0.8,
|
upload: ((500 * 1000) / 8) * 0.8,
|
||||||
|
// 400ms RTT
|
||||||
latency: 400 * 5,
|
latency: 400 * 5,
|
||||||
} as NetworkConditions,
|
} as NetworkConditions,
|
||||||
'Fast 3G': {
|
'Fast 3G': {
|
||||||
|
// ~1.6 Mbps down
|
||||||
download: ((1.6 * 1000 * 1000) / 8) * 0.9,
|
download: ((1.6 * 1000 * 1000) / 8) * 0.9,
|
||||||
|
// ~0.75 Mbps up
|
||||||
upload: ((750 * 1000) / 8) * 0.9,
|
upload: ((750 * 1000) / 8) * 0.9,
|
||||||
|
// 150ms RTT
|
||||||
latency: 150 * 3.75,
|
latency: 150 * 3.75,
|
||||||
} as NetworkConditions,
|
} as NetworkConditions,
|
||||||
|
// alias to Fast 3G to align with Lighthouse (crbug.com/342406608)
|
||||||
|
// and DevTools (crbug.com/342406608),
|
||||||
|
'Slow 4G': {
|
||||||
|
// ~1.6 Mbps down
|
||||||
|
download: ((1.6 * 1000 * 1000) / 8) * 0.9,
|
||||||
|
// ~0.75 Mbps up
|
||||||
|
upload: ((750 * 1000) / 8) * 0.9,
|
||||||
|
// 150ms RTT
|
||||||
|
latency: 150 * 3.75,
|
||||||
|
} as NetworkConditions,
|
||||||
|
'Fast 4G': {
|
||||||
|
// 9 Mbps down
|
||||||
|
download: ((9 * 1000 * 1000) / 8) * 0.9,
|
||||||
|
// 1.5 Mbps up
|
||||||
|
upload: ((1.5 * 1000 * 1000) / 8) * 0.9,
|
||||||
|
// 60ms RTT
|
||||||
|
latency: 60 * 2.75,
|
||||||
|
} as NetworkConditions,
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user