123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347 |
- (function (root, factory) {
- define(["jasmine", "mock", "test-utils"], factory);
- } (this, function (jasmine, mock, test_utils) {
- const { Backbone, Promise, Strophe, $iq, $msg, $pres, b64_sha1, sizzle, _ } = converse.env;
- const u = converse.env.utils;
- describe("A list of open groupchats", function () {
- it("is shown in controlbox", mock.initConverse(
- null, ['rosterGroupsFetched', 'chatBoxesFetched'],
- { allow_bookmarks: false // Makes testing easier, otherwise we
- // have to mock stanza traffic.
- }, async function (done, _converse) {
- test_utils.openControlBox();
- const controlbox = _converse.chatboxviews.get('controlbox');
- let list = controlbox.el.querySelector('div.rooms-list-container');
- expect(_.includes(list.classList, 'hidden')).toBeTruthy();
- await test_utils.openChatRoom(_converse, 'room', 'conference.shakespeare.lit', 'JC');
- expect(_.isUndefined(_converse.rooms_list_view)).toBeFalsy();
- const lview = _converse.rooms_list_view
- await test_utils.waitUntil(() => lview.el.querySelectorAll(".open-room").length);
- let room_els = lview.el.querySelectorAll(".open-room");
- expect(room_els.length).toBe(1);
- expect(room_els[0].innerText).toBe('room@conference.shakespeare.lit');
- await test_utils.openChatRoom(_converse, 'lounge', 'montague.lit', 'romeo');
- await test_utils.waitUntil(() => lview.el.querySelectorAll(".open-room").length > 1);
- room_els = _converse.rooms_list_view.el.querySelectorAll(".open-room");
- expect(room_els.length).toBe(2);
- let view = _converse.chatboxviews.get('room@conference.shakespeare.lit');
- view.close();
- room_els = _converse.rooms_list_view.el.querySelectorAll(".open-room");
- expect(room_els.length).toBe(1);
- expect(room_els[0].innerText).toBe('lounge@montague.lit');
- list = controlbox.el.querySelector('div.rooms-list-container');
- test_utils.waitUntil(() => _.includes(list.classList, 'hidden'));
- view = _converse.chatboxviews.get('lounge@montague.lit');
- view.close();
- room_els = _converse.rooms_list_view.el.querySelectorAll(".open-room");
- expect(room_els.length).toBe(0);
- list = controlbox.el.querySelector('div.rooms-list-container');
- expect(_.includes(list.classList, 'hidden')).toBeTruthy();
- done();
- }
- ));
- it("uses bookmarks to determine groupchat names",
- mock.initConverse(
- {'connection': ['send']}, ['rosterGroupsFetched', 'chatBoxesFetched'], {'view_mode': 'fullscreen'},
- async function (done, _converse) {
- await test_utils.openAndEnterChatRoom(_converse, 'lounge', 'montague.lit', 'romeo');
- const view = _converse.chatboxviews.get('lounge@montague.lit');
- const contact_jid = 'newguy@montague.lit';
- let stanza = $pres({
- to: 'romeo@montague.lit/orchard',
- from: 'lounge@montague.lit/newguy'
- })
- .c('x', {xmlns: Strophe.NS.MUC_USER})
- .c('item', {
- 'affiliation': 'none',
- 'jid': 'newguy@montague.lit/_converse.js-290929789',
- 'role': 'participant'
- }).tree();
- _converse.connection._dataRecv(test_utils.createRequest(stanza));
- spyOn(_converse.Bookmarks.prototype, 'fetchBookmarks').and.callThrough();
- await test_utils.waitUntilDiscoConfirmed(
- _converse, _converse.bare_jid,
- [{'category': 'pubsub', 'type':'pep'}],
- [`${Strophe.NS.PUBSUB}#publish-options`]
- );
- const call = await test_utils.waitUntil(() =>
- _.filter(
- _converse.connection.send.calls.all(),
- c => sizzle('items[node="storage:bookmarks"]', c.args[0]).length
- ).pop()
- );
- expect(Strophe.serialize(call.args[0])).toBe(
- `<iq from="romeo@montague.lit/orchard" id="${call.args[0].getAttribute('id')}" type="get" xmlns="jabber:client">`+
- '<pubsub xmlns="http://jabber.org/protocol/pubsub">'+
- '<items node="storage:bookmarks"/>'+
- '</pubsub>'+
- '</iq>');
- stanza = $iq({'to': _converse.connection.jid, 'type':'result', 'id':call.args[0].getAttribute('id')})
- .c('pubsub', {'xmlns': Strophe.NS.PUBSUB})
- .c('items', {'node': 'storage:bookmarks'})
- .c('item', {'id': 'current'})
- .c('storage', {'xmlns': 'storage:bookmarks'})
- .c('conference', {
- 'name': 'Bookmarked Lounge',
- 'jid': 'lounge@montague.lit'
- });
- _converse.connection._dataRecv(test_utils.createRequest(stanza));
- await _converse.api.waitUntil('roomsListInitialized');
- const controlbox = _converse.chatboxviews.get('controlbox');
- const list = controlbox.el.querySelector('div.rooms-list-container');
- expect(_.includes(list.classList, 'hidden')).toBeFalsy();
- const items = list.querySelectorAll('.list-item');
- expect(items.length).toBe(1);
- expect(items[0].textContent.trim()).toBe('Bookmarked Lounge');
- expect(_converse.bookmarks.fetchBookmarks).toHaveBeenCalled();
- done();
- }));
- });
- describe("A groupchat shown in the groupchats list", function () {
- it("is highlighted if its currently open", mock.initConverse(
- null, ['rosterGroupsFetched', 'chatBoxesFetched'],
- { view_mode: 'fullscreen',
- allow_bookmarks: false // Makes testing easier, otherwise we have to mock stanza traffic.
- }, async function (done, _converse) {
- let item;
- await _converse.api.rooms.open('coven@chat.shakespeare.lit', {'nick': 'some1'});
- const lview = _converse.rooms_list_view
- await test_utils.waitUntil(() => lview.el.querySelectorAll(".open-room").length);
- let room_els = lview.el.querySelectorAll(".available-chatroom");
- expect(room_els.length).toBe(1);
- item = room_els[0];
- expect(u.hasClass('open', item)).toBe(true);
- expect(item.textContent.trim()).toBe('coven@chat.shakespeare.lit');
- await _converse.api.rooms.open('balcony@chat.shakespeare.lit', {'nick': 'some1'});
- await test_utils.waitUntil(() => lview.el.querySelectorAll(".open-room").length > 1);
- room_els = lview.el.querySelectorAll(".open-room");
- expect(room_els.length).toBe(2);
- room_els = lview.el.querySelectorAll(".available-chatroom.open");
- expect(room_els.length).toBe(1);
- item = room_els[0];
- expect(item.textContent.trim()).toBe('balcony@chat.shakespeare.lit');
- const conv_el = document.querySelector('#conversejs');
- conv_el.parentElement.removeChild(conv_el);
- done();
- }));
- it("has an info icon which opens a details modal when clicked", mock.initConverse(
- null, ['rosterGroupsFetched', 'chatBoxesFetched'],
- { whitelisted_plugins: ['converse-roomslist'],
- allow_bookmarks: false // Makes testing easier, otherwise we
- // have to mock stanza traffic.
- }, async function (done, _converse) {
- const IQ_stanzas = _converse.connection.IQ_stanzas;
- const room_jid = 'coven@chat.shakespeare.lit';
- test_utils.openControlBox();
- await _converse.api.rooms.open(room_jid, {'nick': 'some1'});
- const last_stanza = await test_utils.waitUntil(() => _.filter(
- IQ_stanzas,
- iq => iq.querySelector(
- `iq[to="${room_jid}"] query[xmlns="http://jabber.org/protocol/disco#info"]`
- )).pop());
- const view = _converse.chatboxviews.get(room_jid);
- const IQ_id = last_stanza.getAttribute('id');
- const features_stanza = $iq({
- 'from': 'coven@chat.shakespeare.lit',
- 'id': IQ_id,
- 'to': 'romeo@montague.lit/desktop',
- 'type': 'result'
- })
- .c('query', { 'xmlns': 'http://jabber.org/protocol/disco#info'})
- .c('identity', {
- 'category': 'conference',
- 'name': 'A Dark Cave',
- 'type': 'text'
- }).up()
- .c('feature', {'var': 'http://jabber.org/protocol/muc'}).up()
- .c('feature', {'var': 'muc_passwordprotected'}).up()
- .c('feature', {'var': 'muc_hidden'}).up()
- .c('feature', {'var': 'muc_temporary'}).up()
- .c('feature', {'var': 'muc_open'}).up()
- .c('feature', {'var': 'muc_unmoderated'}).up()
- .c('feature', {'var': 'muc_nonanonymous'}).up()
- .c('feature', {'var': 'urn:xmpp:mam:0'}).up()
- .c('x', { 'xmlns':'jabber:x:data', 'type':'result'})
- .c('field', {'var':'FORM_TYPE', 'type':'hidden'})
- .c('value').t('http://jabber.org/protocol/muc#roominfo').up().up()
- .c('field', {'type':'text-single', 'var':'muc#roominfo_description', 'label':'Description'})
- .c('value').t('This is the description').up().up()
- .c('field', {'type':'text-single', 'var':'muc#roominfo_occupants', 'label':'Number of occupants'})
- .c('value').t(0);
- _converse.connection._dataRecv(test_utils.createRequest(features_stanza));
- await test_utils.waitUntil(() => view.model.get('connection_status') === converse.ROOMSTATUS.CONNECTING)
- let presence = $pres({
- to: _converse.connection.jid,
- from: 'coven@chat.shakespeare.lit/some1',
- id: 'DC352437-C019-40EC-B590-AF29E879AF97'
- }).c('x').attrs({xmlns:'http://jabber.org/protocol/muc#user'})
- .c('item').attrs({
- affiliation: 'member',
- jid: _converse.bare_jid,
- role: 'participant'
- }).up()
- .c('status').attrs({code:'110'});
- _converse.connection._dataRecv(test_utils.createRequest(presence));
- const room_els = _converse.rooms_list_view.el.querySelectorAll(".open-room");
- expect(room_els.length).toBe(1);
- const info_el = _converse.rooms_list_view.el.querySelector(".room-info");
- info_el.click();
- const modal = view.model.room_details_modal;
- await test_utils.waitUntil(() => u.isVisible(modal.el), 1000);
- let els = modal.el.querySelectorAll('p.room-info');
- expect(els[0].textContent).toBe("Name: A Dark Cave")
- expect(els[1].textContent).toBe("Groupchat address (JID): coven@chat.shakespeare.lit")
- expect(els[2].textContent).toBe("Description: This is the description")
- expect(els[3].textContent).toBe("Online users: 1")
- const features_list = modal.el.querySelector('.features-list');
- expect(features_list.textContent.replace(/(\n|\s{2,})/g, '')).toBe(
- 'Password protected - This groupchat requires a password before entry'+
- 'Hidden - This groupchat is not publicly searchable'+
- 'Open - Anyone can join this groupchat'+
- 'Temporary - This groupchat will disappear once the last person leaves'+
- 'Not anonymous - All other groupchat participants can see your XMPP address'+
- 'Not moderated - Participants entering this groupchat can write right away'
- );
- presence = $pres({
- to: 'romeo@montague.lit/_converse.js-29092160',
- from: 'coven@chat.shakespeare.lit/newguy'
- })
- .c('x', {xmlns: Strophe.NS.MUC_USER})
- .c('item', {
- 'affiliation': 'none',
- 'jid': 'newguy@montague.lit/_converse.js-290929789',
- 'role': 'participant'
- });
- _converse.connection._dataRecv(test_utils.createRequest(presence));
- els = modal.el.querySelectorAll('p.room-info');
- expect(els[3].textContent).toBe("Online users: 2")
- view.model.set({'subject': {'author': 'someone', 'text': 'Hatching dark plots'}});
- els = modal.el.querySelectorAll('p.room-info');
- expect(els[0].textContent).toBe("Name: A Dark Cave")
- expect(els[1].textContent).toBe("Groupchat address (JID): coven@chat.shakespeare.lit")
- expect(els[2].textContent).toBe("Description: This is the description")
- expect(els[3].textContent).toBe("Topic: Hatching dark plots")
- expect(els[4].textContent).toBe("Topic author: someone")
- expect(els[5].textContent).toBe("Online users: 2")
- done();
- }));
- it("can be closed", mock.initConverse(
- null, ['rosterGroupsFetched'],
- { whitelisted_plugins: ['converse-roomslist'],
- allow_bookmarks: false // Makes testing easier, otherwise we have to mock stanza traffic.
- },
- async function (done, _converse) {
- spyOn(window, 'confirm').and.callFake(() => true);
- expect(_converse.chatboxes.length).toBe(1);
- await test_utils.openChatRoom(_converse, 'lounge', 'conference.shakespeare.lit', 'JC');
- expect(_converse.chatboxes.length).toBe(2);
- const lview = _converse.rooms_list_view
- await test_utils.waitUntil(() => lview.el.querySelectorAll(".open-room").length);
- let room_els = lview.el.querySelectorAll(".open-room");
- expect(room_els.length).toBe(1);
- const close_el = _converse.rooms_list_view.el.querySelector(".close-room");
- close_el.click();
- expect(window.confirm).toHaveBeenCalledWith(
- 'Are you sure you want to leave the groupchat lounge@conference.shakespeare.lit?');
- room_els = _converse.rooms_list_view.el.querySelectorAll(".open-room");
- expect(room_els.length).toBe(0);
- expect(_converse.chatboxes.length).toBe(1);
- done();
- }));
- it("shows unread messages directed at the user", mock.initConverse(
- null, null,
- { whitelisted_plugins: ['converse-roomslist'],
- allow_bookmarks: false // Makes testing easier, otherwise we have to mock stanza traffic.
- }, async (done, _converse) => {
- test_utils.openControlBox();
- const room_jid = 'kitchen@conference.shakespeare.lit';
- await test_utils.waitUntil(() => !_.isUndefined(_converse.rooms_list_view), 500);
- await test_utils.openAndEnterChatRoom(_converse, 'kitchen', 'conference.shakespeare.lit', 'romeo');
- const view = _converse.chatboxviews.get(room_jid);
- view.model.set({'minimized': true});
- const contact_jid = mock.cur_names[5].replace(/ /g,'.').toLowerCase() + '@montague.lit';
- const nick = mock.chatroom_names[0];
- await view.model.onMessage(
- $msg({
- from: room_jid+'/'+nick,
- id: (new Date()).getTime(),
- to: 'romeo@montague.lit',
- type: 'groupchat'
- }).c('body').t('foo').tree());
- const lview = _converse.rooms_list_view
- await test_utils.waitUntil(() => lview.el.querySelectorAll(".available-chatroom").length, 500);
- // If the user isn't mentioned, the counter doesn't get incremented, but the text of the groupchat is bold
- let room_el = lview.el.querySelector(".available-chatroom");
- expect(_.includes(room_el.classList, 'unread-msgs')).toBeTruthy();
- // If the user is mentioned, the counter also gets updated
- await view.model.onMessage(
- $msg({
- from: room_jid+'/'+nick,
- id: (new Date()).getTime(),
- to: 'romeo@montague.lit',
- type: 'groupchat'
- }).c('body').t('romeo: Your attention is required').tree()
- );
- await test_utils.waitUntil(() => _converse.rooms_list_view.el.querySelectorAll(".msgs-indicator").length);
- spyOn(view.model, 'incrementUnreadMsgCounter').and.callThrough();
- let indicator_el = _converse.rooms_list_view.el.querySelector(".msgs-indicator");
- expect(indicator_el.textContent).toBe('1');
- await view.model.onMessage(
- $msg({
- from: room_jid+'/'+nick,
- id: (new Date()).getTime(),
- to: 'romeo@montague.lit',
- type: 'groupchat'
- }).c('body').t('romeo: and another thing...').tree()
- );
- await test_utils.waitUntil(() => view.model.incrementUnreadMsgCounter.calls.count());
- indicator_el = _converse.rooms_list_view.el.querySelector(".msgs-indicator");
- expect(indicator_el.textContent).toBe('2');
- // When the chat gets maximized again, the unread indicators are removed
- view.model.set({'minimized': false});
- indicator_el = _converse.rooms_list_view.el.querySelector(".msgs-indicator");
- expect(_.isNull(indicator_el));
- room_el = _converse.rooms_list_view.el.querySelector(".available-chatroom");
- expect(_.includes(room_el.classList, 'unread-msgs')).toBeFalsy();
- done();
- }));
- });
- }));
|