Commit d1bf5b84 authored by JC Brand's avatar JC Brand

Add event emitter tests for chatrooms. Updates #48

parent 603087c3
...@@ -942,7 +942,6 @@ ...@@ -942,7 +942,6 @@
}, },
sendMessage: function (text) { sendMessage: function (text) {
converse.emit('onMessageSend', text);
var match = text.replace(/^\s*/, "").match(/^\/(.*)\s*$/), msgs; var match = text.replace(/^\s*/, "").match(/^\/(.*)\s*$/), msgs;
if (match) { if (match) {
if (match[1] === "clear") { if (match[1] === "clear") {
...@@ -995,6 +994,7 @@ ...@@ -995,6 +994,7 @@
} else { } else {
this.sendMessage(message); this.sendMessage(message);
} }
converse.emit('onMessageSend', message);
} }
this.$el.data('composing', false); this.$el.data('composing', false);
} else if (!this.model.get('chatroom')) { } else if (!this.model.get('chatroom')) {
...@@ -2241,12 +2241,17 @@ ...@@ -2241,12 +2241,17 @@
})); }));
} }
if (!body) { return true; } if (!body) { return true; }
this.showMessage($chat_content, var display_sender = sender === this.model.get('nick') && 'me' || 'room';
{'message': body, this.showMessage($chat_content, {
'sender': sender === this.model.get('nick') && 'me' || 'room', 'message': body,
'fullname': sender, 'sender': display_sender,
'time': converse.toISOString(message_datetime) 'fullname': sender,
}); 'time': converse.toISOString(message_datetime)
});
if (display_sender === 'room') {
// We only emit an event if it's not our own message
converse.emit('onMessage', message);
}
return true; return true;
}, },
......
...@@ -18,7 +18,6 @@ ...@@ -18,7 +18,6 @@
var chatroomview = this.chatboxesview.views['lounge@muc.localhost'], var chatroomview = this.chatboxesview.views['lounge@muc.localhost'],
$participant_list; $participant_list;
var roster = {}, room = {}, i; var roster = {}, room = {}, i;
for (i=0; i<mock.chatroom_names.length-1; i++) { for (i=0; i<mock.chatroom_names.length-1; i++) {
roster[mock.chatroom_names[i]] = {}; roster[mock.chatroom_names[i]] = {};
chatroomview.onChatRoomRoster(roster, room); chatroomview.onChatRoomRoster(roster, room);
...@@ -43,7 +42,8 @@ ...@@ -43,7 +42,8 @@
expect($(occupant).attr('title')).toBe('This user is a moderator'); expect($(occupant).attr('title')).toBe('This user is a moderator');
}, converse)); }, converse));
it("shows received and sent groupchat messages", $.proxy(function () { it("shows received groupchat messages", $.proxy(function () {
spyOn(converse, 'emit');
var view = this.chatboxesview.views['lounge@muc.localhost']; var view = this.chatboxesview.views['lounge@muc.localhost'];
if (!view.$el.find('.chat-area').length) { view.renderChatArea(); } if (!view.$el.find('.chat-area').length) { view.renderChatArea(); }
var nick = mock.chatroom_names[0]; var nick = mock.chatroom_names[0];
...@@ -58,6 +58,31 @@ ...@@ -58,6 +58,31 @@
var $chat_content = view.$el.find('.chat-content'); var $chat_content = view.$el.find('.chat-content');
expect($chat_content.find('.chat-message').length).toBe(1); expect($chat_content.find('.chat-message').length).toBe(1);
expect($chat_content.find('.chat-message-content').text()).toBe(text); expect($chat_content.find('.chat-message-content').text()).toBe(text);
expect(converse.emit).toHaveBeenCalledWith('onMessage', message.nodeTree);
}, converse));
it("shows sent groupchat messages", $.proxy(function () {
spyOn(converse, 'emit');
var view = this.chatboxesview.views['lounge@muc.localhost'];
if (!view.$el.find('.chat-area').length) { view.renderChatArea(); }
var nick = mock.chatroom_names[0];
var text = 'This is a sent message';
view.$el.find('.chat-textarea').text(text);
view.$el.find('textarea.chat-textarea').trigger($.Event('keypress', {keyCode: 13}));
expect(converse.emit).toHaveBeenCalledWith('onMessageSend', text);
var message = $msg({
from: 'lounge@muc.localhost/dummy',
id: '2',
to: 'dummy@localhost.com',
type: 'groupchat'
}).c('body').t(text);
view.onChatRoomMessage(message.nodeTree);
var $chat_content = view.$el.find('.chat-content');
expect($chat_content.find('.chat-message').length).toBe(1);
expect($chat_content.find('.chat-message-content').last().text()).toBe(text);
// We don't emit an event if it's our own message
expect(converse.emit.callCount, 1);
}, converse)); }, converse));
it("can be saved to, and retrieved from, localStorage", $.proxy(function () { it("can be saved to, and retrieved from, localStorage", $.proxy(function () {
...@@ -83,11 +108,13 @@ ...@@ -83,11 +108,13 @@
it("can be closed again by clicking a DOM element with class 'close-chatbox-button'", $.proxy(function () { it("can be closed again by clicking a DOM element with class 'close-chatbox-button'", $.proxy(function () {
var view = this.chatboxesview.views['lounge@muc.localhost'], chatroom = view.model, $el; var view = this.chatboxesview.views['lounge@muc.localhost'], chatroom = view.model, $el;
spyOn(view, 'closeChat').andCallThrough(); spyOn(view, 'closeChat').andCallThrough();
spyOn(converse, 'emit');
spyOn(converse.connection.muc, 'leave'); spyOn(converse.connection.muc, 'leave');
view.delegateEvents(); // We need to rebind all events otherwise our spy won't be called view.delegateEvents(); // We need to rebind all events otherwise our spy won't be called
view.$el.find('.close-chatbox-button').click(); view.$el.find('.close-chatbox-button').click();
expect(view.closeChat).toHaveBeenCalled(); expect(view.closeChat).toHaveBeenCalled();
expect(converse.connection.muc.leave).toHaveBeenCalled(); expect(converse.connection.muc.leave).toHaveBeenCalled();
expect(converse.emit).toHaveBeenCalledWith('onChatBoxClosed', jasmine.any(Object));
}, converse)); }, converse));
}, converse)); }, converse));
......
...@@ -34,7 +34,8 @@ ...@@ -34,7 +34,8 @@
'listRooms': function () {}, 'listRooms': function () {},
'join': function () {}, 'join': function () {},
'leave': function () {}, 'leave': function () {},
'rooms': {} 'rooms': {},
'groupchat': function () {}
}, },
'service': 'jasmine tests', 'service': 'jasmine tests',
'jid': 'dummy@localhost', 'jid': 'dummy@localhost',
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment