SymphonyElectron/spec/__mocks__/electron.ts

198 lines
5.0 KiB
TypeScript
Raw Normal View History

2019-01-22 09:12:16 -06:00
import { EventEmitter } from 'events';
import * as path from 'path';
2019-03-11 09:25:34 -05:00
import { isWindowsOS } from '../../src/common/env';
2019-01-22 09:12:16 -06:00
const ipcEmitter = new EventEmitter();
const mockIdleTime: number = 15;
2019-01-22 09:12:16 -06:00
const appName: string = 'Symphony';
const executableName: string = '/Symphony.exe';
const isReady: boolean = true;
2019-02-11 21:54:46 -06:00
const version: string = '4.0.0';
2019-01-22 09:12:16 -06:00
interface IApp {
commandLine: any;
2019-01-22 09:12:16 -06:00
getAppPath(): string;
getPath(type: string): string;
getName(): string;
isReady(): boolean;
2019-02-11 21:54:46 -06:00
getVersion(): string;
2019-04-02 00:09:34 -05:00
on(eventName: any, cb: any): void;
once(eventName: any, cb: any): void;
setPath(value: string, path: string): void;
2019-05-07 02:56:57 -05:00
setLoginItemSettings(settings: { openAtLogin: boolean, path: string }): void;
getLoginItemSettings(options?: { path: string, args: string[] }): ILoginItemSettings;
2019-05-07 02:56:57 -05:00
}
interface ILoginItemSettings {
2019-05-07 02:56:57 -05:00
openAtLogin: boolean;
2019-01-22 09:12:16 -06:00
}
interface IIpcMain {
on(event: any, cb: any): void;
send(event: any, cb: any): void;
}
interface IIpcRenderer {
sendSync(event: any, cb: any): any;
on(eventName: any, cb: any): void;
2019-03-25 03:26:08 -05:00
send(event: any, ...cb: any[]): void;
2019-01-22 09:12:16 -06:00
removeListener(eventName: any, cb: any): void;
2019-03-25 03:26:08 -05:00
once(eventName: any, cb: any): void;
2019-01-22 09:12:16 -06:00
}
interface IPowerMonitor {
querySystemIdleTime(): void;
}
2019-01-22 09:12:16 -06:00
const pathToConfigDir = (): string => {
2019-03-11 09:25:34 -05:00
if (isWindowsOS) {
return path.join(__dirname, '/../..') as string;
} else {
return path.join(__dirname, '/..') as string;
}
2019-01-22 09:12:16 -06:00
};
// electron app mock...
export const app: IApp = {
2019-01-22 09:12:16 -06:00
getAppPath: pathToConfigDir,
getPath: (type) => {
if (type === 'exe') {
return path.join(pathToConfigDir(), executableName);
}
2019-02-11 21:54:46 -06:00
if (type === 'userData') {
return path.join(pathToConfigDir(), '/../config');
}
2019-01-22 09:12:16 -06:00
return pathToConfigDir();
},
getName: () => appName,
isReady: () => isReady,
2019-02-11 21:54:46 -06:00
getVersion: () => version,
2019-03-30 00:09:34 -05:00
on: (event, cb) => {
ipcEmitter.on(event, cb);
},
setPath: () => jest.fn(),
commandLine: {
appendSwitch: jest.fn(),
},
2019-04-02 00:09:34 -05:00
once: (eventName, cb) => {
ipcEmitter.on(eventName, cb);
},
2019-05-07 02:56:57 -05:00
setLoginItemSettings: () => jest.fn(),
getLoginItemSettings: (): ILoginItemSettings => {
return { openAtLogin: true };
},
2019-01-22 09:12:16 -06:00
};
// simple ipc mocks for render and main process ipc using
// nodes' EventEmitter
export const ipcMain: IIpcMain = {
2019-01-22 09:12:16 -06:00
on: (event, cb) => {
ipcEmitter.on(event, cb);
},
send: (event, args) => {
const senderEvent = {
sender: {
send: (eventSend, arg) => {
ipcEmitter.emit(eventSend, arg);
},
},
};
ipcEmitter.emit(event, senderEvent, args);
},
};
export const powerMonitor: IPowerMonitor = {
querySystemIdleTime: jest.fn().mockImplementation((cb) => cb(mockIdleTime)),
};
export const ipcRenderer: IIpcRenderer = {
2019-01-22 09:12:16 -06:00
sendSync: (event, args) => {
const listeners = ipcEmitter.listeners(event);
if (listeners.length > 0) {
const listener = listeners[0];
const eventArg = {};
listener(eventArg, args);
return eventArg;
}
return null;
},
2019-03-25 03:26:08 -05:00
send: (event, ...args) => {
2019-01-22 09:12:16 -06:00
const senderEvent = {
sender: {
2019-03-25 03:26:08 -05:00
send: (eventSend, ...arg) => {
ipcEmitter.emit(eventSend, ...arg);
2019-01-22 09:12:16 -06:00
},
},
2019-03-25 03:26:08 -05:00
preventDefault: jest.fn(),
2019-01-22 09:12:16 -06:00
};
2019-03-25 03:26:08 -05:00
ipcEmitter.emit(event, senderEvent, ...args);
2019-01-22 09:12:16 -06:00
},
on: (eventName, cb) => {
ipcEmitter.on(eventName, cb);
},
removeListener: (eventName, cb) => {
ipcEmitter.removeListener(eventName, cb);
},
2019-03-25 03:26:08 -05:00
once: (eventName, cb) => {
ipcEmitter.on(eventName, cb);
},
2019-01-22 09:12:16 -06:00
};
2019-03-22 06:15:23 -05:00
export const shell = {
openExternal: jest.fn(),
};
// tslint:disable-next-line:variable-name
export const Menu = {
buildFromTemplate: jest.fn(),
setApplicationMenu: jest.fn(),
};
export const crashReporter = {
start: jest.fn(),
};
2019-03-20 00:16:01 -05:00
const getCurrentWindow = jest.fn(() => {
return {
isFullScreen: jest.fn(() => {
return false;
}),
isMaximized: jest.fn(() => {
return false;
}),
on: jest.fn(),
removeListener: jest.fn(),
isDestroyed: jest.fn(() => {
return false;
}),
close: jest.fn(),
maximize: jest.fn(),
minimize: jest.fn(),
unmaximize: jest.fn(),
setFullScreen: jest.fn(),
};
});
2019-03-22 06:15:23 -05:00
export const dialog = {
showMessageBox: jest.fn(),
showErrorBox: jest.fn(),
2019-03-20 23:21:59 -05:00
};
// tslint:disable-next-line:variable-name
export const BrowserWindow = {
getFocusedWindow: jest.fn(() => {
return {
isDestroyed: jest.fn(() => false),
};
}),
fromWebContents: (arg) => arg,
getAllWindows: jest.fn(() => []),
};
export const session = {
defaultSession: {
clearCache: jest.fn(),
},
};
export const remote = {
2019-01-22 09:12:16 -06:00
app,
2019-03-20 00:16:01 -05:00
getCurrentWindow,
2019-01-22 09:12:16 -06:00
};