mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-06 08:08:10 +08:00
68b6d7df60
- When accounts changed and the saved perspective could reference accounts that no longer exist and cause all sorts of errors. This is fixed. - Add specs - Fixes some sentry errors
81 lines
3.8 KiB
CoffeeScript
81 lines
3.8 KiB
CoffeeScript
_ = require 'underscore'
|
|
|
|
Actions = require '../../src/flux/actions'
|
|
Category = require '../../src/flux/models/category'
|
|
MailboxPerspective = require '../../src/mailbox-perspective'
|
|
|
|
CategoryStore = require '../../src/flux/stores/category-store'
|
|
AccountStore = require '../../src/flux/stores/account-store'
|
|
FocusedPerspectiveStore = require '../../src/flux/stores/focused-perspective-store'
|
|
|
|
describe "FocusedPerspectiveStore", ->
|
|
beforeEach ->
|
|
spyOn(FocusedPerspectiveStore, 'trigger')
|
|
FocusedPerspectiveStore._perspective = null
|
|
@account = AccountStore.accounts()[0]
|
|
|
|
@inboxCategory = new Category(id: 'id-123', name: 'inbox', displayName: "INBOX", accountId: @account.id)
|
|
@inboxFilter = MailboxPerspective.forCategory(@inboxCategory)
|
|
@userCategory = new Category(id: 'id-456', name: null, displayName: "MyCategory", accountId: @account.id)
|
|
@userFilter = MailboxPerspective.forCategory(@userCategory)
|
|
|
|
spyOn(CategoryStore, "getStandardCategory").andReturn @inboxCategory
|
|
spyOn(CategoryStore, "byId").andCallFake (id) =>
|
|
return @inboxCategory if id is @inboxCategory.id
|
|
return @userCategory if id is @userCategory.id
|
|
return null
|
|
|
|
describe "_initCurrentPerspective", ->
|
|
beforeEach ->
|
|
@default = 'default'
|
|
@accounts = [{id: 1}, {id: 2}]
|
|
spyOn(MailboxPerspective, 'fromJSON').andCallFake (json) -> json
|
|
spyOn(FocusedPerspectiveStore, '_defaultPerspective').andReturn @default
|
|
|
|
it "uses default perspective when no perspective has been saved", ->
|
|
current = FocusedPerspectiveStore._initCurrentPerspective(undefined, @accounts)
|
|
expect(current).toEqual @default
|
|
|
|
it "uses default if saved perspective has more account ids not present in current accounts", ->
|
|
saved = {accountIds: [1,2,3]}
|
|
current = FocusedPerspectiveStore._initCurrentPerspective(saved, @accounts)
|
|
expect(current).toEqual @default
|
|
|
|
saved = {accountIds: [3]}
|
|
current = FocusedPerspectiveStore._initCurrentPerspective(saved, @accounts)
|
|
expect(current).toEqual @default
|
|
|
|
it "uses saved perspective if all accounts in saved perspective are present in the current accounts", ->
|
|
saved = {accountIds: [1,2]}
|
|
current = FocusedPerspectiveStore._initCurrentPerspective(saved, @accounts)
|
|
expect(current).toEqual saved
|
|
|
|
saved = {accountIds: [1]}
|
|
current = FocusedPerspectiveStore._initCurrentPerspective(saved, @accounts)
|
|
expect(current).toEqual saved
|
|
|
|
describe "_onCategoryStoreChanged", ->
|
|
it "should set the current category to Inbox when it is unset", ->
|
|
FocusedPerspectiveStore._perspective = null
|
|
FocusedPerspectiveStore._onCategoryStoreChanged()
|
|
expect(FocusedPerspectiveStore.current()).not.toBe(null)
|
|
expect(FocusedPerspectiveStore.current().categories()).toEqual([@inboxCategory])
|
|
|
|
it "should set the current category to Inbox when the current category no longer exists in the CategoryStore", ->
|
|
otherAccountInbox = @inboxCategory.clone()
|
|
otherAccountInbox.serverId = 'other-id'
|
|
FocusedPerspectiveStore._perspective = MailboxPerspective.forCategory(otherAccountInbox)
|
|
FocusedPerspectiveStore._onCategoryStoreChanged()
|
|
expect(FocusedPerspectiveStore.current().categories()).toEqual([@inboxCategory])
|
|
|
|
describe "_onFocusPerspective", ->
|
|
it "should focus the category and trigger", ->
|
|
FocusedPerspectiveStore._onFocusPerspective(@userFilter)
|
|
expect(FocusedPerspectiveStore.trigger).toHaveBeenCalled()
|
|
expect(FocusedPerspectiveStore.current().categories()).toEqual([@userCategory])
|
|
|
|
it "should do nothing if the category is already focused", ->
|
|
FocusedPerspectiveStore._onFocusPerspective(@inboxFilter)
|
|
spyOn(FocusedPerspectiveStore, '_setPerspective')
|
|
FocusedPerspectiveStore._onFocusPerspective(@inboxFilter)
|
|
expect(FocusedPerspectiveStore._setPerspective).not.toHaveBeenCalled()
|