89 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
/*
 | 
						|
Copyright 2022 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 { screen, render } from "@testing-library/react";
 | 
						|
 | 
						|
import {
 | 
						|
    getUserOnboardingCounters,
 | 
						|
    UserOnboardingList,
 | 
						|
} from "../../../../src/components/views/user-onboarding/UserOnboardingList";
 | 
						|
import SdkConfig from "../../../../src/SdkConfig";
 | 
						|
 | 
						|
const tasks = [
 | 
						|
    {
 | 
						|
        id: "1",
 | 
						|
        title: "Lorem ipsum",
 | 
						|
        description: "Lorem ipsum dolor amet.",
 | 
						|
        completed: true,
 | 
						|
    },
 | 
						|
    {
 | 
						|
        id: "2",
 | 
						|
        title: "Lorem ipsum",
 | 
						|
        description: "Lorem ipsum dolor amet.",
 | 
						|
        completed: false,
 | 
						|
    },
 | 
						|
];
 | 
						|
 | 
						|
describe("getUserOnboardingCounters()", () => {
 | 
						|
    it.each([
 | 
						|
        {
 | 
						|
            tasks: [],
 | 
						|
            expectation: {
 | 
						|
                completed: 0,
 | 
						|
                waiting: 0,
 | 
						|
                total: 0,
 | 
						|
            },
 | 
						|
        },
 | 
						|
        {
 | 
						|
            tasks: tasks,
 | 
						|
            expectation: {
 | 
						|
                completed: 1,
 | 
						|
                waiting: 1,
 | 
						|
                total: 2,
 | 
						|
            },
 | 
						|
        },
 | 
						|
    ])("should calculate counters correctly", ({ tasks, expectation }) => {
 | 
						|
        const result = getUserOnboardingCounters(tasks);
 | 
						|
        expect(result).toStrictEqual(expectation);
 | 
						|
    });
 | 
						|
});
 | 
						|
 | 
						|
describe("UserOnboardingList", () => {
 | 
						|
    // This configuration affects rendering of the feedback and needs to be set.
 | 
						|
    beforeAll(() => {
 | 
						|
        SdkConfig.put({
 | 
						|
            bug_report_endpoint_url: "https://bug_report_endpoint_url.com",
 | 
						|
        });
 | 
						|
    });
 | 
						|
 | 
						|
    it("should not display feedback when there are waiting tasks", async () => {
 | 
						|
        render(<UserOnboardingList tasks={tasks} />);
 | 
						|
 | 
						|
        expect(await screen.findByText("Only 1 step to go")).toBeVisible();
 | 
						|
        expect(await screen.queryByTestId("user-onboarding-feedback")).toBeNull();
 | 
						|
        expect(await screen.findAllByTestId("user-onboarding-task")).toHaveLength(2);
 | 
						|
    });
 | 
						|
 | 
						|
    it("should display feedback when all tasks are completed", async () => {
 | 
						|
        render(<UserOnboardingList tasks={tasks.map((task) => ({ ...task, completed: true }))} />);
 | 
						|
 | 
						|
        expect(await screen.findByText("You did it!")).toBeVisible();
 | 
						|
        expect(await screen.findByTestId("user-onboarding-feedback")).toBeInTheDocument();
 | 
						|
        expect(await screen.queryAllByTestId("user-onboarding-task")).toHaveLength(2);
 | 
						|
    });
 | 
						|
});
 |