90 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			3.4 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 { renderHook } from "@testing-library/react-hooks";
 | |
| import { waitFor } from "@testing-library/react";
 | |
| 
 | |
| import { useUserOnboardingTasks } from "../../src/hooks/useUserOnboardingTasks";
 | |
| import { useUserOnboardingContext } from "../../src/hooks/useUserOnboardingContext";
 | |
| import { stubClient } from "../test-utils";
 | |
| import MatrixClientContext from "../../src/contexts/MatrixClientContext";
 | |
| import DMRoomMap from "../../src/utils/DMRoomMap";
 | |
| import PlatformPeg from "../../src/PlatformPeg";
 | |
| 
 | |
| describe("useUserOnboardingTasks", () => {
 | |
|     it.each([
 | |
|         {
 | |
|             context: {
 | |
|                 hasAvatar: false,
 | |
|                 hasDevices: false,
 | |
|                 hasDmRooms: false,
 | |
|                 showNotificationsPrompt: false,
 | |
|             },
 | |
|         },
 | |
|         {
 | |
|             context: {
 | |
|                 hasAvatar: true,
 | |
|                 hasDevices: false,
 | |
|                 hasDmRooms: false,
 | |
|                 showNotificationsPrompt: true,
 | |
|             },
 | |
|         },
 | |
|     ])("sequence should stay static", async ({ context }) => {
 | |
|         const { result } = renderHook(() => useUserOnboardingTasks(context));
 | |
| 
 | |
|         expect(result.current).toHaveLength(5);
 | |
|         expect(result.current[0].id).toBe("create-account");
 | |
|         expect(result.current[1].id).toBe("find-friends");
 | |
|         expect(result.current[2].id).toBe("download-apps");
 | |
|         expect(result.current[3].id).toBe("setup-profile");
 | |
|         expect(result.current[4].id).toBe("permission-notifications");
 | |
|     });
 | |
| 
 | |
|     it("should mark desktop notifications task completed on click", async () => {
 | |
|         jest.spyOn(PlatformPeg, "get").mockReturnValue({
 | |
|             supportsNotifications: jest.fn().mockReturnValue(true),
 | |
|             maySendNotifications: jest.fn().mockReturnValue(false),
 | |
|         } as any);
 | |
| 
 | |
|         const cli = stubClient();
 | |
|         cli.pushRules = {
 | |
|             global: {
 | |
|                 override: [
 | |
|                     {
 | |
|                         rule_id: ".m.rule.master",
 | |
|                         enabled: false,
 | |
|                         actions: [],
 | |
|                         default: true,
 | |
|                     },
 | |
|                 ],
 | |
|             },
 | |
|         };
 | |
|         DMRoomMap.makeShared(cli);
 | |
|         const context = renderHook(() => useUserOnboardingContext(), {
 | |
|             wrapper: (props) => {
 | |
|                 return <MatrixClientContext.Provider value={cli}>{props.children}</MatrixClientContext.Provider>;
 | |
|             },
 | |
|         });
 | |
|         const { result, rerender } = renderHook(() => useUserOnboardingTasks(context.result.current));
 | |
|         expect(result.current[4].id).toBe("permission-notifications");
 | |
|         await waitFor(() => expect(result.current[4].completed).toBe(false));
 | |
|         result.current[4].action!.onClick!({ type: "click" } as any);
 | |
|         rerender();
 | |
|         await waitFor(() => expect(result.current[4].completed).toBe(true));
 | |
|     });
 | |
| });
 |