abb_one_group_test.rb 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. # encoding: utf-8
  2. require 'browser_test_helper'
  3. class AgentTicketActionLevel0Test < TestCase
  4. def test_aaa_agent_ticket_create_with_one_group
  5. agent = "bob.smith_one_group#{rand(99_999_999)}"
  6. @browser = browser_instance
  7. login(
  8. username: 'master@example.com',
  9. password: 'test',
  10. url: browser_url,
  11. )
  12. tasks_close_all()
  13. # create new ticket
  14. ticket1 = ticket_create(
  15. data: {
  16. customer: 'nico',
  17. group: '-NONE-',
  18. title: 'some subject 123äöü - one group 1',
  19. body: 'some body 123äöü - one group 1',
  20. },
  21. )
  22. sleep 1
  23. # update ticket
  24. ticket_update(
  25. data: {
  26. state: 'closed',
  27. group: '-NONE-',
  28. body: 'some body 1234 äöüß - one group 1 - update',
  29. },
  30. )
  31. tasks_close_all()
  32. # invite agent (with one group)
  33. click(css: '#navigation a[href="#dashboard"]')
  34. click(css: '.active.content .tab[data-area="first-steps-widgets"]')
  35. watch_for(
  36. css: '.active.content',
  37. value: 'Configuration',
  38. )
  39. click(css: '.active.content .js-inviteAgent')
  40. modal_ready()
  41. set(
  42. css: '.modal [name="firstname"]',
  43. value: 'Bob',
  44. )
  45. set(
  46. css: '.modal [name="lastname"]',
  47. value: 'Smith',
  48. )
  49. set(
  50. css: '.modal [name="email"]',
  51. value: "#{agent}@example.com",
  52. )
  53. exists(
  54. displayed: false,
  55. css: '.modal [name="group_ids"]',
  56. )
  57. exists(
  58. css: '.modal [name="group_ids"]:checked',
  59. )
  60. click(
  61. css: '.modal button.btn.btn--primary',
  62. fast: true,
  63. )
  64. watch_for(
  65. css: 'body div.modal',
  66. value: 'Sending',
  67. )
  68. watch_for_disappear(
  69. css: 'body div.modal',
  70. value: 'Sending',
  71. )
  72. click(css: '#navigation a[href="#dashboard"]')
  73. click(css: '.active.content .tab[data-area="first-steps-widgets"]')
  74. watch_for(
  75. css: '.active.content',
  76. value: 'Configuration',
  77. )
  78. click(css: '.active.content .js-inviteAgent')
  79. modal_ready()
  80. set(
  81. css: '.modal [name="firstname"]',
  82. value: 'Bob2',
  83. )
  84. set(
  85. css: '.modal [name="lastname"]',
  86. value: 'Smith2',
  87. )
  88. set(
  89. css: '.modal [name="email"]',
  90. value: "#{agent}2@example.com",
  91. )
  92. # disable agent role
  93. uncheck(
  94. css: '.modal [name="role_ids"][value=2]',
  95. )
  96. exists(
  97. displayed: false,
  98. css: '.modal [name="group_ids"]',
  99. )
  100. exists_not(
  101. css: '.modal [name="group_ids"]:checked',
  102. )
  103. # enable agent role
  104. check(
  105. css: '.modal [name="role_ids"][value=2]',
  106. )
  107. exists(
  108. css: '.modal [name="group_ids"]',
  109. )
  110. exists(
  111. css: '.modal [name="group_ids"]:checked',
  112. )
  113. click(
  114. css: '.modal button.btn.btn--primary',
  115. fast: true,
  116. )
  117. watch_for(
  118. css: 'body div.modal',
  119. value: 'Sending',
  120. )
  121. watch_for_disappear(
  122. css: 'body div.modal',
  123. value: 'Sending',
  124. )
  125. tasks_close_all()
  126. end
  127. def test_bbb_customer_ticket_create_with_one_group
  128. @browser = browser_instance
  129. login(
  130. username: 'nicole.braun@zammad.org',
  131. password: 'test',
  132. url: browser_url,
  133. )
  134. # customer ticket create
  135. click(css: 'a[href="#new"]')
  136. click(css: 'a[href="#customer_ticket_new"]')
  137. watch_for(
  138. css: '.newTicket',
  139. value: 'New Ticket',
  140. )
  141. exists_not(css: '.newTicket select[name="group_id"]')
  142. set(
  143. css: '.newTicket input[name="title"]',
  144. value: 'one group',
  145. )
  146. set(
  147. css: '.newTicket [data-name="body"]',
  148. value: 'one group body',
  149. )
  150. click(css: '.newTicket button.js-submit', wait: 5)
  151. # check if ticket is shown
  152. location_check(url: '#ticket/zoom/')
  153. match(
  154. css: '.active div.ticket-article',
  155. value: 'one group body',
  156. no_quote: true,
  157. )
  158. # update ticket
  159. set(
  160. css: '.active [data-name="body"]',
  161. value: 'one group - some body 1234 äöüß',
  162. no_click: true,
  163. )
  164. task_type(
  165. type: 'stayOnTab',
  166. )
  167. click(css: '.active .js-submit')
  168. watch_for(
  169. css: '.active div.ticket-article',
  170. value: 'one group - some body 1234 äöüß',
  171. )
  172. tasks_close_all()
  173. end
  174. def test_ccc_agent_ticket_create_with_more_groups
  175. @browser = browser_instance
  176. login(
  177. username: 'master@example.com',
  178. password: 'test',
  179. url: browser_url,
  180. )
  181. tasks_close_all()
  182. group_create(
  183. data: {
  184. name: "some group #{rand(999_999_999)}",
  185. member: [
  186. 'master@example.com',
  187. 'agent1@example.com',
  188. ],
  189. },
  190. )
  191. # create new ticket
  192. ticket1 = ticket_create(
  193. data: {
  194. customer: 'nico',
  195. group: 'Users',
  196. title: 'some subject 123äöü - one group 2',
  197. body: 'some body 123äöü - one group 2',
  198. },
  199. )
  200. sleep 1
  201. # update ticket
  202. ticket_update(
  203. data: {
  204. body: 'some body 1234 äöüß - one group 2 - update',
  205. group: 'Users',
  206. },
  207. )
  208. tasks_close_all()
  209. end
  210. end