Fix race conditions in tests

This commit is contained in:
JC Brand 2021-08-31 10:55:24 +02:00
parent b4d00f86a8
commit 6827e21df1
2 changed files with 17 additions and 20 deletions

View File

@ -103,7 +103,7 @@ describe("The Controlbox", function () {
await u.waitUntil(() => el.querySelector('.restore-chat .message-count')?.textContent === '2'); await u.waitUntil(() => el.querySelector('.restore-chat .message-count')?.textContent === '2');
expect(rosterview.querySelector('.msgs-indicator').textContent).toBe('2'); expect(rosterview.querySelector('.msgs-indicator').textContent).toBe('2');
chatview.model.set({'minimized': false}); chatview.model.set({'minimized': false});
expect(el.querySelector('.restore-chat .message-count')).toBe(null); await u.waitUntil(() => el.querySelector('.restore-chat .message-count') === null);
await u.waitUntil(() => rosterview.querySelector('.msgs-indicator') === null); await u.waitUntil(() => rosterview.querySelector('.msgs-indicator') === null);
})); }));
}); });

View File

@ -109,11 +109,9 @@ describe("A Chatbox", function () {
expect(_converse.api.trigger.calls.count(), 2); expect(_converse.api.trigger.calls.count(), 2);
expect(u.isVisible(chatview)).toBeFalsy(); expect(u.isVisible(chatview)).toBeFalsy();
expect(chatview.model.get('minimized')).toBeTruthy(); expect(chatview.model.get('minimized')).toBeTruthy();
document.querySelector('converse-minimized-chat').click(); const restore_el = await u.waitUntil(() => document.querySelector("converse-minimized-chat a.restore-chat"));
restore_el.click();
await u.waitUntil(() => _converse.chatboxviews.keys().length); await u.waitUntil(() => _converse.chatboxviews.keys().length);
const minimized_chats = document.querySelector("converse-minimized-chat")
minimized_chats.querySelector("a.restore-chat").click();
expect(_converse.api.trigger).toHaveBeenCalledWith('chatBoxMaximized', jasmine.any(Object)); expect(_converse.api.trigger).toHaveBeenCalledWith('chatBoxMaximized', jasmine.any(Object));
expect(chatview.model.get('minimized')).toBeFalsy(); expect(chatview.model.get('minimized')).toBeFalsy();
})); }));
@ -122,7 +120,7 @@ describe("A Chatbox", function () {
it("can be opened in minimized mode initially", mock.initConverse([], {}, async function (_converse) { it("can be opened in minimized mode initially", mock.initConverse([], {}, async function (_converse) {
await mock.waitForRoster(_converse, 'current'); await mock.waitForRoster(_converse, 'current');
const sender_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit'; const sender_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
const minimized_chats = document.querySelector("converse-minimized-chats") const minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
expect(u.isVisible(minimized_chats.firstElementChild)).toBe(false); expect(u.isVisible(minimized_chats.firstElementChild)).toBe(false);
await _converse.api.chats.create(sender_jid, {'minimized': true}); await _converse.api.chats.create(sender_jid, {'minimized': true});
await u.waitUntil(() => _converse.chatboxes.length > 1); await u.waitUntil(() => _converse.chatboxes.length > 1);
@ -163,7 +161,7 @@ describe("A Chatbox", function () {
model.set({'minimized': true}); model.set({'minimized': true});
} }
await u.waitUntil(() => _converse.chatboxviews.keys().length === 1); await u.waitUntil(() => _converse.chatboxviews.keys().length === 1);
const minimized_chats = document.querySelector("converse-minimized-chats") const minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
minimized_chats.querySelector("a.restore-chat").click(); minimized_chats.querySelector("a.restore-chat").click();
expect(_converse.minimize.trimChats.calls.count()).toBe(17); expect(_converse.minimize.trimChats.calls.count()).toBe(17);
})); }));
@ -179,16 +177,15 @@ describe("A Minimized ChatBoxView's Unread Message Count", function () {
const sender_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit'; const sender_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
await mock.openChatBoxFor(_converse, sender_jid); await mock.openChatBoxFor(_converse, sender_jid);
const msgFactory = () => mock.createChatMessage(_converse, sender_jid, 'This message will be received as unread, but eventually will be read'); const msgFactory = () => mock.createChatMessage(_converse, sender_jid, 'This message will be received as unread, but eventually will be read');
const minimized_chats = document.querySelector("converse-minimized-chats")
const selectUnreadMsgCount = () => minimized_chats.querySelector('#toggle-minimized-chats .unread-message-count');
const chatbox = _converse.chatboxes.get(sender_jid); const chatbox = _converse.chatboxes.get(sender_jid);
chatbox.ui.set('scrolled', true); chatbox.ui.set('scrolled', true);
_converse.handleMessageStanza(msgFactory()); _converse.handleMessageStanza(msgFactory());
await u.waitUntil(() => chatbox.messages.length); await u.waitUntil(() => chatbox.messages.length);
const view = _converse.chatboxviews.get(sender_jid); await u.waitUntil(() => chatbox.get('num_unread') === 1);
expect(view.model.get('num_unread')).toBe(1); _converse.minimize.minimize(chatbox);
_converse.minimize.minimize(view.model);
const unread_count = selectUnreadMsgCount(); const minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
const unread_count = minimized_chats.querySelector('#toggle-minimized-chats .unread-message-count');
expect(u.isVisible(unread_count)).toBeTruthy(); expect(u.isVisible(unread_count)).toBeTruthy();
expect(unread_count.innerHTML.replace(/<!-.*?->/g, '')).toBe('1'); expect(unread_count.innerHTML.replace(/<!-.*?->/g, '')).toBe('1');
})); }));
@ -200,12 +197,11 @@ describe("A Minimized ChatBoxView's Unread Message Count", function () {
const sender_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit'; const sender_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
const view = await mock.openChatBoxFor(_converse, sender_jid) const view = await mock.openChatBoxFor(_converse, sender_jid)
const msgFactory = () => mock.createChatMessage(_converse, sender_jid, 'This message will be received as unread, but eventually will be read'); const msgFactory = () => mock.createChatMessage(_converse, sender_jid, 'This message will be received as unread, but eventually will be read');
const minimized_chats = document.querySelector("converse-minimized-chats")
const selectUnreadMsgCount = () => minimized_chats.querySelector('#toggle-minimized-chats .unread-message-count');
_converse.minimize.minimize(view.model); _converse.minimize.minimize(view.model);
_converse.handleMessageStanza(msgFactory()); _converse.handleMessageStanza(msgFactory());
await u.waitUntil(() => view.model.messages.length); await u.waitUntil(() => view.model.messages.length);
const unread_count = selectUnreadMsgCount(); const minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
const unread_count = minimized_chats.querySelector('#toggle-minimized-chats .unread-message-count');
expect(u.isVisible(unread_count)).toBeTruthy(); expect(u.isVisible(unread_count)).toBeTruthy();
expect(unread_count.innerHTML.replace(/<!-.*?->/g, '')).toBe('1'); expect(unread_count.innerHTML.replace(/<!-.*?->/g, '')).toBe('1');
})); }));
@ -237,7 +233,7 @@ describe("The Minimized Chats Widget", function () {
await mock.waitForRoster(_converse, 'current'); await mock.waitForRoster(_converse, 'current');
await mock.openControlBox(_converse); await mock.openControlBox(_converse);
const minimized_chats = document.querySelector("converse-minimized-chats") const minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
minimized_chats.initToggle(); minimized_chats.initToggle();
let contact_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit'; let contact_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
@ -267,7 +263,7 @@ describe("The Minimized Chats Widget", function () {
await mock.waitForRoster(_converse, 'current'); await mock.waitForRoster(_converse, 'current');
await mock.openControlBox(_converse); await mock.openControlBox(_converse);
const minimized_chats = document.querySelector("converse-minimized-chats") let minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
minimized_chats.initToggle(); minimized_chats.initToggle();
const contact_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit'; const contact_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
@ -280,6 +276,7 @@ describe("The Minimized Chats Widget", function () {
expect(_converse.chatboxes.filter('minimized').length).toBe(1); expect(_converse.chatboxes.filter('minimized').length).toBe(1);
expect(_converse.chatboxes.models.filter(c => c.get('minimized')).pop().get('jid')).toBe(contact_jid); expect(_converse.chatboxes.models.filter(c => c.get('minimized')).pop().get('jid')).toBe(contact_jid);
minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
expect(u.isVisible(minimized_chats.querySelector('.minimized-chats-flyout'))).toBeTruthy(); expect(u.isVisible(minimized_chats.querySelector('.minimized-chats-flyout'))).toBeTruthy();
expect(minimized_chats.minchats.get('collapsed')).toBeFalsy(); expect(minimized_chats.minchats.get('collapsed')).toBeFalsy();
minimized_chats.querySelector('#toggle-minimized-chats').click(); minimized_chats.querySelector('#toggle-minimized-chats').click();
@ -292,7 +289,7 @@ describe("The Minimized Chats Widget", function () {
await mock.waitForRoster(_converse, 'current', 4); await mock.waitForRoster(_converse, 'current', 4);
await mock.openControlBox(_converse); await mock.openControlBox(_converse);
const minimized_chats = document.querySelector("converse-minimized-chats") const minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
minimized_chats.initToggle(); minimized_chats.initToggle();
minimized_chats.minchats.set({'collapsed': true}); minimized_chats.minchats.set({'collapsed': true});
@ -380,7 +377,7 @@ describe("The Minimized Chats Widget", function () {
}).c('body').t(message).tree(); }).c('body').t(message).tree();
view.model.handleMessageStanza(msg); view.model.handleMessageStanza(msg);
await u.waitUntil(() => view.model.messages.length); await u.waitUntil(() => view.model.messages.length);
const minimized_chats = document.querySelector("converse-minimized-chats") const minimized_chats = await u.waitUntil(() => document.querySelector("converse-minimized-chats"));
expect(u.isVisible(minimized_chats.querySelector('.unread-message-count'))).toBeTruthy(); expect(u.isVisible(minimized_chats.querySelector('.unread-message-count'))).toBeTruthy();
expect(minimized_chats.querySelector('.unread-message-count').textContent).toBe('1'); expect(minimized_chats.querySelector('.unread-message-count').textContent).toBe('1');
})); }));