2014-09-01 20:52:58 +02:00
|
|
|
describe('MessageView', function() {
|
2014-11-17 01:01:28 +01:00
|
|
|
var conversations = new Whisper.ConversationCollection();
|
2014-11-13 23:35:37 +01:00
|
|
|
before(function(done) {
|
2014-11-17 01:01:28 +01:00
|
|
|
conversations.fetch().then(done);
|
2014-11-13 23:35:37 +01:00
|
|
|
});
|
|
|
|
|
2014-11-17 01:01:28 +01:00
|
|
|
var convo = conversations.add({id: 'foo'});
|
2014-11-21 01:30:52 +01:00
|
|
|
var message = convo.messageCollection.add({
|
2014-11-13 23:35:37 +01:00
|
|
|
conversationId: convo.id,
|
2014-09-01 20:52:58 +02:00
|
|
|
body: 'hello world',
|
|
|
|
type: 'outgoing',
|
2014-12-17 02:23:04 +01:00
|
|
|
received_at: new Date().getTime()
|
2014-09-01 20:52:58 +02:00
|
|
|
});
|
|
|
|
|
2014-09-04 09:25:08 +02:00
|
|
|
it('should display the message text', function() {
|
2014-11-21 01:30:52 +01:00
|
|
|
var view = new Whisper.MessageView({model: message}).render();
|
|
|
|
assert.match(view.$el.text(), /hello world/);
|
2014-09-04 09:25:08 +02:00
|
|
|
});
|
2014-09-01 20:52:58 +02:00
|
|
|
|
2014-09-04 09:25:08 +02:00
|
|
|
it('should auto-update the message text', function() {
|
2014-11-21 01:30:52 +01:00
|
|
|
var view = new Whisper.MessageView({model: message}).render();
|
2014-09-04 09:25:08 +02:00
|
|
|
message.set('body', 'goodbye world');
|
|
|
|
assert.match(view.$el.html(), /goodbye world/);
|
|
|
|
});
|
2014-09-01 20:52:58 +02:00
|
|
|
|
2014-11-11 09:35:18 +01:00
|
|
|
it('should have a nice timestamp', function() {
|
|
|
|
var view = new Whisper.MessageView({model: message});
|
2014-12-17 02:23:04 +01:00
|
|
|
message.set({'received_at': new Date().getTime() - 5000});
|
2015-03-06 01:51:53 +01:00
|
|
|
view.render();
|
2014-11-11 09:35:18 +01:00
|
|
|
assert.match(view.$el.html(), /seconds ago/);
|
|
|
|
|
2014-12-17 02:23:04 +01:00
|
|
|
message.set({'received_at': new Date().getTime() - 60000});
|
2015-03-06 01:51:53 +01:00
|
|
|
view.render();
|
2014-11-11 09:35:18 +01:00
|
|
|
assert.match(view.$el.html(), /minute ago/);
|
|
|
|
|
2014-12-17 02:23:04 +01:00
|
|
|
message.set({'received_at': new Date().getTime() - 3600000});
|
2015-03-06 01:51:53 +01:00
|
|
|
view.render();
|
2014-11-11 09:35:18 +01:00
|
|
|
assert.match(view.$el.html(), /hour ago/);
|
|
|
|
});
|
|
|
|
|
2014-09-04 09:25:08 +02:00
|
|
|
it('should go away when the model is destroyed', function() {
|
|
|
|
var view = new Whisper.MessageView({model: message});
|
|
|
|
var div = $('<div>').append(view.$el);
|
|
|
|
message.destroy();
|
|
|
|
assert.strictEqual(div.find(view.$el).length, 0);
|
2014-09-01 20:52:58 +02:00
|
|
|
});
|
2015-03-07 02:01:04 +01:00
|
|
|
|
|
|
|
it('allows links', function() {
|
|
|
|
var url = 'http://example.com';
|
|
|
|
message.set('body', url);
|
|
|
|
var view = new Whisper.MessageView({model: message});
|
|
|
|
view.render();
|
|
|
|
var link = view.$el.find('.content a');
|
|
|
|
assert.strictEqual(link.length, 1);
|
|
|
|
assert.strictEqual(link.text(), url);
|
|
|
|
assert.strictEqual(link.attr('href'), url);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('disallows xss', function() {
|
|
|
|
var xss = '<script>alert("pwnd")</script>';
|
|
|
|
message.set('body', xss);
|
|
|
|
var view = new Whisper.MessageView({model: message});
|
|
|
|
view.render();
|
|
|
|
assert.include(view.$el.text(), xss); // should appear as escaped text
|
|
|
|
assert.strictEqual(view.$el.find('script').length, 0); // should not appear as html
|
|
|
|
});
|
2015-03-10 20:11:32 +01:00
|
|
|
|
|
|
|
it('supports twemoji', function() {
|
|
|
|
message.set('body', 'I \u2764\uFE0F emoji!');
|
|
|
|
var view = new Whisper.MessageView({model: message});
|
|
|
|
view.render();
|
|
|
|
var img = view.$el.find('.content img');
|
|
|
|
assert.strictEqual(img.length, 1);
|
2015-03-20 00:46:58 +01:00
|
|
|
assert.strictEqual(img.attr('src'), '/images/twemoji/16x16/2764.png');
|
2015-03-10 20:11:32 +01:00
|
|
|
assert.strictEqual(img.attr('alt'), '\u2764\uFE0F');
|
|
|
|
assert.strictEqual(img.attr('class'), 'emoji');
|
|
|
|
});
|
2014-09-01 20:52:58 +02:00
|
|
|
});
|