Mailspring/app/spec_disabled/app-env-spec.es6

212 lines
7.1 KiB
Text
Raw Normal View History

import { remote } from 'electron';
2017-09-27 02:36:58 +08:00
describe('the `AppEnv` global', function nylasEnvSpec() {
describe('window sizing methods', () => {
describe('::getPosition and ::setPosition', () =>
it('sets the position of the window, and can retrieve the position just set', () => {
2017-09-27 02:36:58 +08:00
AppEnv.setPosition(22, 45);
expect(AppEnv.getPosition()).toEqual({ x: 22, y: 45 });
2017-09-27 02:33:08 +08:00
}));
describe('::getSize and ::setSize', () => {
beforeEach(() => {
2017-09-27 02:36:58 +08:00
this.originalSize = AppEnv.getSize();
});
2017-09-27 02:36:58 +08:00
afterEach(() => AppEnv.setSize(this.originalSize.width, this.originalSize.height));
2016-05-17 04:26:33 +08:00
it('sets the size of the window, and can retrieve the size just set', () => {
2017-09-27 02:36:58 +08:00
AppEnv.setSize(100, 400);
expect(AppEnv.getSize()).toEqual({ width: 100, height: 400 });
});
});
describe('::setMinimumWidth', () => {
2017-09-27 02:36:58 +08:00
const win = AppEnv.getCurrentWindow();
2017-09-27 02:33:08 +08:00
it('sets the minimum width', () => {
const inputMinWidth = 500;
win.setMinimumSize(1000, 1000);
2017-09-27 02:36:58 +08:00
AppEnv.setMinimumWidth(inputMinWidth);
const [actualMinWidth] = win.getMinimumSize();
2016-05-17 04:26:33 +08:00
expect(actualMinWidth).toBe(inputMinWidth);
});
2017-09-27 02:33:08 +08:00
it('sets the current size if minWidth > current width', () => {
const inputMinWidth = 1000;
win.setSize(500, 500);
2017-09-27 02:36:58 +08:00
AppEnv.setMinimumWidth(inputMinWidth);
const [actualWidth] = win.getMinimumSize();
2016-05-17 04:26:33 +08:00
expect(actualWidth).toBe(inputMinWidth);
});
});
2016-05-17 04:26:33 +08:00
describe('::getDefaultWindowDimensions', () => {
it("returns primary display's work area size if it's small enough", () => {
2017-09-27 02:33:08 +08:00
spyOn(remote.screen, 'getPrimaryDisplay').andReturn({
workAreaSize: { width: 1440, height: 900 },
});
2017-09-27 02:36:58 +08:00
const out = AppEnv.getDefaultWindowDimensions();
2017-09-27 02:33:08 +08:00
expect(out).toEqual({ x: 0, y: 0, width: 1440, height: 900 });
});
2017-09-27 02:33:08 +08:00
it('caps width at 1440 and centers it, if wider', () => {
spyOn(remote.screen, 'getPrimaryDisplay').andReturn({
workAreaSize: { width: 1840, height: 900 },
});
2017-09-27 02:36:58 +08:00
const out = AppEnv.getDefaultWindowDimensions();
2017-09-27 02:33:08 +08:00
expect(out).toEqual({ x: 200, y: 0, width: 1440, height: 900 });
});
2017-09-27 02:33:08 +08:00
it('caps height at 900 and centers it, if taller', () => {
spyOn(remote.screen, 'getPrimaryDisplay').andReturn({
workAreaSize: { width: 1440, height: 1100 },
});
2017-09-27 02:36:58 +08:00
const out = AppEnv.getDefaultWindowDimensions();
2017-09-27 02:33:08 +08:00
expect(out).toEqual({ x: 0, y: 100, width: 1440, height: 900 });
});
it("returns only the max viewport size if it's smaller than the defaults", () => {
2017-09-27 02:33:08 +08:00
spyOn(remote.screen, 'getPrimaryDisplay').andReturn({
workAreaSize: { width: 1000, height: 800 },
});
2017-09-27 02:36:58 +08:00
const out = AppEnv.getDefaultWindowDimensions();
2017-09-27 02:33:08 +08:00
expect(out).toEqual({ x: 0, y: 0, width: 1000, height: 800 });
});
2017-09-27 02:33:08 +08:00
it('always rounds X and Y', () => {
spyOn(remote.screen, 'getPrimaryDisplay').andReturn({
workAreaSize: { width: 1845, height: 955 },
});
2017-09-27 02:36:58 +08:00
const out = AppEnv.getDefaultWindowDimensions();
2017-09-27 02:33:08 +08:00
expect(out).toEqual({ x: 202, y: 27, width: 1440, height: 900 });
});
});
});
2017-09-27 02:33:08 +08:00
describe('.isReleasedVersion()', () =>
it('returns false if the version is a SHA and true otherwise', () => {
let version = '0.1.0';
2017-09-27 02:36:58 +08:00
spyOn(AppEnv, 'getVersion').andCallFake(() => version);
expect(AppEnv.isReleasedVersion()).toBe(true);
version = '36b5518';
2017-09-27 02:36:58 +08:00
expect(AppEnv.isReleasedVersion()).toBe(false);
2017-09-27 02:33:08 +08:00
}));
2017-09-27 02:33:08 +08:00
describe('when an update becomes available', () => {
let subscription = null;
afterEach(() => {
2017-09-27 02:33:08 +08:00
if (subscription) {
subscription.dispose();
}
});
2017-09-27 02:33:08 +08:00
it('invokes onUpdateAvailable listeners', () => {
if (process.platform === 'linux') {
return;
}
2017-09-27 02:33:08 +08:00
const updateAvailableHandler = jasmine.createSpy('update-available-handler');
2017-09-27 02:36:58 +08:00
subscription = AppEnv.onUpdateAvailable(updateAvailableHandler);
2017-09-27 02:33:08 +08:00
remote.autoUpdater.emit('update-downloaded', null, 'notes', 'version');
waitsFor(() => updateAvailableHandler.callCount > 0);
2016-05-17 04:26:33 +08:00
runs(() => {
2017-09-27 02:33:08 +08:00
const { releaseVersion, releaseNotes } = updateAvailableHandler.mostRecentCall.args[0];
expect(releaseVersion).toBe('version');
2016-05-17 04:26:33 +08:00
expect(releaseNotes).toBe('notes');
});
});
});
2017-09-27 02:33:08 +08:00
describe('error handling', () => {
beforeEach(() => {
2017-09-27 02:36:58 +08:00
spyOn(AppEnv, 'inSpecMode').andReturn(false);
spyOn(AppEnv, 'inDevMode').andReturn(false);
spyOn(AppEnv, 'openDevTools');
spyOn(AppEnv, 'executeJavaScriptInDevTools');
spyOn(AppEnv.errorLogger, 'reportError');
});
2017-09-27 02:33:08 +08:00
it('Catches errors that make it to window.onerror', () => {
2017-09-27 02:36:58 +08:00
spyOn(AppEnv, 'reportError');
2017-09-27 02:33:08 +08:00
const e = new Error('Test Error');
2016-05-17 04:26:33 +08:00
window.onerror.call(window, e.toString(), 'abc', 2, 3, e);
2017-09-27 02:36:58 +08:00
expect(AppEnv.reportError).toHaveBeenCalled();
expect(AppEnv.reportError.calls[0].args[0]).toBe(e);
const extra = AppEnv.reportError.calls[0].args[1];
2017-09-27 02:33:08 +08:00
expect(extra.url).toBe('abc');
expect(extra.line).toBe(2);
expect(extra.column).toBe(3);
2016-05-17 04:26:33 +08:00
});
2017-09-27 02:33:08 +08:00
it('Catches unhandled rejections', async () => {
2017-09-27 02:36:58 +08:00
spyOn(AppEnv, 'reportError');
2017-09-27 02:33:08 +08:00
const err = new Error('TEST');
const p = new Promise((resolve, reject) => {
reject(err);
2017-09-27 02:33:08 +08:00
});
p.then(() => {
2017-09-27 02:33:08 +08:00
throw new Error("Shouldn't resolve");
});
/**
* This test was started from within the `setTimeout` block of the
* Node event loop. The unhandled rejection will not get caught
* until the "pending callbacks" block (which happens next). Since
* that happens immediately next it's important that we don't use:
*
* await new Promise(setImmediate)
*
* Because of setImmediate's position in the Node event loop
* relative to this test and process.on('unhandledRejection'), using
* setImmediate would require us to await for it twice.
*
* We can use the original, no-stubbed-out `setTimeout` to put our
* test in the correct spot in the Node event loop relative to
* unhandledRejection.
*/
2017-09-27 02:33:08 +08:00
await new Promise(resolve => {
window.originalSetTimeout(resolve, 0);
});
2017-09-27 02:36:58 +08:00
expect(AppEnv.reportError.callCount).toBe(1);
expect(AppEnv.reportError.calls[0].args[0]).toBe(err);
});
2017-09-27 02:33:08 +08:00
describe('reportError', () => {
beforeEach(() => {
2017-09-27 02:33:08 +08:00
this.testErr = new Error('Test');
spyOn(console, 'error');
});
2017-09-27 02:33:08 +08:00
it('opens dev tools in dev mode', () => {
2017-09-27 02:36:58 +08:00
jasmine.unspy(AppEnv, 'inDevMode');
spyOn(AppEnv, 'inDevMode').andReturn(true);
AppEnv.reportError(this.testErr);
expect(AppEnv.openDevTools).toHaveBeenCalled();
expect(AppEnv.executeJavaScriptInDevTools).toHaveBeenCalled();
2016-05-17 04:26:33 +08:00
});
2017-09-27 02:33:08 +08:00
it('sends the error report to the error logger', () => {
2017-09-27 02:36:58 +08:00
AppEnv.reportError(this.testErr);
expect(AppEnv.errorLogger.reportError).toHaveBeenCalled();
expect(AppEnv.errorLogger.reportError.callCount).toBe(1);
expect(AppEnv.errorLogger.reportError.calls[0].args[0]).toBe(this.testErr);
2016-05-17 04:26:33 +08:00
});
});
});
});