123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- describe("correct behavior", () => {
- test("length is 1", () => {
- expect(Temporal.Now.plainDateTime).toHaveLength(1);
- });
- test("basic functionality", () => {
- const calendar = new Temporal.Calendar("iso8601");
- const plainDateTime = Temporal.Now.plainDateTime(calendar);
- expect(plainDateTime).toBeInstanceOf(Temporal.PlainDateTime);
- expect(plainDateTime.calendar).toBe(calendar);
- });
- const plainDateTimeToEpochSeconds = plainDateTime =>
- (plainDateTime.year - 1970) * 31_556_952 +
- plainDateTime.dayOfYear * 86_400 +
- plainDateTime.hour * 3_600 +
- plainDateTime.minute * 60 +
- plainDateTime.second +
- plainDateTime.millisecond / 1_000 +
- plainDateTime.microsecond / 1_000_000 +
- plainDateTime.nanosecond / 1_000_000_000;
- let timeZoneTested = false;
- // Note: We test both positive and negative timezones because one might cross a year boundary.
- // Since a year does not have a fixed amount of seconds because it can be a leap year,
- // we cannot have a correct constant for seconds per year which is always correct.
- // However, by assuming years are at least 2 days long we can simply try the positive
- // and negative timezones and skip one if we jump the year. To ensure at least one is
- // tested we have the timeZoneTested which is only set to true if one of the tests passed.
- // FIXME: The custom time zone tests are disabled due to being flaky. See:
- // https://github.com/SerenityOS/serenity/issues/20806
- test.skip("custom time zone positive", () => {
- const calendar = new Temporal.Calendar("iso8601");
- const timeZone = {
- getOffsetNanosecondsFor() {
- return 86399999999999;
- },
- };
- const [plainDateTime, plainDateTimeWithOffset] = withinSameSecond(() => {
- return [
- Temporal.Now.plainDateTime(calendar, "UTC"),
- Temporal.Now.plainDateTime(calendar, timeZone),
- ];
- });
- if (plainDateTime.year !== plainDateTimeWithOffset.year) return;
- const differenceSeconds =
- plainDateTimeToEpochSeconds(plainDateTimeWithOffset) -
- plainDateTimeToEpochSeconds(plainDateTime);
- expect(Math.floor(differenceSeconds)).toBe(86400);
- timeZoneTested = true;
- });
- test.skip("custom time zone negative", () => {
- const calendar = new Temporal.Calendar("iso8601");
- const timeZone = {
- getOffsetNanosecondsFor() {
- return -86399999999999;
- },
- };
- const [plainDateTime, plainDateTimeWithOffset] = withinSameSecond(() => {
- return [
- Temporal.Now.plainDateTime(calendar, "UTC"),
- Temporal.Now.plainDateTime(calendar, timeZone),
- ];
- });
- if (plainDateTime.year !== plainDateTimeWithOffset.year) return;
- const differenceSeconds =
- plainDateTimeToEpochSeconds(plainDateTimeWithOffset) -
- plainDateTimeToEpochSeconds(plainDateTime);
- expect(Math.floor(differenceSeconds)).toBe(-86400);
- timeZoneTested = true;
- });
- test.skip("custom time zone test was executed", () => {
- expect(timeZoneTested).toBeTrue();
- });
- test("cannot have a time zone with more than a day", () => {
- [86400000000000, -86400000000000, 86400000000001, 86400000000002].forEach(offset => {
- const calendar = new Temporal.Calendar("iso8601");
- const timeZone = {
- getOffsetNanosecondsFor() {
- return offset;
- },
- };
- expect(() => Temporal.Now.plainDateTime(calendar, timeZone)).toThrowWithMessage(
- RangeError,
- "Invalid offset nanoseconds value, must be in range -86400 * 10^9 + 1 to 86400 * 10^9 - 1"
- );
- });
- });
- });
- describe("errors", () => {
- test("custom time zone doesn't have a getOffsetNanosecondsFor function", () => {
- expect(() => {
- Temporal.Now.plainDateTime({}, {});
- }).toThrowWithMessage(TypeError, "getOffsetNanosecondsFor is undefined");
- });
- });
|