From c15534ff01f7f5604b16a6ed11d351d78f6c6414 Mon Sep 17 00:00:00 2001 From: Pavel Feldman Date: Thu, 13 Feb 2020 13:37:59 -0800 Subject: [PATCH] fix(locale): document locale parameter (#990) --- docs/api.md | 2 ++ src/browserContext.ts | 2 +- src/chromium/crPage.ts | 4 ++-- src/webkit/wkBrowser.ts | 4 ++-- src/webkit/wkPage.ts | 12 ++++++------ test/emulation.spec.js | 6 +++--- 6 files changed, 16 insertions(+), 14 deletions(-) diff --git a/docs/api.md b/docs/api.md index bfb95e292a..5af1c4165e 100644 --- a/docs/api.md +++ b/docs/api.md @@ -196,6 +196,7 @@ Indicates that the browser is connected. - `latitude` <[number]> Latitude between -90 and 90. - `longitude` <[number]> Longitude between -180 and 180. - `accuracy` <[number]> Optional non-negative accuracy value. + - `locale` Specify user locale, for example `en-GB`, `de-DE`, etc. Locale will affect `navigator.language` value, `Accept-Language` request header value as well as number and date formatting rules. - `permissions` <[Object]> A map from origin keys to permissions values. See [browserContext.setPermissions](#browsercontextsetpermissionsorigin-permissions) for more details. - returns: <[Promise]<[BrowserContext]>> @@ -228,6 +229,7 @@ Creates a new browser context. It won't share cookies/cache with other browser c - `latitude` <[number]> Latitude between -90 and 90. - `longitude` <[number]> Longitude between -180 and 180. - `accuracy` <[number]> Optional non-negative accuracy value. + - `locale` Specify user locale, for example `en-GB`, `de-DE`, etc. Locale will affect `navigator.language` value, `Accept-Language` request header value as well as number and date formatting rules. - `permissions` <[Object]> A map from origin keys to permissions values. See [browserContext.setPermissions](#browsercontextsetpermissionsorigin-permissions) for more details. - returns: <[Promise]<[Page]>> diff --git a/src/browserContext.ts b/src/browserContext.ts index 2c6768a159..7c819ae372 100644 --- a/src/browserContext.ts +++ b/src/browserContext.ts @@ -44,7 +44,7 @@ export type BrowserContextOptions = { javaScriptEnabled?: boolean, bypassCSP?: boolean, userAgent?: string, - language?: string, + locale?: string, timezoneId?: string, geolocation?: types.Geolocation, permissions?: { [key: string]: string[] }; diff --git a/src/chromium/crPage.ts b/src/chromium/crPage.ts index a032329098..a09d918c88 100644 --- a/src/chromium/crPage.ts +++ b/src/chromium/crPage.ts @@ -110,8 +110,8 @@ export class CRPage implements PageDelegate { promises.push(this._updateViewport(true /* updateTouch */)); if (options.javaScriptEnabled === false) promises.push(this._client.send('Emulation.setScriptExecutionDisabled', { value: true })); - if (options.userAgent || options.language) - promises.push(this._client.send('Emulation.setUserAgentOverride', { userAgent: options.userAgent || '', acceptLanguage: options.language })); + if (options.userAgent || options.locale) + promises.push(this._client.send('Emulation.setUserAgentOverride', { userAgent: options.userAgent || '', acceptLanguage: options.locale })); if (options.timezoneId) promises.push(emulateTimezone(this._client, options.timezoneId)); if (options.geolocation) diff --git a/src/webkit/wkBrowser.ts b/src/webkit/wkBrowser.ts index 2615debc5a..3b93574441 100644 --- a/src/webkit/wkBrowser.ts +++ b/src/webkit/wkBrowser.ts @@ -78,8 +78,8 @@ export class WKBrowser extends platform.EventEmitter implements Browser { const context = this._createBrowserContext(browserContextId, options); if (options.ignoreHTTPSErrors) await this._browserSession.send('Browser.setIgnoreCertificateErrors', { browserContextId, ignore: true }); - if (options.language) - await this._browserSession.send('Browser.setLanguages', { browserContextId, languages: [options.language] }); + if (options.locale) + await this._browserSession.send('Browser.setLanguages', { browserContextId, languages: [options.locale] }); await context._initialize(); this._contexts.set(browserContextId, context); return context; diff --git a/src/webkit/wkPage.ts b/src/webkit/wkPage.ts index e093f01e3c..953ff968ea 100644 --- a/src/webkit/wkPage.ts +++ b/src/webkit/wkPage.ts @@ -142,10 +142,10 @@ export class WKPage implements PageDelegate { } if (contextOptions.bypassCSP) promises.push(session.send('Page.setBypassCSP', { enabled: true })); - if (this._page._state.extraHTTPHeaders || contextOptions.language) { + if (this._page._state.extraHTTPHeaders || contextOptions.locale) { const headers = this._page._state.extraHTTPHeaders || {}; - if (contextOptions.language) - headers['Accept-Language'] = contextOptions.language; + if (contextOptions.locale) + headers['Accept-Language'] = contextOptions.locale; promises.push(session.send('Network.setExtraHTTPHeaders', { headers })); } if (this._page._state.hasTouch) @@ -380,9 +380,9 @@ export class WKPage implements PageDelegate { async setExtraHTTPHeaders(headers: network.Headers): Promise { const copy = { ...headers }; - const language = this._page.context()._options.language; - if (language) - copy['Accept-Language'] = language; + const locale = this._page.context()._options.locale; + if (locale) + copy['Accept-Language'] = locale; await this._updateState('Network.setExtraHTTPHeaders', { headers: copy }); } diff --git a/test/emulation.spec.js b/test/emulation.spec.js index fe49c59f10..bdf94df102 100644 --- a/test/emulation.spec.js +++ b/test/emulation.spec.js @@ -225,7 +225,7 @@ module.exports.describe = function({testRunner, expect, playwright, headless, FF describe.skip(CHROMIUM || FFOX)('BrowserContext({language})', function() { it('should affect accept-language header', async({newPage, server}) => { - const page = await newPage({ language: 'fr-CH' }); + const page = await newPage({ locale: 'fr-CH' }); const [request] = await Promise.all([ server.waitForRequest('/empty.html'), page.goto(server.EMPTY_PAGE), @@ -240,7 +240,7 @@ module.exports.describe = function({testRunner, expect, playwright, headless, FF expect(await page.evaluate(() => (1000000.50).toLocaleString())).toBe('1,000,000.5'); } { - const page = await newPage({ language: 'fr-CH' }); + const page = await newPage({ locale: 'fr-CH' }); await page.goto(server.EMPTY_PAGE); expect(await page.evaluate(() => (1000000.50).toLocaleString())).toBe('1 000 000,5'); } @@ -253,7 +253,7 @@ module.exports.describe = function({testRunner, expect, playwright, headless, FF 'Sat Nov 19 2016 10:12:34 GMT-0800 (PST)'); } { - const page = await newPage({ language: 'de-de', timezoneId: 'Europe/Berlin' }); + const page = await newPage({ locale: 'de-de', timezoneId: 'Europe/Berlin' }); await page.goto(server.EMPTY_PAGE); expect(await page.evaluate(() => new Date(1479579154987).toString())).toBe( 'Sat Nov 19 2016 19:12:34 GMT+0100 (Mitteleuropäische Normalzeit)');