summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/intl402/Locale/constructor-options-region-valid.js
blob: f57fec222610f893762098c6f66d7db042de5409 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Copyright 2018 André Bargull; 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 error cases for the options argument to the Locale
    constructor.
info: |
    Intl.Locale( tag [, options] )
    10. If options is undefined, then
    11. Else
        a. Let options be ? ToObject(options).
    12. Set tag to ? ApplyOptionsToTag(tag, options).

    ApplyOptionsToTag( tag, options )
    ...
    7. Let region be ? GetOption(options, "region", "string", undefined, undefined).
    ...
    9. If tag matches neither the privateuse nor the grandfathered production, then
      ...
      d. If region is not undefined, then
        i. If tag does not contain a region production, then
          1. Set tag to the concatenation of the language production of tag, the substring corresponding to the "-" script production if present, "-", region, and the rest of tag.
        ii. Else,
          1. Set tag to tag with the substring corresponding to the region production replaced by the string region.

features: [Intl.Locale]
---*/

const validRegionOptions = [
  [undefined, undefined],
  ['FR', 'en-FR'],
  ['554', 'en-NZ'],
  [554, 'en-NZ'],
];
for (const [region, expected] of validRegionOptions) {
  let options = { region };
  let expect = expected || 'en';

  assert.sameValue(
    new Intl.Locale('en', options).toString(),
    expect,
    `new Intl.Locale('en', {region: "${region}"}).toString() returns "${expect}"`
  );

  expect = expected || 'en-US';
  assert.sameValue(
    new Intl.Locale('en-US', options).toString(),
    expect,
    `new Intl.Locale('en-US', {region: "${region}"}).toString() returns "${expect}"`
  );

  expect = (expected || 'en') + '-u-ca-gregory';
  assert.sameValue(
    new Intl.Locale('en-u-ca-gregory', options).toString(),
    expect,
    `new Intl.Locale('en-u-ca-gregory', {region: "${region}"}).toString() returns "${expect}"`
  );

  expect = (expected || 'en-US') + '-u-ca-gregory';
  assert.sameValue(
    new Intl.Locale('en-US-u-ca-gregory', options).toString(),
    expect,
    `new Intl.Locale('en-US-u-ca-gregory', {region: "${region}"}).toString() returns "${expect}"`
  );
}

reportCompare(0, 0);