mirror of https://github.com/tc39/test262.git
87 lines
2.8 KiB
JavaScript
87 lines
2.8 KiB
JavaScript
|
// Copyright (C) 2020 André Bargull. All rights reserved.
|
||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||
|
|
||
|
/*---
|
||
|
esid: sec-intl.getcanonicallocales
|
||
|
description: >
|
||
|
"kb", "kc", "kh", "kk", and "kn" Unicode extension keys canonicalise "yes" to "true".
|
||
|
info: |
|
||
|
8.2.1 Intl.getCanonicalLocales (locales)
|
||
|
1. Let ll be ? CanonicalizeLocaleList(locales).
|
||
|
2. Return CreateArrayFromList(ll).
|
||
|
|
||
|
9.2.1 CanonicalizeLocaleList (locales)
|
||
|
...
|
||
|
7. Repeat, while k < len
|
||
|
...
|
||
|
c. If kPresent is true, then
|
||
|
...
|
||
|
v. If IsStructurallyValidLanguageTag(tag) is false, throw a RangeError exception.
|
||
|
vi. Let canonicalizedTag be CanonicalizeUnicodeLocaleId(tag).
|
||
|
...
|
||
|
|
||
|
UTS 35, §3.2.1 Canonical Unicode Locale Identifiers
|
||
|
Use the bcp47 data to replace keys, types, tfields, and tvalues by their canonical forms.
|
||
|
See Section 3.6.4 U Extension Data Files) and Section 3.7.1 T Extension Data Files. The
|
||
|
aliases are in the alias attribute value, while the canonical is in the name attribute value.
|
||
|
|
||
|
UTS 35, §3.2.1 Canonical Unicode Locale Identifiers
|
||
|
Any type or tfield value "true" is removed.
|
||
|
includes: [testIntl.js]
|
||
|
---*/
|
||
|
|
||
|
const unicodeKeys = [
|
||
|
// <key name="kb" [...] alias="colBackwards">
|
||
|
// <type name="true" [...] alias="yes"/>
|
||
|
"kb",
|
||
|
|
||
|
// <key name="kc" [...] alias="colCaseLevel">
|
||
|
// <type name="true" [...] alias="yes"/>
|
||
|
"kc",
|
||
|
|
||
|
// <key name="kh" [...] alias="colBackwards">
|
||
|
// <type name="true" [...] alias="yes"/>
|
||
|
"kh",
|
||
|
|
||
|
// <key name="kh" [...] alias="colHiraganaQuaternary">
|
||
|
// <type name="true" [...] alias="yes"/>
|
||
|
"kk",
|
||
|
|
||
|
// <key name="kn" [...] alias="colNumeric">
|
||
|
// <type name="true" [...] alias="yes"/>
|
||
|
"kn",
|
||
|
];
|
||
|
|
||
|
for (let key of unicodeKeys) {
|
||
|
let tag = `und-u-${key}-yes`;
|
||
|
let canonical = `und-u-${key}`;
|
||
|
|
||
|
// Make sure the test data is correct.
|
||
|
assert.sameValue(isCanonicalizedStructurallyValidLanguageTag(tag), false,
|
||
|
"\"" + tag + "\" isn't a canonical language tag.");
|
||
|
assert(isCanonicalizedStructurallyValidLanguageTag(canonical),
|
||
|
"\"" + canonical + "\" is a canonical and structurally valid language tag.");
|
||
|
|
||
|
let result = Intl.getCanonicalLocales(tag);
|
||
|
assert.sameValue(result.length, 1);
|
||
|
assert.sameValue(result[0], canonical);
|
||
|
}
|
||
|
|
||
|
// Test some other Unicode extension keys which don't contain an alias entry to
|
||
|
// canonicalise "yes" to "true".
|
||
|
const otherUnicodeKeys = [
|
||
|
"ka", "kf", "kr", "ks", "kv",
|
||
|
];
|
||
|
|
||
|
for (let key of otherUnicodeKeys) {
|
||
|
let tag = `und-u-${key}-yes`;
|
||
|
|
||
|
// Make sure the test data is correct.
|
||
|
assert(isCanonicalizedStructurallyValidLanguageTag(tag),
|
||
|
"\"" + tag + "\" is a canonical and structurally valid language tag.");
|
||
|
|
||
|
let result = Intl.getCanonicalLocales(tag);
|
||
|
assert.sameValue(result.length, 1);
|
||
|
assert.sameValue(result[0], tag);
|
||
|
}
|