mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 15:42:44 +00:00 
			
		
		
		
	 f95117f75d
			
		
	
	
		f95117f75d
		
	
	
	
	
		
			
			Update to the latest version of the spec which was refactored to use time zone methods record. This requires updating a whole bunch of callers to pass through a record too. This also ends up improving exceptions on a missing getOffsetNanosecondsFor method.
		
			
				
	
	
		
			57 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| describe("correct behavior", () => {
 | |
|     test("length is 0", () => {
 | |
|         expect(Temporal.Now.plainDateISO).toHaveLength(0);
 | |
|     });
 | |
| 
 | |
|     test("basic functionality", () => {
 | |
|         const plainDate = Temporal.Now.plainDateISO();
 | |
|         expect(plainDate).toBeInstanceOf(Temporal.PlainDate);
 | |
|         expect(plainDate.calendar.id).toBe("iso8601");
 | |
|     });
 | |
| 
 | |
|     test("custom time zone", () => {
 | |
|         const timeZone = {
 | |
|             getOffsetNanosecondsFor() {
 | |
|                 return 86399999999999;
 | |
|             },
 | |
|         };
 | |
|         const plainDate = Temporal.Now.plainDateISO("UTC");
 | |
|         const plainDateWithOffset = Temporal.Now.plainDateISO(timeZone);
 | |
|         if (plainDate.dayOfYear === plainDate.daysInYear) {
 | |
|             expect(plainDateWithOffset.year).toBe(plainDate.year + 1);
 | |
|             expect(plainDateWithOffset.month).toBe(1);
 | |
|             expect(plainDateWithOffset.day).toBe(1);
 | |
|         } else {
 | |
|             expect(plainDateWithOffset.year).toBe(plainDate.year);
 | |
|             if (plainDate.day === plainDate.daysInMonth) {
 | |
|                 expect(plainDateWithOffset.month).toBe(plainDate.month + 1);
 | |
|                 expect(plainDateWithOffset.day).toBe(1);
 | |
|             } else {
 | |
|                 expect(plainDateWithOffset.month).toBe(plainDate.month);
 | |
|                 expect(plainDateWithOffset.day).toBe(plainDate.day + 1);
 | |
|             }
 | |
|         }
 | |
|     });
 | |
| 
 | |
|     test("cannot have a time zone with more than a day", () => {
 | |
|         [86400000000000, -86400000000000, 86400000000001, 86400000000002].forEach(offset => {
 | |
|             const timeZone = {
 | |
|                 getOffsetNanosecondsFor() {
 | |
|                     return offset;
 | |
|                 },
 | |
|             };
 | |
|             expect(() => Temporal.Now.plainDateISO(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.plainDateISO({});
 | |
|         }).toThrowWithMessage(TypeError, "getOffsetNanosecondsFor is undefined");
 | |
|     });
 | |
| });
 |