| 
									
										
										
										
											2024-04-29 14:32:14 +08:00
										 |  |  | // ***********************************************************
 | 
					
						
							|  |  |  | // This example support/component.ts is processed and
 | 
					
						
							|  |  |  | // loaded automatically before your test files.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This is a great place to put global configuration and
 | 
					
						
							|  |  |  | // behavior that modifies Cypress.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // You can change the location of this file or turn off
 | 
					
						
							|  |  |  | // automatically serving support files with the
 | 
					
						
							|  |  |  | // 'supportFile' configuration option.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // You can read more here:
 | 
					
						
							|  |  |  | // https://on.cypress.io/configuration
 | 
					
						
							|  |  |  | // ***********************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Import commands.js using ES2015 syntax:
 | 
					
						
							| 
									
										
										
										
											2024-06-03 11:20:45 +08:00
										 |  |  | import '@cypress/code-coverage/support'; | 
					
						
							| 
									
										
										
										
											2024-04-29 14:32:14 +08:00
										 |  |  | import './commands'; | 
					
						
							|  |  |  | import './document'; | 
					
						
							|  |  |  | // Alternatively you can use CommonJS syntax:
 | 
					
						
							|  |  |  | // require('./commands')
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { mount } from 'cypress/react18'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Augment the Cypress namespace to include type definitions for
 | 
					
						
							|  |  |  | // your custom command.
 | 
					
						
							|  |  |  | // Alternatively, can be defined in cypress/support/component.d.ts
 | 
					
						
							|  |  |  | // with a <reference path="./component" /> at the top of your spec.
 | 
					
						
							|  |  |  | declare global { | 
					
						
							|  |  |  |   // eslint-disable-next-line @typescript-eslint/no-namespace
 | 
					
						
							|  |  |  |   namespace Cypress { | 
					
						
							|  |  |  |     interface Chainable { | 
					
						
							|  |  |  |       mount: typeof mount; | 
					
						
							|  |  |  |       mockAPI: () => void; | 
					
						
							| 
									
										
										
										
											2024-06-03 11:20:45 +08:00
										 |  |  |       mockDatabase: () => void; | 
					
						
							|  |  |  |       mockCurrentWorkspace: () => void; | 
					
						
							|  |  |  |       mockGetWorkspaceDatabases: () => void; | 
					
						
							|  |  |  |       mockDocument: (id: string) => void; | 
					
						
							| 
									
										
										
										
											2024-06-06 19:47:14 +08:00
										 |  |  |       clickOutside: () => void; | 
					
						
							|  |  |  |       getTestingSelector: (testId: string) => Chainable<JQuery<HTMLElement>>; | 
					
						
							| 
									
										
										
										
											2024-04-29 14:32:14 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Cypress.Commands.add('mount', mount); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-06 19:47:14 +08:00
										 |  |  | Cypress.Commands.add('getTestingSelector', (testId: string) => { | 
					
						
							|  |  |  |   return cy.get(`[data-testid="${testId}"]`); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Cypress.Commands.add('clickOutside', () => { | 
					
						
							|  |  |  |   cy.document().then((doc) => { | 
					
						
							|  |  |  |     // [0, 0] is the top left corner of the window
 | 
					
						
							|  |  |  |     const x = 0; | 
					
						
							|  |  |  |     const y = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const evt = new MouseEvent('click', { | 
					
						
							|  |  |  |       bubbles: true, | 
					
						
							|  |  |  |       cancelable: true, | 
					
						
							|  |  |  |       view: window, | 
					
						
							|  |  |  |       clientX: x, | 
					
						
							|  |  |  |       clientY: y, | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Dispatch the event
 | 
					
						
							|  |  |  |     doc.elementFromPoint(x, y)?.dispatchEvent(evt); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2024-04-29 14:32:14 +08:00
										 |  |  | // Example use:
 | 
					
						
							|  |  |  | // cy.mount(<MyComponent />)
 | 
					
						
							| 
									
										
										
										
											2024-06-03 11:20:45 +08:00
										 |  |  | 
 |