test262/test/intl402/DurationFormat/constructor-unit-style-defa...

32 lines
1.6 KiB
JavaScript

// Copyright 2024 Igalia, S.L. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-Intl.DurationFormat
description: Verifies that default style settings for units following units with "numeric" or "2-digit" style are honored.
info: |
GetDurationUnitOptions (unit, options, baseStyle, stylesList, digitalBase, prevStyle)
(...)
3. If style is undefined, then
(...)
i. If prevStyle is "fractional", "numeric" or "2-digit", then
(...)
2. Set style to "numeric".
(...)
9. If prevStyle is "numeric" or "2-digit", then
(...)
b. If unit is "minutes" or "seconds", then
i. Set style to "2-digit".
features: [Intl.DurationFormat]
---*/
for (const numericLikeStyle of ["numeric", "2-digit"]){
var opts = new Intl.DurationFormat([], {hours: numericLikeStyle}).resolvedOptions();
assert.sameValue(opts.minutes, "2-digit", `minutes default value should be '2-digit' when following any ${numericLikeStyle}-styled unit`);
assert.sameValue(opts.seconds, "2-digit", `seconds default value should be '2-digit' when following any ${numericLikeStyle}-styled unit`);
assert.sameValue(opts.milliseconds, "numeric", `milliseconds default value should be 'numeric' when following any ${numericLikeStyle}-styled unit`);
assert.sameValue(opts.microseconds, "numeric", `microseconds default value should be 'numeric' when following any ${numericLikeStyle}-styled unit`);
assert.sameValue(opts.nanoseconds, "numeric", `nanoseconds default value should be 'numeric' when following any ${numericLikeStyle}-styled unit`);
}