mirror of
				https://github.com/TriliumNext/Notes.git
				synced 2025-10-31 21:11:30 +08:00 
			
		
		
		
	Merge branch 'develop' into renovate/draggabilly-3.x
This commit is contained in:
		
						commit
						67bfd1dde6
					
				
							
								
								
									
										6
									
								
								.github/workflows/playwright.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/playwright.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,9 +1,9 @@ | ||||
| name: Playwright Tests | ||||
| on: | ||||
|   push: | ||||
|     branches: [ main, master ] | ||||
|     branches: [ develop ] | ||||
|   pull_request: | ||||
|     branches: [ main, master ] | ||||
|     branches: [ develop ] | ||||
| jobs: | ||||
|   test: | ||||
|     timeout-minutes: 60 | ||||
| @ -20,7 +20,7 @@ jobs: | ||||
|     - name: Run Playwright tests | ||||
|       run: npx playwright test | ||||
|     - uses: actions/upload-artifact@v4 | ||||
|       if: always() | ||||
|       if: ${{ !cancelled() }} | ||||
|       with: | ||||
|         name: playwright-report | ||||
|         path: playwright-report/ | ||||
|  | ||||
							
								
								
									
										59
									
								
								e2e/layout/tab_bar.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								e2e/layout/tab_bar.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,59 @@ | ||||
| import { test, expect } from "@playwright/test"; | ||||
| import App from "../support/app"; | ||||
| 
 | ||||
| const NOTE_TITLE = "Trilium Integration Test DB"; | ||||
| 
 | ||||
| test("Can drag tabs around", async ({ page }) => { | ||||
|     const app = new App(page); | ||||
|     await app.goto(); | ||||
| 
 | ||||
|     // [1]: Trilium Integration Test DB note
 | ||||
|     await app.closeAllTabs(); | ||||
|     await app.clickNoteOnNoteTreeByTitle(NOTE_TITLE); | ||||
|     await expect(app.getActiveTab()).toContainText(NOTE_TITLE); | ||||
| 
 | ||||
|     // [1] [2] [3]
 | ||||
|     await app.addNewTab(); | ||||
|     await app.addNewTab(); | ||||
| 
 | ||||
|     let tab = app.getTab(0); | ||||
| 
 | ||||
|     // Drag the first tab at the end
 | ||||
|     await tab.dragTo(app.getTab(2), { targetPosition: { x: 50, y: 0 }}); | ||||
| 
 | ||||
|     tab = app.getTab(2); | ||||
|     await expect(tab).toContainText(NOTE_TITLE); | ||||
| 
 | ||||
|     // Drag the tab to the left
 | ||||
|     await tab.dragTo(app.getTab(0), { targetPosition: { x: 50, y: 0 }}); | ||||
|     await expect(app.getTab(0)).toContainText(NOTE_TITLE); | ||||
| }); | ||||
| 
 | ||||
| test("Can drag tab to new window", async ({ page }) => { | ||||
|     const app = new App(page); | ||||
|     await app.goto(); | ||||
| 
 | ||||
|     await app.closeAllTabs(); | ||||
|     await app.clickNoteOnNoteTreeByTitle(NOTE_TITLE); | ||||
|     const tab = app.getTab(0); | ||||
|     await expect(tab).toContainText(NOTE_TITLE); | ||||
| 
 | ||||
|     const popupPromise = page.waitForEvent("popup"); | ||||
| 
 | ||||
|     const tabPos = await tab.boundingBox(); | ||||
|     if (tabPos) { | ||||
|         const x = tabPos.x + tabPos.width / 2; | ||||
|         const y = tabPos.y + tabPos.height / 2; | ||||
|         await page.mouse.move(x, y); | ||||
|         await page.mouse.down(); | ||||
|         await page.mouse.move(x, y + tabPos.height + 100, { steps: 5 }); | ||||
|         await page.mouse.up(); | ||||
|     } else { | ||||
|         fail("Unable to determine tab position"); | ||||
|     } | ||||
| 
 | ||||
|     // Wait for the popup to show
 | ||||
|     const popup = await popupPromise; | ||||
|     const popupApp = new App(popup); | ||||
|     await expect(popupApp.getActiveTab()).toHaveText(NOTE_TITLE); | ||||
| }); | ||||
							
								
								
									
										45
									
								
								e2e/support/app.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								e2e/support/app.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | ||||
| import { Locator, Page, expect } from "@playwright/test"; | ||||
| 
 | ||||
| export default class App { | ||||
|     readonly page: Page; | ||||
| 
 | ||||
|     readonly tabBar: Locator; | ||||
|     readonly noteTree: Locator; | ||||
| 
 | ||||
|     constructor(page: Page) { | ||||
|         this.page = page; | ||||
|         this.tabBar = page.locator(".tab-row-widget-container"); | ||||
|         this.noteTree = page.locator(".tree-wrapper"); | ||||
|     } | ||||
| 
 | ||||
|     async goto() { | ||||
|         await this.page.goto("/", { waitUntil: "networkidle" }); | ||||
| 
 | ||||
|         // Wait for the page to load.
 | ||||
|         await expect(this.page.locator(".tree")) | ||||
|             .toContainText("Trilium Integration Test"); | ||||
|     } | ||||
| 
 | ||||
|     getTab(tabIndex: number) { | ||||
|         return this.tabBar.locator(".note-tab-wrapper").nth(tabIndex); | ||||
|     } | ||||
| 
 | ||||
|     getActiveTab() { | ||||
|         return this.tabBar.locator(".note-tab[active]"); | ||||
|     } | ||||
| 
 | ||||
|     async closeAllTabs() { | ||||
|         await this.getTab(0).click({ button: "right" }); | ||||
|         await this.page.waitForTimeout(500); // TODO: context menu won't dismiss otherwise
 | ||||
|         await this.page.getByText("Close all tabs").click({ force: true }); | ||||
|     } | ||||
| 
 | ||||
|     async addNewTab() { | ||||
|         await this.page.locator('[data-trigger-command="openNewTab"]').click(); | ||||
|     } | ||||
| 
 | ||||
|     async clickNoteOnNoteTreeByTitle(title: string) { | ||||
|         this.noteTree.getByText(title).click(); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| @ -1,85 +1,79 @@ | ||||
| import { defineConfig, devices } from "@playwright/test"; | ||||
| import { defineConfig, devices } from '@playwright/test'; | ||||
| 
 | ||||
| /** | ||||
|  * Read environment variables from file. | ||||
|  * https://github.com/motdotla/dotenv
 | ||||
|  */ | ||||
| // import dotenv from 'dotenv';
 | ||||
| // import path from 'path';
 | ||||
| // dotenv.config({ path: path.resolve(__dirname, '.env') });
 | ||||
| 
 | ||||
| /** | ||||
|  * See https://playwright.dev/docs/test-configuration.
 | ||||
|  */ | ||||
| export default defineConfig({ | ||||
|     testDir: "./integration-tests", | ||||
|     /* Run tests in files in parallel */ | ||||
|     fullyParallel: true, | ||||
|     /* Fail the build on CI if you accidentally left test.only in the source code. */ | ||||
|     forbidOnly: !!process.env.CI, | ||||
|     /* Retry on CI only */ | ||||
|     retries: process.env.CI ? 2 : 0, | ||||
|     /* Opt out of parallel tests on CI. */ | ||||
|     workers: process.env.CI ? 1 : undefined, | ||||
|     /* Reporter to use. See https://playwright.dev/docs/test-reporters */ | ||||
|     reporter: "html", | ||||
|     /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */ | ||||
|     use: { | ||||
|         /* Base URL to use in actions like `await page.goto('/')`. */ | ||||
|         // baseURL: 'http://127.0.0.1:3000',
 | ||||
|   testDir: './e2e', | ||||
|   /* Run tests in files in parallel */ | ||||
|   fullyParallel: true, | ||||
|   /* Fail the build on CI if you accidentally left test.only in the source code. */ | ||||
|   forbidOnly: !!process.env.CI, | ||||
|   /* Retry on CI only */ | ||||
|   retries: process.env.CI ? 2 : 0, | ||||
|   /* Opt out of parallel tests on CI. */ | ||||
|   workers: process.env.CI ? 1 : undefined, | ||||
|   /* Reporter to use. See https://playwright.dev/docs/test-reporters */ | ||||
|   reporter: 'html', | ||||
|   /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */ | ||||
|   use: { | ||||
|     /* Base URL to use in actions like `await page.goto('/')`. */ | ||||
|     baseURL: 'http://127.0.0.1:8082', | ||||
| 
 | ||||
|         /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */ | ||||
|         trace: "on-first-retry" | ||||
|     /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */ | ||||
|     trace: 'on-first-retry', | ||||
|   }, | ||||
| 
 | ||||
|   /* Configure projects for major browsers */ | ||||
|   projects: [ | ||||
|     { | ||||
|       name: 'chromium', | ||||
|       use: { ...devices['Desktop Chrome'] }, | ||||
|     }, | ||||
| 
 | ||||
|     webServer: { | ||||
|         command: "npm run integration-mem-db", | ||||
|         url: "http://127.0.0.1:8082", | ||||
|         reuseExistingServer: true, | ||||
|         stdout: "ignore", | ||||
|         stderr: "pipe" | ||||
|     { | ||||
|       name: 'firefox', | ||||
|       use: { ...devices['Desktop Firefox'] }, | ||||
|     }, | ||||
| 
 | ||||
|     /* Configure projects for major browsers */ | ||||
|     projects: [ | ||||
|         { | ||||
|             name: "setup", | ||||
|             testMatch: /.*\.setup\.ts/ | ||||
|         }, | ||||
|     { | ||||
|       name: 'webkit', | ||||
|       use: { ...devices['Desktop Safari'] }, | ||||
|     }, | ||||
| 
 | ||||
|         { | ||||
|             name: "firefox", | ||||
|             use: { | ||||
|                 ...devices["Desktop Firefox"], | ||||
|                 storageState: "playwright/.auth/user.json" | ||||
|             }, | ||||
|             dependencies: ["setup"] | ||||
|         } | ||||
| 
 | ||||
|         /* Test against mobile viewports. */ | ||||
|         // {
 | ||||
|         //   name: 'Mobile Chrome',
 | ||||
|         //   use: { ...devices['Pixel 5'] },
 | ||||
|         // },
 | ||||
|         // {
 | ||||
|         //   name: 'Mobile Safari',
 | ||||
|         //   use: { ...devices['iPhone 12'] },
 | ||||
|         // },
 | ||||
| 
 | ||||
|         /* Test against branded browsers. */ | ||||
|         // {
 | ||||
|         //   name: 'Microsoft Edge',
 | ||||
|         //   use: { ...devices['Desktop Edge'], channel: 'msedge' },
 | ||||
|         // },
 | ||||
|         // {
 | ||||
|         //   name: 'Google Chrome',
 | ||||
|         //   use: { ...devices['Desktop Chrome'], channel: 'chrome' },
 | ||||
|         // },
 | ||||
|     ] | ||||
| 
 | ||||
|     /* Run your local dev server before starting the tests */ | ||||
|     // webServer: {
 | ||||
|     //   command: 'npm run start',
 | ||||
|     //   url: 'http://127.0.0.1:3000',
 | ||||
|     //   reuseExistingServer: !process.env.CI,
 | ||||
|     /* Test against mobile viewports. */ | ||||
|     // {
 | ||||
|     //   name: 'Mobile Chrome',
 | ||||
|     //   use: { ...devices['Pixel 5'] },
 | ||||
|     // },
 | ||||
|     // {
 | ||||
|     //   name: 'Mobile Safari',
 | ||||
|     //   use: { ...devices['iPhone 12'] },
 | ||||
|     // },
 | ||||
| 
 | ||||
|     /* Test against branded browsers. */ | ||||
|     // {
 | ||||
|     //   name: 'Microsoft Edge',
 | ||||
|     //   use: { ...devices['Desktop Edge'], channel: 'msedge' },
 | ||||
|     // },
 | ||||
|     // {
 | ||||
|     //   name: 'Google Chrome',
 | ||||
|     //   use: { ...devices['Desktop Chrome'], channel: 'chrome' },
 | ||||
|     // },
 | ||||
|   ], | ||||
| 
 | ||||
|   /* Run your local dev server before starting the tests */ | ||||
|   // webServer: {
 | ||||
|   //   command: 'npm run start',
 | ||||
|   //   url: 'http://127.0.0.1:3000',
 | ||||
|   //   reuseExistingServer: !process.env.CI,
 | ||||
|   // },
 | ||||
| }); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Elian Doran
						Elian Doran