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.
|
|
|
|
*/
|
2020-09-03 07:43:38 +03:00
|
|
|
|
2021-04-29 21:11:32 +03:00
|
|
|
import { contextTest as it, expect } from './config/browserTest';
|
2020-08-03 23:41:48 +03:00
|
|
|
|
2020-08-28 14:20:29 +03:00
|
|
|
it('should return no cookies in pristine browser context', async ({context, page, server}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(await context.cookies()).toEqual([]);
|
|
|
|
});
|
|
|
|
|
2021-08-09 23:57:17 +03:00
|
|
|
it('should get a cookie', async ({context, page, server, browserName}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
const documentCookie = await page.evaluate(() => {
|
|
|
|
document.cookie = 'username=John Doe';
|
|
|
|
return document.cookie;
|
|
|
|
});
|
|
|
|
expect(documentCookie).toBe('username=John Doe');
|
|
|
|
expect(await context.cookies()).toEqual([{
|
|
|
|
name: 'username',
|
|
|
|
value: 'John Doe',
|
|
|
|
domain: 'localhost',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: false,
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: browserName === 'chromium' ? 'Lax' : 'None',
|
2020-08-03 23:41:48 +03:00
|
|
|
}]);
|
|
|
|
});
|
|
|
|
|
2021-08-09 23:57:17 +03:00
|
|
|
it('should get a non-session cookie', async ({context, page, server, browserName}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
// @see https://en.wikipedia.org/wiki/Year_2038_problem
|
|
|
|
const date = +(new Date('1/1/2038'));
|
|
|
|
const documentCookie = await page.evaluate(timestamp => {
|
|
|
|
const date = new Date(timestamp);
|
|
|
|
document.cookie = `username=John Doe;expires=${date.toUTCString()}`;
|
|
|
|
return document.cookie;
|
|
|
|
}, date);
|
|
|
|
expect(documentCookie).toBe('username=John Doe');
|
|
|
|
expect(await context.cookies()).toEqual([{
|
|
|
|
name: 'username',
|
|
|
|
value: 'John Doe',
|
|
|
|
domain: 'localhost',
|
|
|
|
path: '/',
|
|
|
|
expires: date / 1000,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: false,
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: browserName === 'chromium' ? 'Lax' : 'None',
|
2020-08-03 23:41:48 +03:00
|
|
|
}]);
|
|
|
|
});
|
|
|
|
|
2020-08-28 14:20:29 +03:00
|
|
|
it('should properly report httpOnly cookie', async ({context, page, server}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
server.setRoute('/empty.html', (req, res) => {
|
|
|
|
res.setHeader('Set-Cookie', 'name=value;HttpOnly; Path=/');
|
|
|
|
res.end();
|
|
|
|
});
|
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
const cookies = await context.cookies();
|
|
|
|
expect(cookies.length).toBe(1);
|
|
|
|
expect(cookies[0].httpOnly).toBe(true);
|
|
|
|
});
|
|
|
|
|
2021-04-03 07:07:45 +03:00
|
|
|
it('should properly report "Strict" sameSite cookie', async ({context, page, server, browserName, platform}) => {
|
|
|
|
it.fail(browserName === 'webkit' && platform === 'win32');
|
|
|
|
|
2020-08-03 23:41:48 +03:00
|
|
|
server.setRoute('/empty.html', (req, res) => {
|
|
|
|
res.setHeader('Set-Cookie', 'name=value;SameSite=Strict');
|
|
|
|
res.end();
|
|
|
|
});
|
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
const cookies = await context.cookies();
|
|
|
|
expect(cookies.length).toBe(1);
|
|
|
|
expect(cookies[0].sameSite).toBe('Strict');
|
|
|
|
});
|
|
|
|
|
2021-04-03 07:07:45 +03:00
|
|
|
it('should properly report "Lax" sameSite cookie', async ({context, page, server, browserName, platform}) => {
|
|
|
|
it.fail(browserName === 'webkit' && platform === 'win32');
|
|
|
|
|
2020-08-03 23:41:48 +03:00
|
|
|
server.setRoute('/empty.html', (req, res) => {
|
|
|
|
res.setHeader('Set-Cookie', 'name=value;SameSite=Lax');
|
|
|
|
res.end();
|
|
|
|
});
|
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
const cookies = await context.cookies();
|
|
|
|
expect(cookies.length).toBe(1);
|
|
|
|
expect(cookies[0].sameSite).toBe('Lax');
|
|
|
|
});
|
|
|
|
|
2021-08-09 23:57:17 +03:00
|
|
|
it('should get multiple cookies', async ({context, page, server, browserName}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
const documentCookie = await page.evaluate(() => {
|
|
|
|
document.cookie = 'username=John Doe';
|
|
|
|
document.cookie = 'password=1234';
|
|
|
|
return document.cookie.split('; ').sort().join('; ');
|
|
|
|
});
|
2021-02-19 22:50:59 +03:00
|
|
|
const cookies = new Set(await context.cookies());
|
2020-08-03 23:41:48 +03:00
|
|
|
expect(documentCookie).toBe('password=1234; username=John Doe');
|
2021-02-19 22:50:59 +03:00
|
|
|
expect(cookies).toEqual(new Set([
|
2020-08-03 23:41:48 +03:00
|
|
|
{
|
|
|
|
name: 'password',
|
|
|
|
value: '1234',
|
|
|
|
domain: 'localhost',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: false,
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: browserName === 'chromium' ? 'Lax' : 'None',
|
2020-08-03 23:41:48 +03:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'username',
|
|
|
|
value: 'John Doe',
|
|
|
|
domain: 'localhost',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: false,
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: browserName === 'chromium' ? 'Lax' : 'None',
|
2020-08-03 23:41:48 +03:00
|
|
|
},
|
2021-02-19 22:50:59 +03:00
|
|
|
]));
|
2020-08-03 23:41:48 +03:00
|
|
|
});
|
|
|
|
|
2021-08-11 20:27:41 +03:00
|
|
|
it('should get cookies from multiple urls', async ({context, browserName, isWindows}) => {
|
2020-08-03 23:41:48 +03:00
|
|
|
await context.addCookies([{
|
|
|
|
url: 'https://foo.com',
|
|
|
|
name: 'doggo',
|
|
|
|
value: 'woofs',
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: 'None',
|
2020-08-03 23:41:48 +03:00
|
|
|
}, {
|
|
|
|
url: 'https://bar.com',
|
|
|
|
name: 'catto',
|
|
|
|
value: 'purrs',
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: 'Lax',
|
2020-08-03 23:41:48 +03:00
|
|
|
}, {
|
|
|
|
url: 'https://baz.com',
|
|
|
|
name: 'birdo',
|
|
|
|
value: 'tweets',
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: 'Lax',
|
2020-08-03 23:41:48 +03:00
|
|
|
}]);
|
2021-02-19 22:50:59 +03:00
|
|
|
const cookies = new Set(await context.cookies(['https://foo.com', 'https://baz.com']));
|
|
|
|
expect(cookies).toEqual(new Set([{
|
2020-08-03 23:41:48 +03:00
|
|
|
name: 'birdo',
|
|
|
|
value: 'tweets',
|
|
|
|
domain: 'baz.com',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: true,
|
2021-08-11 20:27:41 +03:00
|
|
|
sameSite: (browserName === 'webkit' && isWindows) ? 'None' : 'Lax',
|
2020-08-03 23:41:48 +03:00
|
|
|
}, {
|
|
|
|
name: 'doggo',
|
|
|
|
value: 'woofs',
|
|
|
|
domain: 'foo.com',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: true,
|
|
|
|
sameSite: 'None',
|
2021-02-19 22:50:59 +03:00
|
|
|
}]));
|
2020-08-03 23:41:48 +03:00
|
|
|
});
|
2021-01-13 02:56:29 +03:00
|
|
|
|
2021-08-11 20:27:41 +03:00
|
|
|
it('should work with subdomain cookie', async ({context, browserName, isWindows}) => {
|
2021-01-13 02:56:29 +03:00
|
|
|
await context.addCookies([{
|
|
|
|
domain: '.foo.com',
|
|
|
|
path: '/',
|
|
|
|
name: 'doggo',
|
|
|
|
value: 'woofs',
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: 'Lax',
|
2021-01-13 02:56:29 +03:00
|
|
|
secure: true
|
|
|
|
}]);
|
|
|
|
expect(await context.cookies('https://foo.com')).toEqual([{
|
|
|
|
name: 'doggo',
|
|
|
|
value: 'woofs',
|
|
|
|
domain: '.foo.com',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: true,
|
2021-08-11 20:27:41 +03:00
|
|
|
sameSite: (browserName === 'webkit' && isWindows) ? 'None' : 'Lax',
|
2021-01-13 02:56:29 +03:00
|
|
|
}]);
|
|
|
|
expect(await context.cookies('https://sub.foo.com')).toEqual([{
|
|
|
|
name: 'doggo',
|
|
|
|
value: 'woofs',
|
|
|
|
domain: '.foo.com',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: true,
|
2021-08-11 20:27:41 +03:00
|
|
|
sameSite: (browserName === 'webkit' && isWindows) ? 'None' : 'Lax',
|
2021-01-13 02:56:29 +03:00
|
|
|
}]);
|
|
|
|
});
|
2021-01-26 03:37:33 +03:00
|
|
|
|
|
|
|
it('should not return cookies with empty value', async ({context, page, server}) => {
|
|
|
|
server.setRoute('/empty.html', (req, res) => {
|
|
|
|
res.setHeader('Set-Cookie', 'name=;Path=/');
|
|
|
|
res.end();
|
|
|
|
});
|
|
|
|
await page.goto(server.EMPTY_PAGE);
|
|
|
|
const cookies = await context.cookies();
|
|
|
|
expect(cookies.length).toBe(0);
|
|
|
|
});
|
|
|
|
|
2021-08-11 20:27:41 +03:00
|
|
|
it('should return secure cookies based on HTTP(S) protocol', async ({context, browserName, isWindows}) => {
|
2021-02-19 22:50:59 +03:00
|
|
|
await context.addCookies([{
|
|
|
|
url: 'https://foo.com',
|
|
|
|
name: 'doggo',
|
|
|
|
value: 'woofs',
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: 'Lax',
|
2021-02-19 22:50:59 +03:00
|
|
|
secure: true
|
|
|
|
}, {
|
|
|
|
url: 'http://foo.com',
|
|
|
|
name: 'catto',
|
|
|
|
value: 'purrs',
|
2021-08-09 23:57:17 +03:00
|
|
|
sameSite: 'Lax',
|
2021-02-19 22:50:59 +03:00
|
|
|
secure: false
|
|
|
|
}]);
|
|
|
|
const cookies = new Set(await context.cookies('https://foo.com'));
|
|
|
|
expect(cookies).toEqual(new Set([{
|
|
|
|
name: 'catto',
|
|
|
|
value: 'purrs',
|
|
|
|
domain: 'foo.com',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: false,
|
2021-08-11 20:27:41 +03:00
|
|
|
sameSite: (browserName === 'webkit' && isWindows) ? 'None' : 'Lax',
|
2021-02-19 22:50:59 +03:00
|
|
|
}, {
|
|
|
|
name: 'doggo',
|
|
|
|
value: 'woofs',
|
|
|
|
domain: 'foo.com',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: true,
|
2021-08-11 20:27:41 +03:00
|
|
|
sameSite: (browserName === 'webkit' && isWindows) ? 'None' : 'Lax',
|
2021-02-19 22:50:59 +03:00
|
|
|
}]));
|
|
|
|
expect(await context.cookies('http://foo.com/')).toEqual([{
|
|
|
|
name: 'catto',
|
|
|
|
value: 'purrs',
|
|
|
|
domain: 'foo.com',
|
|
|
|
path: '/',
|
|
|
|
expires: -1,
|
|
|
|
httpOnly: false,
|
|
|
|
secure: false,
|
2021-08-11 20:27:41 +03:00
|
|
|
sameSite: (browserName === 'webkit' && isWindows) ? 'None' : 'Lax',
|
2021-02-19 22:50:59 +03:00
|
|
|
}]);
|
|
|
|
});
|