mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-18 05:58:11 +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
107 lines
2.9 KiB
TypeScript
107 lines
2.9 KiB
TypeScript
/*
|
|
* decaffeinate suggestions:
|
|
* DS001: Remove Babel/TypeScript constructor workaround
|
|
* DS101: Remove unnecessary use of Array.from
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
* DS207: Consider shorter variations of null checks
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
*/
|
|
import _ from 'underscore';
|
|
import _str from 'underscore.string';
|
|
import { jasmine } from './jasmine';
|
|
|
|
export default class TimeReporter extends jasmine.Reporter {
|
|
constructor() {
|
|
super();
|
|
|
|
window.timedSpecs = [];
|
|
window.timedSuites = {};
|
|
|
|
window.logLongestSpec = () => this.logLongestSpecs(1);
|
|
window.logLongestSpecs = number => this.logLongestSpecs(number);
|
|
window.logLongestSuite = () => this.logLongestSuites(1);
|
|
window.logLongestSuites = number => this.logLongestSuites(number);
|
|
}
|
|
|
|
logLongestSuites(number, log) {
|
|
if (number == null) {
|
|
number = 10;
|
|
}
|
|
if (!(window.timedSuites.length > 0)) {
|
|
return;
|
|
}
|
|
|
|
if (log == null) {
|
|
log = line => console.log(line);
|
|
}
|
|
log('Longest running suites:');
|
|
const suites = _.map(window.timedSuites, (key, value) => [value, key]);
|
|
for (let suite of Array.from(_.sortBy(suites, suite => -suite[1]).slice(0, number))) {
|
|
const time = Math.round(suite[1] / 100) / 10;
|
|
log(` ${suite[0]} (${time}s)`);
|
|
}
|
|
}
|
|
|
|
logLongestSpecs(number, log) {
|
|
if (number == null) {
|
|
number = 10;
|
|
}
|
|
if (!(window.timedSpecs.length > 0)) {
|
|
return;
|
|
}
|
|
|
|
if (log == null) {
|
|
log = line => console.log(line);
|
|
}
|
|
log('Longest running specs:');
|
|
for (let spec of Array.from(_.sortBy(window.timedSpecs, spec => -spec.time).slice(0, number))) {
|
|
const time = Math.round(spec.time / 100) / 10;
|
|
log(`${spec.description} (${time}s)`);
|
|
}
|
|
}
|
|
|
|
reportSpecStarting(spec) {
|
|
const stack = [spec.description];
|
|
let { suite } = spec;
|
|
while (suite) {
|
|
stack.unshift(suite.description);
|
|
this.suite = suite.description;
|
|
suite = suite.parentSuite;
|
|
}
|
|
|
|
const reducer = function(memo, description, index) {
|
|
if (index === 0) {
|
|
return `${description}`;
|
|
} else {
|
|
return `${memo}\n${_str.repeat(' ', index)}${description}`;
|
|
}
|
|
};
|
|
this.description = _.reduce(stack, reducer, '');
|
|
this.time = Date.now();
|
|
}
|
|
|
|
reportSpecResults(spec) {
|
|
if (this.time == null || this.description == null) {
|
|
return;
|
|
}
|
|
|
|
const duration = Date.now() - this.time;
|
|
|
|
if (duration > 0) {
|
|
window.timedSpecs.push({
|
|
description: this.description,
|
|
time: duration,
|
|
fullName: spec.getFullName(),
|
|
});
|
|
|
|
if (window.timedSuites[this.suite]) {
|
|
window.timedSuites[this.suite] += duration;
|
|
} else {
|
|
window.timedSuites[this.suite] = duration;
|
|
}
|
|
}
|
|
|
|
this.time = null;
|
|
this.description = null;
|
|
}
|
|
}
|