Commit f2c14557 authored by JC Brand's avatar JC Brand

Bump waiting time for room opened via modal in test utils

Convert more promise-based tests to async/await
parent 0d3e94c6
...@@ -3197,189 +3197,185 @@ ...@@ -3197,189 +3197,185 @@
it("will use the nickname set in the global settings if the user doesn't have a VCard nickname", it("will use the nickname set in the global settings if the user doesn't have a VCard nickname",
mock.initConverseWithPromises( mock.initConverseWithPromises(
null, ['rosterGroupsFetched', 'chatBoxesFetched'], {'nickname': 'Benedict-Cucumberpatch'}, null, ['rosterGroupsFetched', 'chatBoxesFetched'], {'nickname': 'Benedict-Cucumberpatch'},
function (done, _converse) { async function (done, _converse) {
test_utils.openChatRoomViaModal(_converse, 'problematic@muc.localhost') await test_utils.openChatRoomViaModal(_converse, 'roomy@muc.localhost');
.then(function () { const view = _converse.chatboxviews.get('roomy@muc.localhost');
const view = _converse.chatboxviews.get('problematic@muc.localhost'); expect(view.model.get('nick')).toBe('Benedict-Cucumberpatch');
expect(view.model.get('nick')).toBe('Benedict-Cucumberpatch'); done();
done();
}).catch(_.partial(console.error, _));
})); }));
it("will show an error message if the groupchat requires a password", it("will show an error message if the groupchat requires a password",
mock.initConverseWithPromises( mock.initConverseWithPromises(
null, ['rosterGroupsFetched', 'chatBoxesFetched'], {}, null, ['rosterGroupsFetched', 'chatBoxesFetched'], {},
function (done, _converse) { async function (done, _converse) {
test_utils.openChatRoomViaModal(_converse, 'problematic@muc.localhost', 'dummy')
.then(function () {
var view = _converse.chatboxviews.get('problematic@muc.localhost');
spyOn(view, 'renderPasswordForm').and.callThrough();
var presence = $pres().attrs({ const groupchat_jid = 'protected';
from:'problematic@muc.localhost/dummy', await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy');
id:'n13mt3l', const view = _converse.chatboxviews.get(groupchat_jid);
to:'dummy@localhost/pda', spyOn(view, 'renderPasswordForm').and.callThrough();
type:'error'})
.c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({by:'lounge@localhost', type:'auth'})
.c('not-authorized').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'});
_converse.connection._dataRecv(test_utils.createRequest(presence)); var presence = $pres().attrs({
'from': `${groupchat_jid}/dummy`,
'id': u.getUniqueId(),
'to': 'dummy@localhost/pda',
'type': 'error'
}).c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({by:'lounge@localhost', type:'auth'})
.c('not-authorized').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'});
var chat_body = view.el.querySelector('.chatroom-body'); _converse.connection._dataRecv(test_utils.createRequest(presence));
expect(view.renderPasswordForm).toHaveBeenCalled();
expect(chat_body.querySelectorAll('form.chatroom-form').length).toBe(1);
expect(chat_body.querySelector('legend').textContent)
.toBe('This groupchat requires a password');
// Let's submit the form const chat_body = view.el.querySelector('.chatroom-body');
spyOn(view, 'join'); expect(view.renderPasswordForm).toHaveBeenCalled();
var input_el = view.el.querySelector('[name="password"]'); expect(chat_body.querySelectorAll('form.chatroom-form').length).toBe(1);
input_el.value = 'secret'; expect(chat_body.querySelector('legend').textContent)
view.el.querySelector('input[type=submit]').click(); .toBe('This groupchat requires a password');
expect(view.join).toHaveBeenCalledWith('dummy', 'secret');
done(); // Let's submit the form
}).catch(_.partial(console.error, _)); spyOn(view, 'join');
const input_el = view.el.querySelector('[name="password"]');
input_el.value = 'secret';
view.el.querySelector('input[type=submit]').click();
expect(view.join).toHaveBeenCalledWith('dummy', 'secret');
done();
})); }));
it("will show an error message if the groupchat is members-only and the user not included", it("will show an error message if the groupchat is members-only and the user not included",
mock.initConverseWithPromises( mock.initConverseWithPromises(
null, ['rosterGroupsFetched'], {}, null, ['rosterGroupsFetched'], {},
function (done, _converse) { async function (done, _converse) {
test_utils.openChatRoomViaModal(_converse, 'problematic@muc.localhost', 'dummy') const groupchat_jid = 'members-only@muc.localhost'
.then(function () { await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy');
var presence = $pres().attrs({ const presence = $pres().attrs({
from:'problematic@muc.localhost/dummy', from: `${groupchat_jid}/dummy`,
id:'n13mt3l', id: u.getUniqueId(),
to:'dummy@localhost/pda', to: 'dummy@localhost/pda',
type:'error'}) type: 'error'
.c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up() }).c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({by:'lounge@localhost', type:'auth'}) .c('error').attrs({by:'lounge@localhost', type:'auth'})
.c('registration-required').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree; .c('registration-required').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
var view = _converse.chatboxviews.get('problematic@muc.localhost');
spyOn(view, 'showErrorMessage').and.callThrough(); const view = _converse.chatboxviews.get(groupchat_jid);
_converse.connection._dataRecv(test_utils.createRequest(presence)); spyOn(view, 'showErrorMessage').and.callThrough();
expect(view.el.querySelector('.chatroom-body .disconnect-container .disconnect-msg:last-child').textContent) _converse.connection._dataRecv(test_utils.createRequest(presence));
.toBe('You are not on the member list of this groupchat.'); expect(view.el.querySelector('.chatroom-body .disconnect-container .disconnect-msg:last-child').textContent)
done(); .toBe('You are not on the member list of this groupchat.');
}).catch(_.partial(console.error, _)); done();
})); }));
it("will show an error message if the user has been banned", it("will show an error message if the user has been banned",
mock.initConverseWithPromises( mock.initConverseWithPromises(
null, ['rosterGroupsFetched'], {}, null, ['rosterGroupsFetched'], {},
function (done, _converse) { async function (done, _converse) {
test_utils.openChatRoomViaModal(_converse, 'problematic@muc.localhost', 'dummy') const groupchat_jid = 'off-limits@muc.localhost'
.then(function () { await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy');
var presence = $pres().attrs({ const presence = $pres().attrs({
from:'problematic@muc.localhost/dummy', from: `${groupchat_jid}/dummy`,
id:'n13mt3l', id: u.getUniqueId(),
to:'dummy@localhost/pda', to: 'dummy@localhost/pda',
type:'error'}) type: 'error'
.c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up() }).c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({by:'lounge@localhost', type:'auth'}) .c('error').attrs({by:'lounge@localhost', type:'auth'})
.c('forbidden').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree; .c('forbidden').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
var view = _converse.chatboxviews.get('problematic@muc.localhost');
spyOn(view, 'showErrorMessage').and.callThrough(); const view = _converse.chatboxviews.get(groupchat_jid);
_converse.connection._dataRecv(test_utils.createRequest(presence)); spyOn(view, 'showErrorMessage').and.callThrough();
expect(view.el.querySelector('.chatroom-body .disconnect-container .disconnect-msg:last-child').textContent) _converse.connection._dataRecv(test_utils.createRequest(presence));
.toBe('You have been banned from this groupchat.'); expect(view.el.querySelector('.chatroom-body .disconnect-container .disconnect-msg:last-child').textContent)
done(); .toBe('You have been banned from this groupchat.');
}).catch(_.partial(console.error, _)); done();
})); }));
it("will render a nickname form if a nickname conflict happens and muc_nickname_from_jid=false", it("will render a nickname form if a nickname conflict happens and muc_nickname_from_jid=false",
mock.initConverseWithPromises( mock.initConverseWithPromises(
null, ['rosterGroupsFetched'], {}, null, ['rosterGroupsFetched'], {},
function (done, _converse) { async function (done, _converse) {
test_utils.openChatRoomViaModal(_converse, 'problematic@muc.localhost', 'dummy') const groupchat_jid = 'conflicted@muc.localhost';
.then(function () { await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy');
var presence = $pres().attrs({ var presence = $pres().attrs({
from:'problematic@muc.localhost/dummy', from: `${groupchat_jid}/dummy`,
id:'n13mt3l', id: u.getUniqueId(),
to:'dummy@localhost/pda', to: 'dummy@localhost/pda',
type:'error'}) type: 'error'
.c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up() }).c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({by:'lounge@localhost', type:'cancel'}) .c('error').attrs({by:'lounge@localhost', type:'cancel'})
.c('conflict').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree; .c('conflict').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
var view = _converse.chatboxviews.get('problematic@muc.localhost');
spyOn(view, 'showErrorMessage').and.callThrough();
_converse.connection._dataRecv(test_utils.createRequest(presence));
expect(sizzle('.chatroom-body form.chatroom-form label:first', view.el).pop().textContent)
.toBe('Please choose your nickname');
const input = sizzle('.chatroom-body form.chatroom-form input:first', view.el).pop(); const view = _converse.chatboxviews.get(groupchat_jid);
input.value = 'nicky'; spyOn(view, 'showErrorMessage').and.callThrough();
view.el.querySelector('input[type=submit]').click(); _converse.connection._dataRecv(test_utils.createRequest(presence));
done(); expect(sizzle('.chatroom-body form.chatroom-form label:first', view.el).pop().textContent)
}).catch(_.partial(console.error, _)); .toBe('Please choose your nickname');
const input = sizzle('.chatroom-body form.chatroom-form input:first', view.el).pop();
input.value = 'nicky';
view.el.querySelector('input[type=submit]').click();
done();
})); }));
it("will automatically choose a new nickname if a nickname conflict happens and muc_nickname_from_jid=true", it("will automatically choose a new nickname if a nickname conflict happens and muc_nickname_from_jid=true",
mock.initConverseWithPromises( mock.initConverseWithPromises(
null, ['rosterGroupsFetched'], {}, null, ['rosterGroupsFetched'], {},
function (done, _converse) { async function (done, _converse) {
test_utils.openChatRoomViaModal(_converse, 'problematic@muc.localhost', 'dummy') const groupchat_jid = 'conflicting@muc.localhost'
.then(function () { await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy');
/* <presence /* <presence
* from='coven@chat.shakespeare.lit/thirdwitch' * from='coven@chat.shakespeare.lit/thirdwitch'
* id='n13mt3l' * id='n13mt3l'
* to='hag66@shakespeare.lit/pda' * to='hag66@shakespeare.lit/pda'
* type='error'> * type='error'>
* <x xmlns='http://jabber.org/protocol/muc'/> * <x xmlns='http://jabber.org/protocol/muc'/>
* <error by='coven@chat.shakespeare.lit' type='cancel'> * <error by='coven@chat.shakespeare.lit' type='cancel'>
* <conflict xmlns='urn:ietf:params:xml:ns:xmpp-stanzas'/> * <conflict xmlns='urn:ietf:params:xml:ns:xmpp-stanzas'/>
* </error> * </error>
* </presence> * </presence>
*/ */
_converse.muc_nickname_from_jid = true; _converse.muc_nickname_from_jid = true;
const attrs = {
'from': `${groupchat_jid}/dummy`,
'id': u.getUniqueId(),
'to': 'dummy@localhost/pda',
'type': 'error'
};
let presence = $pres().attrs(attrs)
.c('x').attrs({'xmlns':'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({'by': groupchat_jid, 'type':'cancel'})
.c('conflict').attrs({'xmlns':'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
var attrs = { const view = _converse.chatboxviews.get(groupchat_jid);
from:'problematic@muc.localhost/dummy', spyOn(view, 'showErrorMessage').and.callThrough();
to:'dummy@localhost/pda', spyOn(view, 'join').and.callThrough();
type:'error'
};
attrs.id = new Date().getTime();
var presence = $pres().attrs(attrs)
.c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({by:'problematic@muc.localhost', type:'cancel'})
.c('conflict').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
var view = _converse.chatboxviews.get('problematic@muc.localhost');
spyOn(view, 'showErrorMessage').and.callThrough();
spyOn(view, 'join').and.callThrough();
// Simulate repeatedly that there's already someone in the groupchat // Simulate repeatedly that there's already someone in the groupchat
// with that nickname // with that nickname
_converse.connection._dataRecv(test_utils.createRequest(presence)); _converse.connection._dataRecv(test_utils.createRequest(presence));
expect(view.join).toHaveBeenCalledWith('dummy-2'); expect(view.join).toHaveBeenCalledWith('dummy-2');
attrs.from = 'problematic@muc.localhost/dummy-2';
attrs.id = new Date().getTime();
presence = $pres().attrs(attrs)
.c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({by:'problematic@muc.localhost', type:'cancel'})
.c('conflict').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
_converse.connection._dataRecv(test_utils.createRequest(presence));
expect(view.join).toHaveBeenCalledWith('dummy-3'); attrs.from = `${groupchat_jid}/dummy-2`;
attrs.id = u.getUniqueId();
presence = $pres().attrs(attrs)
.c('x').attrs({'xmlns':'http://jabber.org/protocol/muc'}).up()
.c('error').attrs({'by': groupchat_jid, type:'cancel'})
.c('conflict').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
_converse.connection._dataRecv(test_utils.createRequest(presence));
attrs.from = 'problematic@muc.localhost/dummy-3'; expect(view.join).toHaveBeenCalledWith('dummy-3');
attrs.id = new Date().getTime();
presence = $pres().attrs(attrs) attrs.from = `${groupchat_jid}/dummy-3`;
.c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up() attrs.id = new Date().getTime();
.c('error').attrs({by:'problematic@muc.localhost', type:'cancel'}) presence = $pres().attrs(attrs)
.c('conflict').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree; .c('x').attrs({'xmlns': 'http://jabber.org/protocol/muc'}).up()
_converse.connection._dataRecv(test_utils.createRequest(presence)); .c('error').attrs({'by': groupchat_jid, 'type': 'cancel'})
expect(view.join).toHaveBeenCalledWith('dummy-4'); .c('conflict').attrs({'xmlns':'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
done(); _converse.connection._dataRecv(test_utils.createRequest(presence));
}).catch(_.partial(console.error, _)); expect(view.join).toHaveBeenCalledWith('dummy-4');
done();
})); }));
it("will show an error message if the user is not allowed to have created the groupchat", it("will show an error message if the user is not allowed to have created the groupchat",
...@@ -3391,7 +3387,7 @@ ...@@ -3391,7 +3387,7 @@
await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy') await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy')
var presence = $pres().attrs({ var presence = $pres().attrs({
from: `${groupchat_jid}/dummy`, from: `${groupchat_jid}/dummy`,
id:'n13mt3l', id: u.getUniqueId(),
to:'dummy@localhost/pda', to:'dummy@localhost/pda',
type:'error' type:'error'
}).c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up() }).c('x').attrs({xmlns:'http://jabber.org/protocol/muc'}).up()
...@@ -3412,7 +3408,7 @@ ...@@ -3412,7 +3408,7 @@
const groupchat_jid = 'conformist@muc.localhost' const groupchat_jid = 'conformist@muc.localhost'
await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy'); await test_utils.openChatRoomViaModal(_converse, groupchat_jid, 'dummy');
var presence = $pres().attrs({ const presence = $pres().attrs({
from: `${groupchat_jid}/dummy`, from: `${groupchat_jid}/dummy`,
id: u.getUniqueId(), id: u.getUniqueId(),
to:'dummy@localhost/pda', to:'dummy@localhost/pda',
...@@ -3421,7 +3417,7 @@ ...@@ -3421,7 +3417,7 @@
.c('error').attrs({by:'lounge@localhost', type:'cancel'}) .c('error').attrs({by:'lounge@localhost', type:'cancel'})
.c('not-acceptable').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree; .c('not-acceptable').attrs({xmlns:'urn:ietf:params:xml:ns:xmpp-stanzas'}).nodeTree;
var view = _converse.chatboxviews.get(groupchat_jid); const view = _converse.chatboxviews.get(groupchat_jid);
spyOn(view, 'showErrorMessage').and.callThrough(); spyOn(view, 'showErrorMessage').and.callThrough();
_converse.connection._dataRecv(test_utils.createRequest(presence)); _converse.connection._dataRecv(test_utils.createRequest(presence));
expect(view.el.querySelector('.chatroom-body .disconnect-container .disconnect-msg:last-child').textContent) expect(view.el.querySelector('.chatroom-body .disconnect-container .disconnect-msg:last-child').textContent)
......
...@@ -101,22 +101,17 @@ ...@@ -101,22 +101,17 @@
return utils.waitUntil(() => _converse.chatboxviews.get(jid), 1000); return utils.waitUntil(() => _converse.chatboxviews.get(jid), 1000);
}; };
utils.openChatRoomViaModal = function (_converse, jid, nick='') { utils.openChatRoomViaModal = async function (_converse, jid, nick='') {
// Opens a new chatroom // Opens a new chatroom
return new Promise(function (resolve, reject) { utils.openControlBox(_converse);
utils.openControlBox(_converse); const roomspanel = _converse.chatboxviews.get('controlbox').roomspanel;
const roomspanel = _converse.chatboxviews.get('controlbox').roomspanel; roomspanel.el.querySelector('.show-add-muc-modal').click();
roomspanel.el.querySelector('.show-add-muc-modal').click(); utils.closeControlBox(_converse);
utils.closeControlBox(_converse); const modal = roomspanel.add_room_modal;
const modal = roomspanel.add_room_modal; await utils.waitUntil(() => u.isVisible(modal.el), 1500)
utils.waitUntil(() => u.isVisible(modal.el), 1000) modal.el.querySelector('input[name="chatroom"]').value = jid;
.then(() => { modal.el.querySelector('input[name="nickname"]').value = nick;
modal.el.querySelector('input[name="chatroom"]').value = jid; modal.el.querySelector('form input[type="submit"]').click();
modal.el.querySelector('input[name="nickname"]').value = nick;
modal.el.querySelector('form input[type="submit"]').click();
resolve();
});
}).catch(_.partial(console.error, _));
}; };
utils.openChatRoom = function (_converse, room, server, nick) { utils.openChatRoom = function (_converse, room, server, nick) {
......
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