128 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			128 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) {
 | 
						|
            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();
 | 
						|
        });
 | 
						|
    });
 | 
						|
});
 |