test262/test/intl402/NumberFormat/constructor-roundingIncrement-invalid.js
Frank Yung-Fong Tang 63f2c5b10f Remove 1.1 case which should NOT throw RangeError
roundingIncrement: 1.1 will not throw RangeError because
1.  roundingIncrement is read by calling GetNumberOption 
2. GetNumberOption https://tc39.es/ecma402/#sec-getnumberoption will call DefaultNumberOption https://tc39.es/ecma402/#sec-defaultnumberoption and 
3. DefaultNumberOption will call floor() in step 3.
2022-01-07 13:18:18 -05:00

40 lines
1.3 KiB
JavaScript

// Copyright 2021 the V8 project authors. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-initializenumberformat
description: Rejects invalid values for roundingIncrement option.
features: [Intl.NumberFormat-v3]
---*/
assert.throws(RangeError, function() {
new Intl.NumberFormat([], {roundingIncrement: 0});
}, '0');
assert.throws(RangeError, function() {
new Intl.NumberFormat([], {roundingIncrement: 3});
}, '3');
assert.throws(RangeError, function() {
new Intl.NumberFormat([], {roundingIncrement: 4});
}, '4');
assert.throws(RangeError, function() {
new Intl.NumberFormat([], {roundingIncrement: 5000.1});
}, '5000.1');
assert.throws(RangeError, function() {
new Intl.NumberFormat([], {roundingIncrement: 5001});
}, '5001');
assert.throws(RangeError, function() {
new Intl.NumberFormat([], {roundingIncrement: 2, roundingPriority: 'morePrecision'});
}, '2, roundingType is "morePrecision"');
assert.throws(RangeError, function() {
new Intl.NumberFormat([], {roundingIncrement: 2, roundingPriority: 'lessPrecision'});
}, '2, roundingType is "lessPrecision"');
assert.throws(RangeError, function() {
new Intl.NumberFormat([], {roundingIncrement: 2, minimumSignificantDigits: 1});
}, '2, roundingType is "significantDigits"');