mirror of
https://github.com/tc39/test262.git
synced 2025-07-01 03:04:42 +02:00
* Add Tests for ECMA402 PR811 Add tests to check the order of option readings and output keys in resolvedOptions of Intl.NumberFormat and PluralRules. * Address reveiw feedback Hard code the list of property to be inspect for GetOption Use compareArray * Update test/intl402/NumberFormat/constructor-option-read-order.js Co-authored-by: Richard Gibson <richard.gibson@gmail.com> * Update test/intl402/NumberFormat/constructor-option-read-order.js Co-authored-by: Richard Gibson <richard.gibson@gmail.com> * Update test/intl402/NumberFormat/prototype/resolvedOptions/return-keys-order-default.js Co-authored-by: Richard Gibson <richard.gibson@gmail.com> * Update test/intl402/PluralRules/constructor-option-read-order.js Co-authored-by: Richard Gibson <richard.gibson@gmail.com> * Update test/intl402/PluralRules/constructor-option-read-order.js Co-authored-by: Richard Gibson <richard.gibson@gmail.com> * Fix intl402/PluralRules/prototype/resolvedOptions/return-keys-order-default.js To test all options * Add more tests --------- Co-authored-by: Richard Gibson <richard.gibson@gmail.com>
42 lines
1.2 KiB
JavaScript
42 lines
1.2 KiB
JavaScript
/// Copyright 2023 the V8 project authors. All rights reserved.
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
/*---
|
|
esid: sec-initializepluralrules
|
|
description: Checks the order of option read.
|
|
features: [Intl.NumberFormat-v3]
|
|
includes: [compareArray.js]
|
|
---*/
|
|
|
|
let optionKeys = [
|
|
// Inside InitializePluralRules
|
|
"localeMatcher",
|
|
"type",
|
|
// Inside SetNumberFormatDigitOptions
|
|
"minimumIntegerDigits",
|
|
"minimumFractionDigits",
|
|
"maximumFractionDigits",
|
|
"minimumSignificantDigits",
|
|
"maximumSignificantDigits",
|
|
"roundingIncrement",
|
|
"roundingMode",
|
|
"roundingPriority",
|
|
"trailingZeroDisplay",
|
|
// End of SetNumberFormatDigitOptions
|
|
];
|
|
|
|
// Use getters to track the order of reading known properties.
|
|
// TODO: Should we use a Proxy to detect *unexpected* property reads?
|
|
let reads = new Array();
|
|
let options = {};
|
|
optionKeys.forEach((key) => {
|
|
Object.defineProperty(options, key, {
|
|
get() {
|
|
reads.push(key);
|
|
return undefined;
|
|
},
|
|
});
|
|
});
|
|
new Intl.PluralRules(undefined, options);
|
|
assert.compareArray(reads, optionKeys, "Intl.PluralRules options read order");
|