static-user-onboarding-steps (#9799)
This commit is contained in:
parent
ecb3e7a197
commit
1b06b72b67
9 changed files with 279 additions and 33 deletions
|
@ -0,0 +1,88 @@
|
|||
/*
|
||||
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);
|
||||
});
|
||||
});
|
|
@ -0,0 +1,102 @@
|
|||
/*
|
||||
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 { act, render, RenderResult } from "@testing-library/react";
|
||||
|
||||
import { filterConsole, stubClient } from "../../../test-utils";
|
||||
import { UserOnboardingPage } from "../../../../src/components/views/user-onboarding/UserOnboardingPage";
|
||||
import { MatrixClientPeg } from "../../../../src/MatrixClientPeg";
|
||||
import SdkConfig from "../../../../src/SdkConfig";
|
||||
|
||||
jest.mock("../../../../src/components/structures/EmbeddedPage", () => ({
|
||||
__esModule: true,
|
||||
default: jest.fn().mockImplementation(({ url }) => <div>{url}</div>),
|
||||
}));
|
||||
|
||||
jest.mock("../../../../src/components/structures/HomePage", () => ({
|
||||
__esModule: true,
|
||||
default: jest.fn().mockImplementation(() => <div>home page</div>),
|
||||
}));
|
||||
|
||||
describe("UserOnboardingPage", () => {
|
||||
let restoreConsole: () => void;
|
||||
|
||||
const renderComponent = async (): Promise<RenderResult> => {
|
||||
const renderResult = render(<UserOnboardingPage />);
|
||||
await act(async () => {
|
||||
jest.runAllTimers();
|
||||
});
|
||||
return renderResult;
|
||||
};
|
||||
|
||||
beforeAll(() => {
|
||||
restoreConsole = filterConsole(
|
||||
// unrelated for this test
|
||||
"could not update user onboarding context",
|
||||
);
|
||||
});
|
||||
|
||||
beforeEach(() => {
|
||||
stubClient();
|
||||
jest.useFakeTimers();
|
||||
});
|
||||
|
||||
afterEach(() => {
|
||||
jest.useRealTimers();
|
||||
jest.restoreAllMocks();
|
||||
});
|
||||
|
||||
afterAll(() => {
|
||||
restoreConsole();
|
||||
});
|
||||
|
||||
describe("when the user registered before the cutoff date", () => {
|
||||
beforeEach(() => {
|
||||
jest.spyOn(MatrixClientPeg, "userRegisteredAfter").mockReturnValue(false);
|
||||
});
|
||||
|
||||
it("should render the home page", async () => {
|
||||
expect((await renderComponent()).queryByText("home page")).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
|
||||
describe("when the user registered after the cutoff date", () => {
|
||||
beforeEach(() => {
|
||||
jest.spyOn(MatrixClientPeg, "userRegisteredAfter").mockReturnValue(true);
|
||||
});
|
||||
|
||||
describe("and there is an explicit home page configured", () => {
|
||||
beforeEach(() => {
|
||||
jest.spyOn(SdkConfig, "get").mockReturnValue({
|
||||
embedded_pages: {
|
||||
home_url: "https://example.com/home",
|
||||
},
|
||||
});
|
||||
});
|
||||
|
||||
it("should render the configured page", async () => {
|
||||
expect((await renderComponent()).queryByText("https://example.com/home")).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
|
||||
describe("and there is no home page configured", () => {
|
||||
it("should render the onboarding", async () => {
|
||||
expect((await renderComponent()).queryByTestId("user-onboarding-list")).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue