describe('MessageView', function() { var conversations = new Whisper.ConversationCollection(); before(function(done) { conversations.fetch().then(done); storage.put('number_id', '+18088888888.1'); }); var convo = conversations.add({id: 'foo'}); var message = convo.messageCollection.add({ conversationId: convo.id, body: 'hello world', type: 'outgoing', source: '+14158675309', received_at: Date.now() }); it('should display the message text', function() { var view = new Whisper.MessageView({model: message}).render(); assert.match(view.$el.text(), /hello world/); }); it('should auto-update the message text', function() { var view = new Whisper.MessageView({model: message}).render(); message.set('body', 'goodbye world'); assert.match(view.$el.html(), /goodbye world/); }); it('should have a nice timestamp', function() { var view = new Whisper.MessageView({model: message}); message.set({'sent_at': Date.now() - 5000}); view.render(); assert.match(view.$el.html(), /seconds ago/); message.set({'sent_at': Date.now() - 60000}); view.render(); assert.match(view.$el.html(), /minute ago/); message.set({'sent_at': Date.now() - 3600000}); view.render(); assert.match(view.$el.html(), /hour ago/); }); it('should not imply messages are from the future', function() { var view = new Whisper.MessageView({model: message}); message.set({'sent_at': Date.now() + 60000}); view.render(); assert.match(view.$el.html(), /seconds ago/); }); it('should go away when the model is destroyed', function() { var view = new Whisper.MessageView({model: message}); var div = $('