mirror of
				https://github.com/excalidraw/excalidraw.git
				synced 2025-10-25 08:54:20 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { UI } from "@excalidraw/excalidraw/tests/helpers/ui";
 | |
| import {
 | |
|   mockBoundingClientRect,
 | |
|   render,
 | |
|   restoreOriginalGetBoundingClientRect,
 | |
| } from "@excalidraw/excalidraw/tests/test-utils";
 | |
| 
 | |
| import ExcalidrawApp from "../App";
 | |
| 
 | |
| describe("Test MobileMenu", () => {
 | |
|   const { h } = window;
 | |
|   const dimensions = { height: 400, width: 800 };
 | |
| 
 | |
|   beforeAll(() => {
 | |
|     mockBoundingClientRect(dimensions);
 | |
|   });
 | |
| 
 | |
|   beforeEach(async () => {
 | |
|     await render(<ExcalidrawApp />);
 | |
|     // @ts-ignore
 | |
|     h.app.refreshViewportBreakpoints();
 | |
|     // @ts-ignore
 | |
|     h.app.refreshEditorBreakpoints();
 | |
|   });
 | |
| 
 | |
|   afterAll(() => {
 | |
|     restoreOriginalGetBoundingClientRect();
 | |
|   });
 | |
| 
 | |
|   it("should set device correctly", () => {
 | |
|     expect(h.app.device).toMatchInlineSnapshot(`
 | |
|       {
 | |
|         "editor": {
 | |
|           "canFitSidebar": false,
 | |
|           "isMobile": true,
 | |
|         },
 | |
|         "isTouchScreen": false,
 | |
|         "viewport": {
 | |
|           "isLandscape": false,
 | |
|           "isMobile": true,
 | |
|         },
 | |
|       }
 | |
|     `);
 | |
|   });
 | |
| 
 | |
|   it("should initialize with welcome screen and hide once user interacts", async () => {
 | |
|     expect(document.querySelector(".welcome-screen-center")).toMatchSnapshot();
 | |
|     UI.clickTool("rectangle");
 | |
|     expect(document.querySelector(".welcome-screen-center")).toBeNull();
 | |
|   });
 | |
| });
 | 
