mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-11 18:24:43 +02:00
147 lines
5.1 KiB
TypeScript
147 lines
5.1 KiB
TypeScript
import { test, expect } from './util/test';
|
|
import MainScreen from './models/MainScreen';
|
|
import activateMainMenuItem from './util/activateMainMenuItem';
|
|
import SettingsScreen from './models/SettingsScreen';
|
|
import { _electron as electron } from '@playwright/test';
|
|
import { writeFile } from 'fs-extra';
|
|
import { join } from 'path';
|
|
import createStartupArgs from './util/createStartupArgs';
|
|
import firstNonDevToolsWindow from './util/firstNonDevToolsWindow';
|
|
|
|
|
|
test.describe('main', () => {
|
|
test('app should launch', async ({ mainWindow }) => {
|
|
// A window should open with the correct title
|
|
expect(await mainWindow.title()).toMatch(/^Joplin/);
|
|
|
|
const mainPage = new MainScreen(mainWindow);
|
|
await mainPage.waitFor();
|
|
});
|
|
|
|
test('should be able to create and edit a new note', async ({ mainWindow }) => {
|
|
const mainScreen = new MainScreen(mainWindow);
|
|
await mainScreen.newNoteButton.click();
|
|
|
|
const editor = mainScreen.noteEditor;
|
|
await editor.waitFor();
|
|
|
|
// Wait for the title input to have the correct placeholder
|
|
await mainWindow.locator('input[placeholder^="Creating new note"]').waitFor();
|
|
|
|
// Fill the title
|
|
await editor.noteTitleInput.click();
|
|
await editor.noteTitleInput.fill('Test note');
|
|
|
|
// Note list should contain the new note
|
|
await expect(mainScreen.noteListContainer.getByText('Test note')).toBeVisible();
|
|
|
|
// Focus the editor
|
|
await editor.codeMirrorEditor.click();
|
|
|
|
// Type some text
|
|
await mainWindow.keyboard.type('# Test note!');
|
|
await mainWindow.keyboard.press('Enter');
|
|
await mainWindow.keyboard.press('Enter');
|
|
await mainWindow.keyboard.type('New note content!');
|
|
|
|
// Should render
|
|
const viewerFrame = editor.getNoteViewerIframe();
|
|
await expect(viewerFrame.locator('h1')).toHaveText('Test note!');
|
|
});
|
|
|
|
test('should be possible to remove sort order buttons in settings', async ({ electronApp, mainWindow }) => {
|
|
const mainScreen = new MainScreen(mainWindow);
|
|
await mainScreen.waitFor();
|
|
|
|
// Sort order buttons should be visible by default
|
|
await expect(mainScreen.noteListContainer.locator('[title^="Toggle sort order"]')).toBeVisible();
|
|
|
|
// Open settings (check both labels so that this works on MacOS)
|
|
expect(
|
|
await activateMainMenuItem(electronApp, 'Preferences...') || await activateMainMenuItem(electronApp, 'Options'),
|
|
).toBe(true);
|
|
|
|
// Should be on the settings screen
|
|
const settingsScreen = new SettingsScreen(mainWindow);
|
|
await settingsScreen.waitFor();
|
|
|
|
// Open the appearance tab
|
|
await settingsScreen.appearanceTabButton.click();
|
|
|
|
// Find the sort order visible checkbox
|
|
const sortOrderVisibleCheckbox = mainWindow.getByLabel(/^Show sort order/);
|
|
|
|
await expect(sortOrderVisibleCheckbox).toBeChecked();
|
|
await sortOrderVisibleCheckbox.click();
|
|
await expect(sortOrderVisibleCheckbox).not.toBeChecked();
|
|
|
|
// Save settings & close
|
|
await settingsScreen.okayButton.click();
|
|
await mainScreen.waitFor();
|
|
|
|
await expect(mainScreen.noteListContainer.locator('[title^="Toggle sort order"]')).not.toBeVisible();
|
|
});
|
|
|
|
test('clicking on an external link should try to launch a browser', async ({ electronApp, mainWindow }) => {
|
|
const mainScreen = new MainScreen(mainWindow);
|
|
await mainScreen.waitFor();
|
|
|
|
// Mock openExternal
|
|
const nextExternalUrlPromise = electronApp.evaluate(({ shell }) => {
|
|
return new Promise<string>(resolve => {
|
|
const openExternal = async (url: string) => {
|
|
resolve(url);
|
|
};
|
|
shell.openExternal = openExternal;
|
|
});
|
|
});
|
|
|
|
// Create a test link
|
|
const testLinkTitle = 'This is a test link!';
|
|
const linkHref = 'https://joplinapp.org/';
|
|
|
|
await mainWindow.evaluate(({ testLinkTitle, linkHref }) => {
|
|
const testLink = document.createElement('a');
|
|
testLink.textContent = testLinkTitle;
|
|
testLink.onclick = () => {
|
|
// We need to navigate by setting location.href -- clicking on a link
|
|
// directly within the main window (i.e. not in a PDF viewer) doesn't
|
|
// navigate.
|
|
location.href = linkHref;
|
|
};
|
|
testLink.href = '#';
|
|
|
|
// Display on top of everything
|
|
testLink.style.zIndex = '99999';
|
|
testLink.style.position = 'fixed';
|
|
testLink.style.top = '0';
|
|
testLink.style.left = '0';
|
|
|
|
document.body.appendChild(testLink);
|
|
}, { testLinkTitle, linkHref });
|
|
|
|
const testLink = mainWindow.getByText(testLinkTitle);
|
|
await expect(testLink).toBeVisible();
|
|
await testLink.click({ noWaitAfter: true });
|
|
|
|
expect(await nextExternalUrlPromise).toBe(linkHref);
|
|
});
|
|
|
|
test('should start in safe mode if profile-dir/force-safe-mode-on-next-start exists', async ({ profileDirectory }) => {
|
|
await writeFile(join(profileDirectory, 'force-safe-mode-on-next-start'), 'true', 'utf8');
|
|
|
|
// We need to write to the force-safe-mode file before opening the Electron app.
|
|
// Open the app ourselves:
|
|
const startupArgs = createStartupArgs(profileDirectory);
|
|
const electronApp = await electron.launch({ args: startupArgs });
|
|
const mainWindow = await firstNonDevToolsWindow(electronApp);
|
|
|
|
const safeModeDisableLink = mainWindow.getByText('Disable safe mode and restart');
|
|
await safeModeDisableLink.waitFor();
|
|
await expect(safeModeDisableLink).toBeInViewport();
|
|
|
|
await electronApp.close();
|
|
});
|
|
});
|
|
|