mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-17 21:50:56 +08:00
149b389508
* Switch to using Typescript instead of Babel * Switch all es6 / jsx file extensions to ts / tsx * Convert Utils to a TS module from module.exports style module * Move everything from module.exports to typescript exports * Define .d.ts files for mailspring-exports and component kit… Yes it seems this is the best option :( * Load up on those @types * Synthesize TS types from PropTypes for standard components * Add types to Model classes and move constructor constants to instance vars * 9800 => 7700 TS errors * 7700 => 5600 TS errors * 5600 => 5330 TS errors * 5330 => 4866 TS errors * 4866 => 4426 TS errors * 4426 => 2411 TS errors * 2411 > 1598 TS errors * 1598 > 769 TS errors * 769 > 129 TS errors * 129 > 22 TS errors * Fix runtime errors * More runtime error fixes * Remove support for custom .es6 file extension * Remove a few odd remaining references to Nylas * Don’t ship Typescript support in the compiled app for now * Fix issues in compiled app - module resolution in TS is case sensitive? * README updates * Fix a few more TS errors * Make “No Signature” option clickable + selectable * Remove flicker when saving file and reloading keymaps * Fix mail rule item height in preferences * Fix missing spacing in thread sharing popover * Fix scrollbar ticks being nested incorrectly * Add Japanese as a manually reviewed language * Prevent the thread list from “sticking” * Re-use Sheet when switching root tabs, prevent sidebar from resetting * Ensure specs run * Update package configuration to avoid shpping types * Turn eslint back on - we will opt-in to the TS rules one by one
190 lines
6 KiB
TypeScript
190 lines
6 KiB
TypeScript
/* eslint global-require:0 */
|
|
import _ from 'underscore';
|
|
import Enzyme from 'enzyme';
|
|
import Adapter from 'enzyme-adapter-react-16';
|
|
|
|
import ReactTestUtils from 'react-dom/test-utils';
|
|
import Config from '../../src/config';
|
|
import SpecLoader from './spec-loader';
|
|
import TimeReporter from './time-reporter';
|
|
import * as GuiReporter from './gui-reporter';
|
|
import jasmineExports from './jasmine';
|
|
import ConsoleReporter from './console-reporter';
|
|
import MasterAfterEach from './master-after-each';
|
|
import MasterBeforeEach from './master-before-each';
|
|
import TestConstants from './test-constants';
|
|
import * as jasmineExtensions from './jasmine-extensions';
|
|
import * as reactTestUtilsExtensions from './react-test-utils-extensions';
|
|
|
|
class SpecRunner {
|
|
jasmineEnv: any;
|
|
loadSettings: any;
|
|
|
|
runSpecs(loadSettings) {
|
|
this.loadSettings = loadSettings;
|
|
|
|
Enzyme.configure({ adapter: new Adapter() });
|
|
|
|
this._extendGlobalWindow();
|
|
this._setupJasmine();
|
|
this._setupAppEnv();
|
|
this._setupWindow();
|
|
Object.assign(ReactTestUtils, reactTestUtilsExtensions);
|
|
MasterBeforeEach.setup(this.loadSettings, window.beforeEach);
|
|
MasterAfterEach.setup(this.loadSettings, window.afterEach);
|
|
SpecLoader.loadSpecs(this.loadSettings, this.jasmineEnv);
|
|
this.jasmineEnv.execute();
|
|
}
|
|
|
|
/**
|
|
* Put jasmine methods on the global scope so they can be used anywhere
|
|
* without importing jasmine.
|
|
*/
|
|
_extendGlobalWindow() {
|
|
Object.assign(
|
|
window,
|
|
{
|
|
jasmine: jasmineExports.jasmine,
|
|
|
|
it: this._makeItAsync(jasmineExports.it),
|
|
// it: jasmineExports.it,
|
|
fit: this._makeItAsync(jasmineExports.fit),
|
|
xit: jasmineExports.xit,
|
|
runs: jasmineExports.runs,
|
|
waits: jasmineExports.waits,
|
|
spyOn: jasmineExports.spyOn,
|
|
expect: jasmineExports.expect,
|
|
waitsFor: jasmineExports.waitsFor,
|
|
describe: jasmineExports.describe,
|
|
xdescribe: jasmineExports.xdescribe,
|
|
afterEach: this._makeSurroundAsync(jasmineExports.afterEach),
|
|
beforeEach: this._makeSurroundAsync(jasmineExports.beforeEach),
|
|
testNowMoment: jasmineExtensions.testNowMoment,
|
|
waitsForPromise: jasmineExtensions.waitsForPromise,
|
|
},
|
|
TestConstants
|
|
);
|
|
|
|
this.jasmineEnv = jasmineExports.jasmine.getEnv();
|
|
}
|
|
|
|
_runAsync(userFn) {
|
|
if (!userFn) return true;
|
|
const resp = userFn.apply(this);
|
|
if (resp && resp.then) {
|
|
return jasmineExtensions.waitsForPromise(() => {
|
|
return resp;
|
|
});
|
|
}
|
|
return resp;
|
|
}
|
|
|
|
_makeItAsync(jasmineIt) {
|
|
const self = this;
|
|
return (desc, userFn) => {
|
|
return jasmineIt(desc, function asyncIt() {
|
|
self._runAsync.call(this, userFn);
|
|
});
|
|
};
|
|
}
|
|
|
|
_makeSurroundAsync(jasmineBeforeAfter) {
|
|
const self = this;
|
|
return userFn => {
|
|
return jasmineBeforeAfter(function asyncBeforeAfter() {
|
|
self._runAsync.call(this, userFn);
|
|
});
|
|
};
|
|
}
|
|
|
|
_setupJasmine() {
|
|
this._addReporters();
|
|
this._initializeDOM();
|
|
this._extendJasmineMethods();
|
|
|
|
// On load this will extend jasmine's `beforeEach`
|
|
require('jasmine-json');
|
|
}
|
|
|
|
_setupAppEnv() {
|
|
// We need to mock the config even before `beforeEach` runs because it
|
|
// gets accessed on module definitions
|
|
const fakePersistedConfig = { env: 'production' };
|
|
AppEnv.config = new Config();
|
|
AppEnv.config.settings = fakePersistedConfig;
|
|
|
|
AppEnv.restoreWindowDimensions();
|
|
AppEnv.themes.loadStaticStylesheets();
|
|
AppEnv.themes.requireStylesheet('../../static/jasmine');
|
|
AppEnv.themes.initialLoadComplete = true;
|
|
AppEnv.keymaps.loadKeymaps();
|
|
}
|
|
|
|
_setupWindow() {
|
|
window.addEventListener('core:close', () => window.close());
|
|
window.addEventListener('beforeunload', () => {
|
|
AppEnv.storeWindowDimensions();
|
|
AppEnv.saveWindowState();
|
|
});
|
|
}
|
|
|
|
_addReporters() {
|
|
const timeReporter = new TimeReporter();
|
|
const consoleReporter = new ConsoleReporter();
|
|
|
|
const loadSettings = AppEnv.getLoadSettings();
|
|
|
|
if (loadSettings.jUnitXmlPath) {
|
|
// jasmine-reporters extends the jasmine global with methods, so needs to
|
|
// be `required` at runtime. The `jasmine` object has to be attached to the
|
|
// global scope before it gets extended. This is done in
|
|
// `_extendGlobalWindow`
|
|
require('jasmine-reporters');
|
|
const jUnitXmlReporter = new jasmine.JUnitXmlReporter(loadSettings.jUnitXmlPath, true, true);
|
|
this.jasmineEnv.addReporter(jUnitXmlReporter);
|
|
}
|
|
this.jasmineEnv.addReporter(timeReporter);
|
|
this.jasmineEnv.addReporter(consoleReporter);
|
|
|
|
if (loadSettings.showSpecsInWindow) {
|
|
this.jasmineEnv.addReporter(GuiReporter);
|
|
AppEnv.show();
|
|
} else {
|
|
// this package's dep `jasmine-focused` also adds methods to the
|
|
// `jasmine` global
|
|
// NOTE: this reporter MUST be added last as it exits the test process
|
|
// when complete, which may result in e.g. your XML output not getting
|
|
// written to disk if that reporter is added afterward.
|
|
const TerminalReporter = require('./terminal-reporter').default;
|
|
const terminalReporter = new TerminalReporter();
|
|
this.jasmineEnv.addReporter(terminalReporter);
|
|
}
|
|
}
|
|
|
|
_initializeDOM() {
|
|
const div = document.createElement('div');
|
|
div.id = 'jasmine-content';
|
|
document.body.appendChild(div);
|
|
document.querySelector('html').style.overflow = 'initial';
|
|
document.querySelector('body').style.overflow = 'initial';
|
|
}
|
|
|
|
_extendJasmineMethods() {
|
|
const jasmine = jasmineExports.jasmine;
|
|
|
|
// Use underscore's definition of equality for toEqual assertions
|
|
jasmine.getEnv().addEqualityTester(_.isEqual);
|
|
|
|
jasmine.unspy = jasmineExtensions.unspy;
|
|
jasmine.attachToDOM = jasmineExtensions.attachToDOM;
|
|
|
|
const origEmitObject = jasmine.StringPrettyPrinter.prototype.emitObject;
|
|
jasmine.StringPrettyPrinter.prototype.emitObject = function emitObject(obj) {
|
|
if (obj.inspect) {
|
|
return this.append(obj.inspect());
|
|
}
|
|
return origEmitObject.call(this, obj);
|
|
};
|
|
}
|
|
}
|
|
export default new SpecRunner();
|