feat(page): add color-gamut support to Page.emulateMediaFeatures (#6857)

The change updates the validation function to allow color-gamut media
features and updates the documentation.

Issues: #6761
This commit is contained in:
Alex Rudenko 2021-02-11 14:59:50 +01:00 committed by GitHub
parent a63f53c938
commit ad5935738d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 46 additions and 2 deletions

View File

@ -1411,7 +1411,7 @@ List of all available devices is available in the source code: [src/common/Devic
#### page.emulateMediaFeatures(features) #### page.emulateMediaFeatures(features)
- `features` <?[Array]<[Object]>> Given an array of media feature objects, emulates CSS media features on the page. Each media feature object must have the following properties: - `features` <?[Array]<[Object]>> Given an array of media feature objects, emulates CSS media features on the page. Each media feature object must have the following properties:
- `name` <[string]> The CSS media feature name. Supported names are `'prefers-colors-scheme'` and `'prefers-reduced-motion'`. - `name` <[string]> The CSS media feature name. Supported names are `'prefers-colors-scheme'`, `'prefers-reduced-motion'`, and `'color-gamut'`.
- `value` <[string]> The value for the given CSS media feature. - `value` <[string]> The value for the given CSS media feature.
- returns: <[Promise]> - returns: <[Promise]>
@ -1440,6 +1440,16 @@ await page.evaluate(() => matchMedia('(prefers-reduced-motion: reduce)').matches
// → true // → true
await page.evaluate(() => matchMedia('(prefers-reduced-motion: no-preference)').matches); await page.evaluate(() => matchMedia('(prefers-reduced-motion: no-preference)').matches);
// → false // → false
await page.emulateMediaFeatures([
{ name: 'color-gamut', value: 'p3' },
]);
await page.evaluate(() => matchMedia('(color-gamut: srgb)').matches);
// → true
await page.evaluate(() => matchMedia('(color-gamut: p3)').matches);
// → true
await page.evaluate(() => matchMedia('(color-gamut: rec2020)').matches);
// → false
``` ```
#### page.emulateMediaType(type) #### page.emulateMediaType(type)

View File

@ -1420,7 +1420,9 @@ export class Page extends EventEmitter {
features.every((mediaFeature) => { features.every((mediaFeature) => {
const name = mediaFeature.name; const name = mediaFeature.name;
assert( assert(
/^prefers-(?:color-scheme|reduced-motion)$/.test(name), /^(?:prefers-(?:color-scheme|reduced-motion)|color-gamut)$/.test(
name
),
'Unsupported media feature: ' + name 'Unsupported media feature: ' + name
); );
return true; return true;

View File

@ -242,6 +242,38 @@ describe('Emulation', () => {
() => matchMedia('(prefers-color-scheme: dark)').matches () => matchMedia('(prefers-color-scheme: dark)').matches
) )
).toBe(false); ).toBe(false);
await page.emulateMediaFeatures([{ name: 'color-gamut', value: 'srgb' }]);
expect(
await page.evaluate(() => matchMedia('(color-gamut: p3)').matches)
).toBe(false);
expect(
await page.evaluate(() => matchMedia('(color-gamut: srgb)').matches)
).toBe(true);
expect(
await page.evaluate(() => matchMedia('(color-gamut: rec2020)').matches)
).toBe(false);
await page.emulateMediaFeatures([{ name: 'color-gamut', value: 'p3' }]);
expect(
await page.evaluate(() => matchMedia('(color-gamut: p3)').matches)
).toBe(true);
expect(
await page.evaluate(() => matchMedia('(color-gamut: srgb)').matches)
).toBe(true);
expect(
await page.evaluate(() => matchMedia('(color-gamut: rec2020)').matches)
).toBe(false);
await page.emulateMediaFeatures([
{ name: 'color-gamut', value: 'rec2020' },
]);
expect(
await page.evaluate(() => matchMedia('(color-gamut: p3)').matches)
).toBe(true);
expect(
await page.evaluate(() => matchMedia('(color-gamut: srgb)').matches)
).toBe(true);
expect(
await page.evaluate(() => matchMedia('(color-gamut: rec2020)').matches)
).toBe(true);
}); });
it('should throw in case of bad argument', async () => { it('should throw in case of bad argument', async () => {
const { page } = getTestState(); const { page } = getTestState();