Mailspring/app/spec/models/thread-spec.coffee

69 lines
3.6 KiB
CoffeeScript

Message = require('../../src/flux/models/message').default
Thread = require('../../src/flux/models/thread').default
Folder = require('../../src/flux/models/folder').default
{Utils} = require 'mailspring-exports'
_ = require 'underscore'
describe 'Thread', ->
describe 'serialization performance', ->
xit '1,000,000 iterations', ->
iterations = 0
json = '[{"client_id":"local-76c370af-65de","server_id":"f0vkowp7zxt7djue7ifylb940","__cls":"Thread","account_id":"1r6w6qiq3sb0o9fiwin6v87dd","snippet":"http://itunestandc.tumblr.com/tagged/itunes-terms-and-conditions/chrono _______________________________________________ http://www.macgroup.com/mailman/listinfo/smartfriends-chat","subject":"iTunes Terms And Conditions as you\'ve never seen them before","unread":true,"starred":false,"version":1,"folders":[],"labels":[{"server_id":"8cf4fn20k9pjjhjawrv3xrxo0","name":"all","display_name":"All Mail","id":"8cf4fn20k9pjjhjawrv3xrxo0"},{"server_id":"f1lq8faw8vv06m67y8f3xdf84","name":"inbox","display_name":"Inbox","id":"f1lq8faw8vv06m67y8f3xdf84"}],"participants":[{"name":"Andrew Stadler","email":"stadler@gmail.com","thirdPartyData":{}},{"name":"Smart Friends™ Chat","email":"smartfriends-chat@macgroup.com","thirdPartyData":{}}],"has_attachments":false,"lastMessageReceivedTimestamp":1446600615,"id":"f0vkowp7zxt7djue7ifylb940"}]'
start = Date.now()
while iterations < 1000000
if _.isString(json)
data = JSON.parse(json)
object = new Thread()
object.fromJSON(data)
object
iterations += 1
console.log((Date.now() - start) / 1000.0 + "ms per 1000")
describe 'sortedCategories', ->
sortedForCategoryNames = (inputs) ->
categories = inputs.map((i) ->
new Folder(path: i, role: i)
)
thread = new Thread(labels: categories, folders: [])
return thread.sortedCategories()
it "puts 'important' label first, if it's present", ->
inputs = ['alphabetically before important', 'important']
actualOut = sortedForCategoryNames inputs
expect(actualOut[0].displayName).toBe 'important'
it "ignores 'important' label if not present", ->
inputs = ['not important']
actualOut = sortedForCategoryNames inputs
expect(actualOut.length).toBe 1
expect(actualOut[0].displayName).toBe 'not important'
it "doesn't display 'all', 'archive', or 'drafts'", ->
inputs = ['all', 'archive', 'drafts']
actualOut = sortedForCategoryNames inputs
expect(actualOut.length).toBe 0
it "displays standard category names which aren't hidden next, if they're present", ->
inputs = ['inbox', 'important', 'social']
actualOut = _.pluck sortedForCategoryNames(inputs), 'displayName'
expectedOut = ['important', 'inbox', 'social']
expect(actualOut).toEqual expectedOut
it "ignores standard category names if they aren't present", ->
inputs = ['social', 'work', 'important']
actualOut = _.pluck sortedForCategoryNames(inputs), 'displayName'
expectedOut = ['important', 'social', 'work']
expect(actualOut).toEqual expectedOut
it "puts user-added categories at the end", ->
inputs = ['food', 'inbox']
actualOut = _.pluck sortedForCategoryNames(inputs), 'displayName'
expectedOut = ['inbox', 'food']
expect(actualOut).toEqual expectedOut
it "sorts user-added categories by displayName", ->
inputs = ['work', 'social', 'receipts', 'important', 'inbox']
actualOut = _.pluck sortedForCategoryNames(inputs), 'displayName'
expectedOut = ['important', 'inbox', 'receipts', 'social', 'work']
expect(actualOut).toEqual expectedOut