signal-desktop/ts/test-node/app/menu_test.ts
adel-signal 8a9ab8c13f
Add calling tools to visualize ringrtc stats
Co-authored-by: ayumi-signal <ayumi@signal.org>
2024-05-22 17:28:01 -07:00

286 lines
7.8 KiB
TypeScript

// Copyright 2018 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import { assert } from 'chai';
import { stub } from 'sinon';
import type { MenuItemConstructorOptions } from 'electron';
import type { CreateTemplateOptionsType } from '../../../app/menu';
import { createTemplate } from '../../../app/menu';
import { load as loadLocale } from '../../../app/locale';
import type { MenuListType } from '../../types/menu';
import { HourCyclePreference } from '../../types/I18N';
const forceUpdate = stub();
const openArtCreator = stub();
const openContactUs = stub();
const openForums = stub();
const openJoinTheBeta = stub();
const openReleaseNotes = stub();
const openSupportPage = stub();
const setupAsNewDevice = stub();
const setupAsStandalone = stub();
const showAbout = stub();
const showDebugLog = stub();
const showCallingDevTools = stub();
const showKeyboardShortcuts = stub();
const showSettings = stub();
const showWindow = stub();
const zoomIn = stub();
const zoomOut = stub();
const zoomReset = stub();
const getExpectedEditMenu = (
includeSpeech: boolean
): MenuItemConstructorOptions => ({
label: '&Edit',
submenu: [
{ label: 'Undo', role: 'undo' },
{ label: 'Redo', role: 'redo' },
{ type: 'separator' },
{ label: 'Cut', role: 'cut' },
{ label: 'Copy', role: 'copy' },
{ label: 'Paste', role: 'paste' },
{ label: 'Paste and Match Style', role: 'pasteAndMatchStyle' },
{ label: 'Delete', role: 'delete' },
{ label: 'Select All', role: 'selectAll' },
...(includeSpeech
? ([
{ type: 'separator' },
{
label: 'Speech',
submenu: [
{ label: 'Start speaking', role: 'startSpeaking' },
{ label: 'Stop speaking', role: 'stopSpeaking' },
],
},
] as MenuListType)
: []),
],
});
const getExpectedViewMenu = (): MenuItemConstructorOptions => ({
label: '&View',
submenu: [
{ accelerator: 'CmdOrCtrl+0', label: 'Actual Size', click: zoomReset },
{ accelerator: 'CmdOrCtrl+=', label: 'Zoom In', click: zoomIn },
{ accelerator: 'CmdOrCtrl+-', label: 'Zoom Out', click: zoomOut },
{ type: 'separator' },
{ label: 'Toggle Full Screen', role: 'togglefullscreen' },
{ type: 'separator' },
{ label: 'Debug Log', click: showDebugLog },
{ type: 'separator' },
{ label: 'Toggle Developer Tools', role: 'toggleDevTools' },
{ label: 'Open Calling Developer Tools', click: showCallingDevTools },
{ label: 'Force Update', click: forceUpdate },
],
});
const getExpectedHelpMenu = (
includeAbout: boolean
): MenuItemConstructorOptions => ({
label: '&Help',
role: 'help',
submenu: [
{
label: 'Show Keyboard Shortcuts',
accelerator: 'CmdOrCtrl+/',
click: showKeyboardShortcuts,
},
{ type: 'separator' },
{ label: 'Contact Us', click: openContactUs },
{ label: 'Go to Release Notes', click: openReleaseNotes },
{ label: 'Go to Forums', click: openForums },
{ label: 'Go to Support Page', click: openSupportPage },
{ label: 'Join the Beta', click: openJoinTheBeta },
...(includeAbout
? ([
{ type: 'separator' },
{ label: 'About Signal Desktop', click: showAbout },
] as MenuListType)
: []),
],
});
const EXPECTED_MACOS: MenuListType = [
{
label: 'Signal Desktop',
submenu: [
{ label: 'About Signal Desktop', click: showAbout },
{ type: 'separator' },
{
label: 'Preferences…',
accelerator: 'CommandOrControl+,',
click: showSettings,
},
{ type: 'separator' },
{ label: 'Services', role: 'services' },
{ type: 'separator' },
{ label: 'Hide', role: 'hide' },
{ label: 'Hide Others', role: 'hideOthers' },
{ label: 'Show All', role: 'unhide' },
{ type: 'separator' },
{ label: 'Quit Signal', role: 'quit' },
],
},
{
label: '&File',
submenu: [
{ label: 'Create/upload sticker pack', click: openArtCreator },
{ type: 'separator' },
{ accelerator: 'CmdOrCtrl+W', label: 'Close Window', role: 'close' },
],
},
getExpectedEditMenu(true),
getExpectedViewMenu(),
{
label: '&Window',
role: 'window',
submenu: [
{ label: 'Minimize', accelerator: 'CmdOrCtrl+M', role: 'minimize' },
{ label: 'Zoom', role: 'zoom' },
{ label: 'Show', accelerator: 'CmdOrCtrl+Shift+0', click: showWindow },
{ type: 'separator' },
{ label: 'Bring All to Front', role: 'front' },
],
},
getExpectedHelpMenu(false),
];
const EXPECTED_WINDOWS: MenuListType = [
{
label: '&File',
submenu: [
{ label: 'Create/upload sticker pack', click: openArtCreator },
{
label: 'Preferences…',
accelerator: 'CommandOrControl+,',
click: showSettings,
},
{ type: 'separator' },
{ label: 'Quit Signal', role: 'quit' },
],
},
getExpectedEditMenu(false),
getExpectedViewMenu(),
{
label: '&Window',
role: 'window',
submenu: [{ label: 'Minimize', role: 'minimize' }],
},
getExpectedHelpMenu(true),
];
const EXPECTED_LINUX: MenuListType = EXPECTED_WINDOWS.map(menuItem => {
if (menuItem.label === '&View' && Array.isArray(menuItem.submenu)) {
return {
...menuItem,
submenu: menuItem.submenu.filter(
submenuItem => submenuItem.label !== 'Force Update'
),
};
}
return menuItem;
});
const PLATFORMS = [
{
label: 'macOS',
platform: 'darwin',
expectedDefault: EXPECTED_MACOS,
},
{
label: 'Windows',
platform: 'win32',
expectedDefault: EXPECTED_WINDOWS,
},
{
label: 'Linux',
platform: 'linux',
expectedDefault: EXPECTED_LINUX,
},
];
describe('createTemplate', () => {
const { i18n } = loadLocale({
preferredSystemLocales: ['en'],
localeOverride: null,
localeDirectionTestingOverride: null,
hourCyclePreference: HourCyclePreference.UnknownPreference,
logger: {
fatal: stub().throwsArg(0),
error: stub().throwsArg(0),
warn: stub().throwsArg(0),
info: stub(),
debug: stub(),
trace: stub(),
},
});
const actions = {
forceUpdate,
openArtCreator,
openContactUs,
openForums,
openJoinTheBeta,
openReleaseNotes,
openSupportPage,
setupAsNewDevice,
setupAsStandalone,
showAbout,
showDebugLog,
showCallingDevTools,
showKeyboardShortcuts,
showSettings,
showWindow,
zoomIn,
zoomOut,
zoomReset,
};
PLATFORMS.forEach(({ label, platform, expectedDefault }) => {
describe(label, () => {
it('should return the correct template without setup options', () => {
const options: CreateTemplateOptionsType = {
development: false,
devTools: true,
includeSetup: false,
isProduction: true,
platform,
...actions,
};
const actual = createTemplate(options, i18n);
assert.deepEqual(actual, expectedDefault);
});
it('should return correct template with setup options', () => {
const options: CreateTemplateOptionsType = {
development: false,
devTools: true,
includeSetup: true,
isProduction: true,
platform,
...actions,
};
const expected: MenuListType = expectedDefault.map(menuItem => {
if (menuItem.label === '&File' && Array.isArray(menuItem.submenu)) {
return {
...menuItem,
submenu: [
{ label: 'Set Up as New Device', click: setupAsNewDevice },
{ type: 'separator' },
...menuItem.submenu,
],
};
}
return menuItem;
});
const actual = createTemplate(options, i18n);
assert.deepEqual(actual, expected);
});
});
});
});