2019-11-26 17:05:17 +01:00
|
|
|
import {
|
|
|
|
getClientLocale,
|
|
|
|
capital,
|
|
|
|
title,
|
|
|
|
upper,
|
|
|
|
lower,
|
2020-01-15 17:47:02 +01:00
|
|
|
flatObj,
|
2020-01-23 14:11:04 +01:00
|
|
|
} from '../../../src/runtime/includes/utils'
|
2019-11-26 17:05:17 +01:00
|
|
|
|
|
|
|
describe('getting client locale', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
delete window.location
|
|
|
|
window.location = {
|
|
|
|
pathname: '/',
|
|
|
|
hostname: 'example.com',
|
|
|
|
hash: '',
|
|
|
|
search: '',
|
|
|
|
} as any
|
|
|
|
})
|
|
|
|
|
|
|
|
test('gets the locale based on the passed hash parameter', () => {
|
|
|
|
window.location.hash = '#locale=en-US&lang=pt-BR'
|
2019-11-26 17:18:07 +01:00
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
hash: 'lang',
|
|
|
|
})
|
|
|
|
).toBe('pt-BR')
|
2019-11-26 17:05:17 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
test('gets the locale based on the passed search parameter', () => {
|
|
|
|
window.location.search = '?locale=en-US&lang=pt-BR'
|
2019-11-26 17:18:07 +01:00
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
search: 'lang',
|
|
|
|
})
|
|
|
|
).toBe('pt-BR')
|
2019-11-26 17:05:17 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
test('gets the locale based on the navigator language', () => {
|
2019-11-26 17:18:07 +01:00
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
navigator: true,
|
|
|
|
})
|
|
|
|
).toBe(window.navigator.language)
|
2019-11-26 17:05:17 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
test('gets the locale based on the pathname', () => {
|
|
|
|
window.location.pathname = '/en-US/foo/'
|
2019-11-26 17:18:07 +01:00
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
pathname: /^\/(.*?)\//,
|
|
|
|
})
|
|
|
|
).toBe('en-US')
|
2019-11-26 17:05:17 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
test('gets the locale base on the hostname', () => {
|
|
|
|
window.location.hostname = 'pt.example.com'
|
2019-11-26 17:18:07 +01:00
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
hostname: /^(.*?)\./,
|
|
|
|
})
|
|
|
|
).toBe('pt')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('hostname precedes pathname', () => {
|
|
|
|
window.location.pathname = '/en-US/foo/'
|
|
|
|
window.location.hostname = 'pt.example.com'
|
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
hostname: /^(.*?)\./,
|
|
|
|
pathname: /^\/(.*?)\//,
|
|
|
|
})
|
|
|
|
).toBe('pt')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('pathname precedes navigator', () => {
|
|
|
|
window.location.pathname = '/it-IT/foo/'
|
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
pathname: /^\/(.*?)\//,
|
|
|
|
navigator: true,
|
|
|
|
})
|
|
|
|
).toBe('it-IT')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('navigator precedes search', () => {
|
|
|
|
window.location.search = '?lang=pt-BR'
|
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
navigator: true,
|
|
|
|
search: 'lang',
|
|
|
|
})
|
|
|
|
).toBe('en-US')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('search precedes hash', () => {
|
|
|
|
window.location.hash = '#lang=pt-BR'
|
|
|
|
window.location.search = '?lang=it-IT'
|
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
hash: 'lang',
|
|
|
|
search: 'lang',
|
|
|
|
})
|
|
|
|
).toBe('it-IT')
|
2019-11-26 17:05:17 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
test('returns null if no locale was found', () => {
|
2019-11-26 17:18:07 +01:00
|
|
|
expect(
|
|
|
|
getClientLocale({
|
|
|
|
search: 'lang',
|
|
|
|
})
|
|
|
|
).toBe(null)
|
2019-11-26 17:05:17 +01:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('string utilities', () => {
|
|
|
|
test('transforms a string into capital case', () => {
|
|
|
|
expect(capital('lowercase string')).toMatch('Lowercase string')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('transforms a string into title case', () => {
|
|
|
|
expect(title('lowercase string')).toMatch('Lowercase String')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('transforms a string into uppercase', () => {
|
|
|
|
expect(upper('lowercase string')).toMatch('LOWERCASE STRING')
|
|
|
|
})
|
|
|
|
|
|
|
|
test('transforms a string into lowercase', () => {
|
|
|
|
expect(lower('UPPERCASE STRING')).toMatch('uppercase string')
|
|
|
|
})
|
|
|
|
})
|
2020-01-15 17:47:02 +01:00
|
|
|
|
|
|
|
describe('deep object handling', () => {
|
|
|
|
test('flattens a deep object', () => {
|
|
|
|
const obj = {
|
|
|
|
a: { b: { c: { d: 'foo' } } },
|
|
|
|
e: { f: 'bar' },
|
|
|
|
}
|
|
|
|
expect(flatObj(obj)).toMatchObject({
|
|
|
|
'a.b.c.d': 'foo',
|
|
|
|
'e.f': 'bar',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
test('flattens a deep object with array values', () => {
|
|
|
|
const obj = {
|
|
|
|
a: { b: { c: { d: ['foo', 'bar'] } } },
|
|
|
|
e: { f: ['foo', 'bar'] },
|
|
|
|
}
|
|
|
|
expect(flatObj(obj)).toMatchObject({
|
|
|
|
'a.b.c.d.0': 'foo',
|
|
|
|
'a.b.c.d.1': 'bar',
|
|
|
|
'e.f.0': 'foo',
|
|
|
|
'e.f.1': 'bar',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|