Mailspring/app/spec/stores/focused-perspective-store-spec.ts

202 lines
7.6 KiB
TypeScript
Raw Normal View History

/*
* decaffeinate suggestions:
* DS102: Remove unnecessary code created because of implicit returns
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
*/
Replace Babel with TypeScript compiler, switch entire app to TypeScript 🎉 (#1404) * 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
2019-03-05 03:03:12 +08:00
import { Folder } from '../../src/flux/models/folder';
import { MailboxPerspective } from '../../src/mailbox-perspective';
Replace Babel with TypeScript compiler, switch entire app to TypeScript 🎉 (#1404) * 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
2019-03-05 03:03:12 +08:00
import CategoryStore from '../../src/flux/stores/category-store';
import { AccountStore } from '../../src/flux/stores/account-store';
import FocusedPerspectiveStore from '../../src/flux/stores/focused-perspective-store';
describe('FocusedPerspectiveStore', function() {
beforeEach(function() {
spyOn(FocusedPerspectiveStore, 'trigger');
FocusedPerspectiveStore._current = MailboxPerspective.forNothing();
this.account = AccountStore.accounts()[0];
this.inboxCategory = new Folder({
id: 'id-123',
role: 'inbox',
path: 'INBOX',
accountId: this.account.id,
});
this.inboxPerspective = MailboxPerspective.forCategory(this.inboxCategory);
this.userCategory = new Folder({
id: 'id-456',
role: null,
path: 'MyCategory',
accountId: this.account.id,
});
this.userPerspective = MailboxPerspective.forCategory(this.userCategory);
spyOn(CategoryStore, 'getCategoryByRole').andReturn(this.inboxCategory);
spyOn(CategoryStore, 'byId').andCallFake((aid, cid) => {
if (aid === 1 && cid === 'A') {
return { id: 'A' };
}
if (cid === this.inboxCategory.id) {
return this.inboxCategory;
}
if (cid === this.userCategory.id) {
return this.userCategory;
}
return null;
});
});
describe('_initializeFromSavedState', function() {
beforeEach(function() {
this.default = MailboxPerspective.forCategory(this.inboxCategory);
spyOn(AccountStore, 'accountIds').andReturn([1, 2]);
spyOn(MailboxPerspective, 'fromJSON').andCallFake(json => json);
spyOn(FocusedPerspectiveStore, '_defaultPerspective').andReturn(this.default);
spyOn(FocusedPerspectiveStore, '_setPerspective');
});
it('uses default perspective when no perspective has been saved', function() {
AppEnv.savedState.sidebarAccountIds = undefined;
AppEnv.savedState.perspective = undefined;
FocusedPerspectiveStore._initializeFromSavedState();
expect(FocusedPerspectiveStore._setPerspective).toHaveBeenCalledWith(
this.default,
this.default.accountIds
);
});
it('uses default if the saved perspective has account ids no longer present', function() {
AppEnv.savedState.sidebarAccountIds = [1, 2, 3];
AppEnv.savedState.perspective = {
accountIds: [1, 2, 3],
categories: () => [{ accountId: 1, id: 'A' }],
};
FocusedPerspectiveStore._initializeFromSavedState();
expect(FocusedPerspectiveStore._setPerspective).toHaveBeenCalledWith(
this.default,
this.default.accountIds
);
AppEnv.savedState.sidebarAccountIds = [1, 2, 3];
AppEnv.savedState.perspective = {
accountIds: [3],
categories: () => [{ accountId: 3, id: 'A' }],
};
FocusedPerspectiveStore._initializeFromSavedState();
expect(FocusedPerspectiveStore._setPerspective).toHaveBeenCalledWith(
this.default,
this.default.accountIds
);
});
it('uses default if the saved perspective has category ids no longer present', function() {
AppEnv.savedState.sidebarAccountIds = [2];
AppEnv.savedState.perspective = {
accountIds: [2],
categories: () => [{ accountId: 2, id: 'C' }],
};
FocusedPerspectiveStore._initializeFromSavedState();
expect(FocusedPerspectiveStore._setPerspective).toHaveBeenCalledWith(
this.default,
this.default.accountIds
);
});
it('does not honor sidebarAccountIds if it includes account ids no longer present', function() {
AppEnv.savedState.sidebarAccountIds = [1, 2, 3];
AppEnv.savedState.perspective = {
accountIds: [1],
categories: () => [{ accountId: 1, id: 'A' }],
};
FocusedPerspectiveStore._initializeFromSavedState();
expect(FocusedPerspectiveStore._setPerspective).toHaveBeenCalledWith(
AppEnv.savedState.perspective,
[1]
);
});
it('uses the saved perspective if it is still valid', function() {
AppEnv.savedState.sidebarAccountIds = [1, 2];
AppEnv.savedState.perspective = {
accountIds: [1, 2],
categories: () => [{ accountId: 1, id: 'A' }],
};
FocusedPerspectiveStore._initializeFromSavedState();
expect(FocusedPerspectiveStore._setPerspective).toHaveBeenCalledWith(
AppEnv.savedState.perspective,
[1, 2]
);
AppEnv.savedState.sidebarAccountIds = [1, 2];
AppEnv.savedState.perspective = {
accountIds: [1],
categories: () => [],
type: 'DraftsMailboxPerspective',
};
FocusedPerspectiveStore._initializeFromSavedState();
expect(FocusedPerspectiveStore._setPerspective).toHaveBeenCalledWith(
AppEnv.savedState.perspective,
[1, 2]
);
AppEnv.savedState.sidebarAccountIds = [1];
AppEnv.savedState.perspective = {
accountIds: [1],
categories: () => [],
type: 'DraftsMailboxPerspective',
};
FocusedPerspectiveStore._initializeFromSavedState();
expect(FocusedPerspectiveStore._setPerspective).toHaveBeenCalledWith(
AppEnv.savedState.perspective,
[1]
);
});
});
describe('_onCategoryStoreChanged', function() {
it("should try to initialize if the curernt perspective hasn't been fully initialized", function() {
spyOn(FocusedPerspectiveStore, '_initializeFromSavedState');
FocusedPerspectiveStore._current = this.inboxPerspective;
FocusedPerspectiveStore._initialized = true;
FocusedPerspectiveStore._onCategoryStoreChanged();
expect(FocusedPerspectiveStore._initializeFromSavedState).not.toHaveBeenCalled();
FocusedPerspectiveStore._current = MailboxPerspective.forNothing();
FocusedPerspectiveStore._initialized = false;
FocusedPerspectiveStore._onCategoryStoreChanged();
expect(FocusedPerspectiveStore._initializeFromSavedState).toHaveBeenCalled();
});
it('should set the current category to default when the current category no longer exists in the CategoryStore', function() {
const defaultPerspective = this.inboxPerspective;
FocusedPerspectiveStore._initialized = true;
spyOn(FocusedPerspectiveStore, '_defaultPerspective').andReturn(defaultPerspective);
const otherAccountInbox = this.inboxCategory.clone();
otherAccountInbox.id = 'other-id';
FocusedPerspectiveStore._current = MailboxPerspective.forCategory(otherAccountInbox);
FocusedPerspectiveStore._onCategoryStoreChanged();
expect(FocusedPerspectiveStore.current()).toEqual(defaultPerspective);
});
});
describe('_onFocusPerspective', () =>
it('should focus the category and trigger', function() {
FocusedPerspectiveStore._onFocusPerspective(this.userPerspective);
expect(FocusedPerspectiveStore.trigger).toHaveBeenCalled();
expect(FocusedPerspectiveStore.current().categories()).toEqual([this.userCategory]);
}));
describe('_setPerspective', () =>
it('should not trigger if the perspective is already focused', function() {
FocusedPerspectiveStore._setPerspective(this.inboxPerspective);
FocusedPerspectiveStore.trigger.reset();
FocusedPerspectiveStore._setPerspective(this.inboxPerspective);
expect(FocusedPerspectiveStore.trigger).not.toHaveBeenCalled();
}));
});