mirror of
https://github.com/TriliumNext/Notes.git
synced 2025-07-27 18:12:29 +08:00
134 lines
4.3 KiB
TypeScript
134 lines
4.3 KiB
TypeScript
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, context }) => {
|
|
const app = new App(page, context);
|
|
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, context }) => {
|
|
const app = new App(page, context);
|
|
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 {
|
|
test.fail(true, "Unable to determine tab position");
|
|
}
|
|
|
|
// Wait for the popup to show
|
|
const popup = await popupPromise;
|
|
const popupApp = new App(popup, context);
|
|
await expect(popupApp.getActiveTab()).toHaveText(NOTE_TITLE);
|
|
});
|
|
|
|
test("Tabs are restored in right order", async ({ page, context }) => {
|
|
const app = new App(page, context);
|
|
await app.goto();
|
|
|
|
// Open three tabs.
|
|
await app.closeAllTabs();
|
|
await app.goToNoteInNewTab("Code notes");
|
|
await app.addNewTab();
|
|
await app.goToNoteInNewTab("Text notes");
|
|
await app.addNewTab();
|
|
await app.goToNoteInNewTab("Mermaid");
|
|
|
|
// Select the mid one.
|
|
await app.getTab(1).click();
|
|
|
|
// Refresh the page and check the order.
|
|
await app.goto( { preserveTabs: true });
|
|
await expect(app.getTab(0)).toContainText("Code notes");
|
|
await expect(app.getTab(1)).toContainText("Text notes");
|
|
await expect(app.getTab(2)).toContainText("Mermaid");
|
|
|
|
// Check the note tree has the right active node.
|
|
await expect(app.noteTreeActiveNote).toContainText("Text notes");
|
|
});
|
|
|
|
test("Empty tabs are cleared out", async ({ page, context }) => {
|
|
const app = new App(page, context);
|
|
await app.goto();
|
|
|
|
// Open three tabs.
|
|
await app.closeAllTabs();
|
|
await app.addNewTab();
|
|
await app.goToNoteInNewTab("Code notes");
|
|
await app.addNewTab();
|
|
await app.addNewTab();
|
|
|
|
// Refresh the page and check the order.
|
|
await app.goto({ preserveTabs: true });
|
|
|
|
// Expect no empty tabs.
|
|
expect(await app.tabBar.locator(".note-tab-wrapper").count()).toBe(1);
|
|
});
|
|
|
|
test("Search works when dismissing a tab", async ({ page, context }) => {
|
|
const app = new App(page, context);
|
|
await app.goto();
|
|
|
|
await app.goToNoteInNewTab("Table of contents");
|
|
await app.openAndClickNoteActionMenu("Search in note");
|
|
await expect(app.findAndReplaceWidget).toBeVisible();
|
|
app.findAndReplaceWidget.locator(".find-widget-close-button").click();
|
|
|
|
await app.addNewTab();
|
|
await app.goToNoteInNewTab("Sample mindmap");
|
|
|
|
await app.getTab(0).click();
|
|
await app.openAndClickNoteActionMenu("Search in note");
|
|
await expect(app.findAndReplaceWidget).toBeVisible();
|
|
});
|
|
|
|
test("New tab displays workspaces", async ({ page, context }) => {
|
|
const app = new App(page, context);
|
|
await app.goto();
|
|
|
|
const workspaceNotesEl = app.currentNoteSplitContent.locator(".workspace-notes");
|
|
await expect(workspaceNotesEl).toBeVisible();
|
|
expect(workspaceNotesEl).toContainText("Personal");
|
|
expect(workspaceNotesEl).toContainText("Work");
|
|
await expect(workspaceNotesEl.locator(".bx.bxs-user")).toBeVisible();
|
|
await expect(workspaceNotesEl.locator(".bx.bx-briefcase-alt")).toBeVisible();
|
|
|
|
await app.closeAllTabs();
|
|
});
|