mirror of https://github.com/TriliumNext/Notes
Merge branch 'develop' into renovate/draggabilly-3.x
commit
67bfd1dde6
@ -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);
|
||||||
|
});
|
||||||
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue