2020-08-03 23:41:48 +03:00
|
|
|
/**
|
|
|
|
* Copyright 2018 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.
|
|
|
|
*/
|
|
|
|
|
2021-04-05 05:32:14 +03:00
|
|
|
import { test as it, expect } from './config/pageTest';
|
|
|
|
import { test as browserTest } from './config/browserTest';
|
2021-04-06 01:51:45 +03:00
|
|
|
import { attachFrame } from './config/utils';
|
2021-04-05 05:32:14 +03:00
|
|
|
|
2021-04-09 17:59:09 +03:00
|
|
|
it.beforeEach(async ({ isAndroid }) => {
|
|
|
|
it.skip(isAndroid);
|
2021-04-05 05:32:14 +03:00
|
|
|
});
|
2020-08-03 23:41:48 +03:00
|
|
|
|
2021-03-19 02:20:35 +03:00
|
|
|
it('should emulate type', async ({page}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(await page.evaluate(() => matchMedia('screen').matches)).toBe(true);
|
|
|
|
expect(await page.evaluate(() => matchMedia('print').matches)).toBe(false);
|
|
|
|
await page.emulateMedia({ media: 'print' });
|
|
|
|
expect(await page.evaluate(() => matchMedia('screen').matches)).toBe(false);
|
|
|
|
expect(await page.evaluate(() => matchMedia('print').matches)).toBe(true);
|
|
|
|
await page.emulateMedia({});
|
|
|
|
expect(await page.evaluate(() => matchMedia('screen').matches)).toBe(false);
|
|
|
|
expect(await page.evaluate(() => matchMedia('print').matches)).toBe(true);
|
|
|
|
await page.emulateMedia({ media: null });
|
|
|
|
expect(await page.evaluate(() => matchMedia('screen').matches)).toBe(true);
|
|
|
|
expect(await page.evaluate(() => matchMedia('print').matches)).toBe(false);
|
|
|
|
});
|
|
|
|
|
2021-03-19 02:20:35 +03:00
|
|
|
it('should throw in case of bad media argument', async ({page}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
let error = null;
|
2020-09-09 13:06:52 +03:00
|
|
|
// @ts-expect-error 'bad' is not a valid media type
|
|
|
|
await page.emulateMedia({ media: 'bad'}).catch(e => error = e);
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(error.message).toContain('media: expected one of (screen|print|null)');
|
|
|
|
});
|
|
|
|
|
2021-03-19 02:20:35 +03:00
|
|
|
it('should emulate scheme work', async ({page}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
await page.emulateMedia({ colorScheme: 'light' });
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: light)').matches)).toBe(true);
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(false);
|
|
|
|
await page.emulateMedia({ colorScheme: 'dark' });
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(true);
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: light)').matches)).toBe(false);
|
|
|
|
});
|
|
|
|
|
2021-03-19 02:20:35 +03:00
|
|
|
it('should default to light', async ({page}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: light)').matches)).toBe(true);
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(false);
|
|
|
|
|
|
|
|
await page.emulateMedia({ colorScheme: 'dark' });
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(true);
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: light)').matches)).toBe(false);
|
|
|
|
|
|
|
|
await page.emulateMedia({ colorScheme: null });
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(false);
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: light)').matches)).toBe(true);
|
|
|
|
});
|
|
|
|
|
2021-03-19 02:20:35 +03:00
|
|
|
it('should throw in case of bad colorScheme argument', async ({page}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
let error = null;
|
2020-09-09 13:06:52 +03:00
|
|
|
// @ts-expect-error 'bad' is not a valid media type
|
|
|
|
await page.emulateMedia({ colorScheme: 'bad' }).catch(e => error = e);
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(error.message).toContain('colorScheme: expected one of (dark|light|no-preference|null)');
|
|
|
|
});
|
|
|
|
|
2020-08-28 14:20:29 +03:00
|
|
|
it('should work during navigation', async ({page, server}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
await page.emulateMedia({ colorScheme: 'light' });
|
|
|
|
const navigated = page.goto(server.EMPTY_PAGE);
|
|
|
|
for (let i = 0; i < 9; i++) {
|
|
|
|
await Promise.all([
|
2020-08-12 01:50:53 +03:00
|
|
|
page.emulateMedia({ colorScheme: (['dark', 'light'] as const)[i & 1] }),
|
2020-08-03 23:41:48 +03:00
|
|
|
new Promise(f => setTimeout(f, 1)),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
await navigated;
|
|
|
|
expect(await page.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(true);
|
|
|
|
});
|
|
|
|
|
2021-04-05 05:32:14 +03:00
|
|
|
browserTest('should work in popup', async ({browser, server}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
{
|
|
|
|
const context = await browser.newContext({ colorScheme: 'dark' });
|
|
|
|
const page = await context.newPage();
|
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
const [popup] = await Promise.all([
|
|
|
|
page.waitForEvent('popup'),
|
|
|
|
page.evaluate(url => { window.open(url); }, server.EMPTY_PAGE),
|
|
|
|
]);
|
|
|
|
expect(await popup.evaluate(() => matchMedia('(prefers-color-scheme: light)').matches)).toBe(false);
|
|
|
|
expect(await popup.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(true);
|
|
|
|
await context.close();
|
|
|
|
}
|
|
|
|
{
|
|
|
|
const page = await browser.newPage({ colorScheme: 'light' });
|
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
const [popup] = await Promise.all([
|
|
|
|
page.waitForEvent('popup'),
|
|
|
|
page.evaluate(url => { window.open(url); }, server.EMPTY_PAGE),
|
|
|
|
]);
|
|
|
|
expect(await popup.evaluate(() => matchMedia('(prefers-color-scheme: light)').matches)).toBe(true);
|
|
|
|
expect(await popup.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(false);
|
|
|
|
await page.close();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-04-05 05:32:14 +03:00
|
|
|
browserTest('should work in cross-process iframe', async ({browser, server}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
const page = await browser.newPage({ colorScheme: 'dark' });
|
|
|
|
await page.goto(server.EMPTY_PAGE);
|
2020-09-19 01:52:14 +03:00
|
|
|
await attachFrame(page, 'frame1', server.CROSS_PROCESS_PREFIX + '/empty.html');
|
2020-08-03 23:41:48 +03:00
|
|
|
const frame = page.frames()[1];
|
|
|
|
expect(await frame.evaluate(() => matchMedia('(prefers-color-scheme: dark)').matches)).toBe(true);
|
|
|
|
await page.close();
|
|
|
|
});
|
|
|
|
|
2020-08-28 14:20:29 +03:00
|
|
|
it('should change the actual colors in css', async ({page}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
await page.setContent(`
|
|
|
|
<style>
|
|
|
|
@media (prefers-color-scheme: dark) {
|
|
|
|
div {
|
|
|
|
background: black;
|
|
|
|
color: white;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@media (prefers-color-scheme: light) {
|
|
|
|
div {
|
|
|
|
background: white;
|
|
|
|
color: black;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
</style>
|
|
|
|
<div>Hello</div>
|
|
|
|
`);
|
|
|
|
function getBackgroundColor() {
|
|
|
|
return page.$eval('div', div => window.getComputedStyle(div).backgroundColor);
|
|
|
|
}
|
|
|
|
|
2020-08-28 14:20:29 +03:00
|
|
|
await page.emulateMedia({ colorScheme: 'light' });
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(await getBackgroundColor()).toBe('rgb(255, 255, 255)');
|
|
|
|
|
2020-08-28 14:20:29 +03:00
|
|
|
await page.emulateMedia({ colorScheme: 'dark' });
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(await getBackgroundColor()).toBe('rgb(0, 0, 0)');
|
|
|
|
|
2020-08-28 14:20:29 +03:00
|
|
|
await page.emulateMedia({ colorScheme: 'light' });
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(await getBackgroundColor()).toBe('rgb(255, 255, 255)');
|
2020-08-28 14:20:29 +03:00
|
|
|
});
|