user-details-modal.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*global mock */
  2. const u = converse.env.utils;
  3. describe("The User Details Modal", function () {
  4. it("can be used to remove a contact",
  5. mock.initConverse(
  6. ['rosterGroupsFetched', 'chatBoxesFetched'], {},
  7. async function (done, _converse) {
  8. await mock.waitForRoster(_converse, 'current', 1);
  9. _converse.api.trigger('rosterContactsFetched');
  10. const contact_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
  11. await mock.openChatBoxFor(_converse, contact_jid);
  12. await u.waitUntil(() => _converse.chatboxes.length > 1);
  13. const view = _converse.chatboxviews.get(contact_jid);
  14. let show_modal_button = view.el.querySelector('.show-user-details-modal');
  15. show_modal_button.click();
  16. const modal = view.user_details_modal;
  17. await u.waitUntil(() => u.isVisible(modal.el), 1000);
  18. spyOn(window, 'confirm').and.returnValue(true);
  19. spyOn(view.model.contact, 'removeFromRoster').and.callFake(callback => callback());
  20. let remove_contact_button = modal.el.querySelector('button.remove-contact');
  21. expect(u.isVisible(remove_contact_button)).toBeTruthy();
  22. remove_contact_button.click();
  23. await u.waitUntil(() => modal.el.getAttribute('aria-hidden'), 1000);
  24. await u.waitUntil(() => !u.isVisible(modal.el));
  25. show_modal_button = view.el.querySelector('.show-user-details-modal');
  26. show_modal_button.click();
  27. remove_contact_button = modal.el.querySelector('button.remove-contact');
  28. expect(remove_contact_button === null).toBeTruthy();
  29. done();
  30. }));
  31. it("shows an alert when an error happened while removing the contact",
  32. mock.initConverse(['rosterGroupsFetched'], {}, async function (done, _converse) {
  33. await mock.waitForRoster(_converse, 'current', 1);
  34. _converse.api.trigger('rosterContactsFetched');
  35. const contact_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
  36. await mock.openChatBoxFor(_converse, contact_jid)
  37. const view = _converse.chatboxviews.get(contact_jid);
  38. let show_modal_button = view.el.querySelector('.show-user-details-modal');
  39. show_modal_button.click();
  40. const modal = view.user_details_modal;
  41. await u.waitUntil(() => u.isVisible(modal.el), 2000);
  42. spyOn(window, 'confirm').and.returnValue(true);
  43. spyOn(view.model.contact, 'removeFromRoster').and.callFake((callback, errback) => errback());
  44. let remove_contact_button = modal.el.querySelector('button.remove-contact');
  45. expect(u.isVisible(remove_contact_button)).toBeTruthy();
  46. remove_contact_button.click();
  47. await u.waitUntil(() => u.isVisible(document.querySelector('.alert-danger')), 2000);
  48. const header = document.querySelector('.alert-danger .modal-title');
  49. expect(header.textContent).toBe("Error");
  50. expect(u.ancestor(header, '.modal-content').querySelector('.modal-body p').textContent.trim())
  51. .toBe("Sorry, there was an error while trying to remove Mercutio as a contact.");
  52. document.querySelector('.alert-danger button.close').click();
  53. show_modal_button = view.el.querySelector('.show-user-details-modal');
  54. show_modal_button.click();
  55. await u.waitUntil(() => u.isVisible(modal.el), 2000)
  56. show_modal_button = view.el.querySelector('.show-user-details-modal');
  57. show_modal_button.click();
  58. await u.waitUntil(() => u.isVisible(modal.el), 2000)
  59. remove_contact_button = modal.el.querySelector('button.remove-contact');
  60. expect(u.isVisible(remove_contact_button)).toBeTruthy();
  61. done();
  62. }));
  63. });