DurationFormat: added tests for default styles for units following numeric-styled units (#4032)

This commit is contained in:
Ben Allen 2024-04-03 09:09:00 -07:00 committed by GitHub
parent 63933d1da5
commit e0a0c27796
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 31 additions and 0 deletions

View File

@ -0,0 +1,31 @@
// 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`);
}