user-details-modal.js 4.1 KB

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