130 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
| /*
 | |
| Copyright 2021 The Matrix.org Foundation C.I.C.
 | |
| 
 | |
| Licensed under the Apache License, Version 2.0 (the "License");
 | |
| you may not use this file except in compliance with the License.
 | |
| You may obtain a copy of the License at
 | |
| 
 | |
|     http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
| Unless required by applicable law or agreed to in writing, software
 | |
| distributed under the License is distributed on an "AS IS" BASIS,
 | |
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| See the License for the specific language governing permissions and
 | |
| limitations under the License.
 | |
| */
 | |
| 
 | |
| import React from "react";
 | |
| import { mocked } from "jest-mock";
 | |
| import { render } from "@testing-library/react";
 | |
| 
 | |
| import { formatFullDateNoTime } from "../../../../src/DateUtils";
 | |
| import SettingsStore from "../../../../src/settings/SettingsStore";
 | |
| import { UIFeature } from "../../../../src/settings/UIFeature";
 | |
| import MatrixClientContext from "../../../../src/contexts/MatrixClientContext";
 | |
| import { getMockClientWithEventEmitter } from "../../../test-utils";
 | |
| import DateSeparator from "../../../../src/components/views/messages/DateSeparator";
 | |
| 
 | |
| jest.mock("../../../../src/settings/SettingsStore");
 | |
| 
 | |
| describe("DateSeparator", () => {
 | |
|     const HOUR_MS = 3600000;
 | |
|     const DAY_MS = HOUR_MS * 24;
 | |
|     // Friday Dec 17 2021, 9:09am
 | |
|     const now = "2021-12-17T08:09:00.000Z";
 | |
|     const nowMs = 1639728540000;
 | |
|     const defaultProps = {
 | |
|         ts: nowMs,
 | |
|         now,
 | |
|         roomId: "!unused:example.org",
 | |
|     };
 | |
|     const RealDate = global.Date;
 | |
|     class MockDate extends Date {
 | |
|         constructor(date: string | number | Date) {
 | |
|             super(date || now);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     const mockClient = getMockClientWithEventEmitter({});
 | |
|     const getComponent = (props = {}) =>
 | |
|         render(
 | |
|             <MatrixClientContext.Provider value={mockClient}>
 | |
|                 <DateSeparator {...defaultProps} {...props} />
 | |
|             </MatrixClientContext.Provider>,
 | |
|         );
 | |
| 
 | |
|     type TestCase = [string, number, string];
 | |
|     const testCases: TestCase[] = [
 | |
|         ["the exact same moment", nowMs, "Today"],
 | |
|         ["same day as current day", nowMs - HOUR_MS, "Today"],
 | |
|         ["day before the current day", nowMs - HOUR_MS * 12, "Yesterday"],
 | |
|         ["2 days ago", nowMs - DAY_MS * 2, "Wednesday"],
 | |
|         ["144 hours ago", nowMs - HOUR_MS * 144, "Sat, Dec 11 2021"],
 | |
|         [
 | |
|             "6 days ago, but less than 144h",
 | |
|             new Date("Saturday Dec 11 2021 23:59:00 GMT+0100 (Central European Standard Time)").getTime(),
 | |
|             "Saturday",
 | |
|         ],
 | |
|     ];
 | |
| 
 | |
|     beforeEach(() => {
 | |
|         global.Date = MockDate as unknown as DateConstructor;
 | |
|         (SettingsStore.getValue as jest.Mock) = jest.fn((arg) => {
 | |
|             if (arg === UIFeature.TimelineEnableRelativeDates) {
 | |
|                 return true;
 | |
|             }
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     afterAll(() => {
 | |
|         global.Date = RealDate;
 | |
|     });
 | |
| 
 | |
|     it("renders the date separator correctly", () => {
 | |
|         const { asFragment } = getComponent();
 | |
|         expect(asFragment()).toMatchSnapshot();
 | |
|         expect(SettingsStore.getValue).toHaveBeenCalledWith(UIFeature.TimelineEnableRelativeDates);
 | |
|     });
 | |
| 
 | |
|     it.each(testCases)("formats date correctly when current time is %s", (_d, ts, result) => {
 | |
|         expect(getComponent({ ts, forExport: false }).container.textContent).toEqual(result);
 | |
|     });
 | |
| 
 | |
|     describe("when forExport is true", () => {
 | |
|         it.each(testCases)("formats date in full when current time is %s", (_d, ts) => {
 | |
|             expect(getComponent({ ts, forExport: true }).container.textContent).toEqual(
 | |
|                 formatFullDateNoTime(new Date(ts)),
 | |
|             );
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when Settings.TimelineEnableRelativeDates is falsy", () => {
 | |
|         beforeEach(() => {
 | |
|             (SettingsStore.getValue as jest.Mock) = jest.fn((arg) => {
 | |
|                 if (arg === UIFeature.TimelineEnableRelativeDates) {
 | |
|                     return false;
 | |
|                 }
 | |
|             });
 | |
|         });
 | |
|         it.each(testCases)("formats date in full when current time is %s", (_d, ts) => {
 | |
|             expect(getComponent({ ts, forExport: false }).container.textContent).toEqual(
 | |
|                 formatFullDateNoTime(new Date(ts)),
 | |
|             );
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when feature_jump_to_date is enabled", () => {
 | |
|         beforeEach(() => {
 | |
|             mocked(SettingsStore).getValue.mockImplementation((arg): any => {
 | |
|                 if (arg === "feature_jump_to_date") {
 | |
|                     return true;
 | |
|                 }
 | |
|             });
 | |
|         });
 | |
|         it("renders the date separator correctly", () => {
 | |
|             const { asFragment } = getComponent();
 | |
|             expect(asFragment()).toMatchSnapshot();
 | |
|         });
 | |
|     });
 | |
| });
 |