Files
bDS/tests/renderer/menuCommands.test.ts

52 lines
2.4 KiB
TypeScript

import { describe, it, expect } from 'vitest';
import { APP_MENU_GROUPS, APP_MENU_ACTION_EVENT_MAP } from '../../src/main/shared/menuCommands';
describe('Help menu documentation entry', () => {
it('includes an Open Documentation action in Help menu', () => {
const helpGroup = APP_MENU_GROUPS.find((group) => group.label === 'Help');
expect(helpGroup).toBeDefined();
expect(helpGroup?.items.some((item) => item.action === 'openDocumentation')).toBe(true);
});
it('maps Open Documentation to a renderer menu event', () => {
expect(APP_MENU_ACTION_EVENT_MAP.openDocumentation).toBe('menu:openDocumentation');
});
it('includes Open in Browser and Open Data Folder actions in File menu', () => {
const fileGroup = APP_MENU_GROUPS.find((group) => group.label === 'File');
expect(fileGroup).toBeDefined();
expect(fileGroup?.items.some((item) => item.action === 'openInBrowser')).toBe(true);
expect(fileGroup?.items.some((item) => item.action === 'openDataFolder')).toBe(true);
});
it('includes Preview Post action in Blog menu', () => {
const blogGroup = APP_MENU_GROUPS.find((group) => group.label === 'Blog');
expect(blogGroup).toBeDefined();
expect(blogGroup?.items.some((item) => item.action === 'previewPost')).toBe(true);
});
it('includes shared View actions for reload, zoom and fullscreen controls', () => {
const viewGroup = APP_MENU_GROUPS.find((group) => group.label === 'View');
expect(viewGroup).toBeDefined();
expect(viewGroup?.items.some((item) => item.action === 'reload')).toBe(true);
expect(viewGroup?.items.some((item) => item.action === 'forceReload')).toBe(true);
expect(viewGroup?.items.some((item) => item.action === 'resetZoom')).toBe(true);
expect(viewGroup?.items.some((item) => item.action === 'zoomIn')).toBe(true);
expect(viewGroup?.items.some((item) => item.action === 'zoomOut')).toBe(true);
expect(viewGroup?.items.some((item) => item.action === 'toggleFullScreen')).toBe(true);
});
it('renames generateSitemap menu item to Render Site and assigns Command/Ctrl+R', () => {
const blogGroup = APP_MENU_GROUPS.find((group) => group.label === 'Blog');
const generateSiteItem = blogGroup?.items.find((item) => item.action === 'generateSitemap');
expect(generateSiteItem).toBeDefined();
expect(generateSiteItem?.label).toBe('Render Site');
expect(generateSiteItem?.accelerator).toBe('CmdOrCtrl+R');
});
});