summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/intl402/Locale/constructor-options-collation-valid.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /js/src/tests/test262/intl402/Locale/constructor-options-collation-valid.js
parentInitial commit. (diff)
downloadfirefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz
firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/tests/test262/intl402/Locale/constructor-options-collation-valid.js')
-rw-r--r--js/src/tests/test262/intl402/Locale/constructor-options-collation-valid.js64
1 files changed, 64 insertions, 0 deletions
diff --git a/js/src/tests/test262/intl402/Locale/constructor-options-collation-valid.js b/js/src/tests/test262/intl402/Locale/constructor-options-collation-valid.js
new file mode 100644
index 0000000000..e9bf3077a2
--- /dev/null
+++ b/js/src/tests/test262/intl402/Locale/constructor-options-collation-valid.js
@@ -0,0 +1,64 @@
+// Copyright 2018 Igalia, S.L. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-intl.locale
+description: >
+ Checks valid cases for the options argument to the Locale constructor.
+info: |
+ Intl.Locale( tag [, options] )
+
+ ...
+ 17. Let collation be ? GetOption(options, "collation", "string", undefined, undefined).
+ ...
+ 19. Set opt.[[co]] to collation.
+ ...
+ 30. Let r be ! ApplyUnicodeExtensionToTag(tag, opt, relevantExtensionKeys).
+ ...
+
+ ApplyUnicodeExtensionToTag( tag, options, relevantExtensionKeys )
+
+ ...
+ 8. Let locale be the String value that is tag with all Unicode locale extension sequences removed.
+ 9. Let newExtension be ! CanonicalizeUnicodeExtension(attributes, keywords).
+ 10. If newExtension is not the empty String, then
+ a. Let locale be ! InsertUnicodeExtension(locale, newExtension).
+ ...
+
+ CanonicalizeUnicodeExtension( attributes, keywords )
+ ...
+ 4. Repeat for each element entry of keywords in List order,
+ a. Let keyword be entry.[[Key]].
+ b. If entry.[[Value]] is not the empty String, then
+ i. Let keyword be the string-concatenation of keyword, "-", and entry.[[Value]].
+ c. Append keyword to fullKeywords.
+ ...
+features: [Intl.Locale]
+---*/
+
+const validCollationOptions = [
+ ["abc", "en-u-co-abc"],
+ ["abcd", "en-u-co-abcd"],
+ ["abcde", "en-u-co-abcde"],
+ ["abcdef", "en-u-co-abcdef"],
+ ["abcdefg", "en-u-co-abcdefg"],
+ ["abcdefgh", "en-u-co-abcdefgh"],
+ ["12345678", "en-u-co-12345678"],
+ ["1234abcd", "en-u-co-1234abcd"],
+ ["1234abcd-abc123", "en-u-co-1234abcd-abc123"],
+];
+for (const [collation, expected] of validCollationOptions) {
+ assert.sameValue(
+ new Intl.Locale('en', {collation}).toString(),
+ expected,
+ `new Intl.Locale('en', {collation: "${collation}"}).toString() returns "${expected}"`
+ );
+
+ assert.sameValue(
+ new Intl.Locale('en-u-co-gregory', {collation}).toString(),
+ expected,
+ `new Intl.Locale('en-u-co-gregory', {collation: "${collation}"}).toString() returns "${expected}"`
+ );
+}
+
+reportCompare(0, 0);