tickets_controller_test.rb 48 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110
  1. require 'test_helper'
  2. class TicketsControllerTest < ActionDispatch::IntegrationTest
  3. setup do
  4. # set accept header
  5. @headers = { 'ACCEPT' => 'application/json', 'CONTENT_TYPE' => 'application/json' }
  6. # create agent
  7. roles = Role.where(name: %w[Admin Agent])
  8. groups = Group.all
  9. UserInfo.current_user_id = 1
  10. @admin = User.create_or_update(
  11. login: 'tickets-admin',
  12. firstname: 'Tickets',
  13. lastname: 'Admin',
  14. email: 'tickets-admin@example.com',
  15. password: 'adminpw',
  16. active: true,
  17. roles: roles,
  18. groups: groups,
  19. )
  20. # create agent
  21. roles = Role.where(name: 'Agent')
  22. @agent = User.create_or_update(
  23. login: 'tickets-agent@example.com',
  24. firstname: 'Tickets',
  25. lastname: 'Agent',
  26. email: 'tickets-agent@example.com',
  27. password: 'agentpw',
  28. active: true,
  29. roles: roles,
  30. groups: groups,
  31. )
  32. # create customer without org
  33. roles = Role.where(name: 'Customer')
  34. @customer_without_org = User.create_or_update(
  35. login: 'tickets-customer1@example.com',
  36. firstname: 'Tickets',
  37. lastname: 'Customer1',
  38. email: 'tickets-customer1@example.com',
  39. password: 'customer1pw',
  40. active: true,
  41. roles: roles,
  42. )
  43. end
  44. test '01.01 ticket create with agent - missing group' do
  45. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  46. params = {
  47. title: 'a new ticket #1',
  48. article: {
  49. content_type: 'text/plain', # or text/html
  50. body: 'some body',
  51. sender: 'Customer',
  52. type: 'note',
  53. },
  54. }
  55. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  56. assert_response(422)
  57. result = JSON.parse(@response.body)
  58. assert_equal(Hash, result.class)
  59. assert_equal('Group can\'t be blank', result['error_human'])
  60. end
  61. test '01.02 ticket create with agent - wrong group' do
  62. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  63. params = {
  64. title: 'a new ticket #2',
  65. group: 'not_existing',
  66. article: {
  67. content_type: 'text/plain', # or text/html
  68. body: 'some body',
  69. sender: 'Customer',
  70. type: 'note',
  71. },
  72. }
  73. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  74. assert_response(422)
  75. result = JSON.parse(@response.body)
  76. assert_equal(Hash, result.class)
  77. assert_equal('No lookup value found for \'group\': "not_existing"', result['error'])
  78. end
  79. test '01.03 ticket create with agent - missing article.body' do
  80. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  81. params = {
  82. title: 'a new ticket #3',
  83. group: 'Users',
  84. priority: '2 normal',
  85. state: 'new',
  86. customer_id: @customer_without_org.id,
  87. article: {},
  88. }
  89. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  90. assert_response(422)
  91. result = JSON.parse(@response.body)
  92. assert_equal(Hash, result.class)
  93. assert_equal('Need at least article: { body: "some text" }', result['error'])
  94. end
  95. test '01.03 ticket create with agent - minimal article' do
  96. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  97. params = {
  98. title: 'a new ticket #3',
  99. group: 'Users',
  100. priority: '2 normal',
  101. state: 'new',
  102. customer_id: @customer_without_org.id,
  103. article: {
  104. body: 'some test 123',
  105. },
  106. }
  107. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  108. assert_response(201)
  109. result = JSON.parse(@response.body)
  110. assert_equal(Hash, result.class)
  111. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  112. assert_equal('a new ticket #3', result['title'])
  113. assert_equal(@customer_without_org.id, result['customer_id'])
  114. assert_equal(@agent.id, result['updated_by_id'])
  115. assert_equal(@agent.id, result['created_by_id'])
  116. end
  117. test '01.04 ticket create with agent - wrong owner_id - 0' do
  118. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  119. params = {
  120. title: 'a new ticket #4',
  121. group: 'Users',
  122. priority: '2 normal',
  123. owner_id: 0,
  124. state: 'new',
  125. customer_id: @customer_without_org.id,
  126. article: {
  127. body: 'some test 123',
  128. },
  129. }
  130. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  131. assert_response(422)
  132. result = JSON.parse(@response.body)
  133. assert_equal(Hash, result.class)
  134. assert_equal('Invalid value for param \'owner_id\': 0', result['error'])
  135. end
  136. test '01.05 ticket create with agent - wrong owner_id - ""' do
  137. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  138. params = {
  139. title: 'a new ticket #5',
  140. group: 'Users',
  141. priority: '2 normal',
  142. owner_id: '',
  143. state: 'new',
  144. customer_id: @customer_without_org.id,
  145. article: {
  146. body: 'some test 123',
  147. },
  148. }
  149. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  150. #assert_response(422)
  151. #result = JSON.parse(@response.body)
  152. #assert_equal(Hash, result.class)
  153. #assert_equal('Invalid value for param \'owner_id\': ""', result['error'])
  154. assert_response(201)
  155. result = JSON.parse(@response.body)
  156. assert_equal(Hash, result.class)
  157. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  158. assert_equal('a new ticket #5', result['title'])
  159. assert_equal(@customer_without_org.id, result['customer_id'])
  160. assert_equal(@agent.id, result['updated_by_id'])
  161. assert_equal(@agent.id, result['created_by_id'])
  162. end
  163. test '01.06 ticket create with agent - wrong owner_id - 99999' do
  164. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  165. params = {
  166. title: 'a new ticket #6',
  167. group: 'Users',
  168. priority: '2 normal',
  169. owner_id: 99_999,
  170. state: 'new',
  171. customer_id: @customer_without_org.id,
  172. article: {
  173. body: 'some test 123',
  174. },
  175. }
  176. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  177. assert_response(422)
  178. result = JSON.parse(@response.body)
  179. assert_equal(Hash, result.class)
  180. assert_equal('Invalid value for param \'owner_id\': 99999', result['error'])
  181. end
  182. test '01.07 ticket create with agent - wrong owner_id - nil' do
  183. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  184. params = {
  185. title: 'a new ticket #7',
  186. group: 'Users',
  187. priority: '2 normal',
  188. owner_id: nil,
  189. state: 'new',
  190. customer_id: @customer_without_org.id,
  191. article: {
  192. body: 'some test 123',
  193. },
  194. }
  195. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  196. assert_response(201)
  197. result = JSON.parse(@response.body)
  198. assert_equal(Hash, result.class)
  199. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  200. assert_equal('a new ticket #7', result['title'])
  201. assert_equal(@customer_without_org.id, result['customer_id'])
  202. assert_equal(@agent.id, result['updated_by_id'])
  203. assert_equal(@agent.id, result['created_by_id'])
  204. end
  205. test '01.08 ticket create with agent - minimal article with guess customer' do
  206. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  207. params = {
  208. title: 'a new ticket #8',
  209. group: 'Users',
  210. priority: '2 normal',
  211. state: 'new',
  212. customer_id: 'guess:some_new_customer@example.com',
  213. article: {
  214. body: 'some test 123',
  215. },
  216. }
  217. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  218. assert_response(201)
  219. result = JSON.parse(@response.body)
  220. assert_equal(Hash, result.class)
  221. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  222. assert_equal('a new ticket #8', result['title'])
  223. assert_equal(User.lookup(email: 'some_new_customer@example.com').id, result['customer_id'])
  224. assert_equal(@agent.id, result['updated_by_id'])
  225. assert_equal(@agent.id, result['created_by_id'])
  226. end
  227. test '01.09 ticket create with agent - minimal article with guess customer' do
  228. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  229. params = {
  230. title: 'a new ticket #9',
  231. group: 'Users',
  232. customer_id: 'guess:some_new_customer@example.com',
  233. article: {
  234. body: 'some test 123',
  235. },
  236. }
  237. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  238. assert_response(201)
  239. result = JSON.parse(@response.body)
  240. assert_equal(Hash, result.class)
  241. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  242. assert_equal('a new ticket #9', result['title'])
  243. assert_equal(User.lookup(email: 'some_new_customer@example.com').id, result['customer_id'])
  244. assert_equal(@agent.id, result['updated_by_id'])
  245. assert_equal(@agent.id, result['created_by_id'])
  246. end
  247. test '01.10 ticket create with agent - minimal article with missing body - with customer' do
  248. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  249. params = {
  250. title: 'a new ticket #10',
  251. group: 'Users',
  252. customer_id: @customer_without_org.id,
  253. article: {
  254. subject: 'some test 123',
  255. },
  256. }
  257. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  258. assert_response(422)
  259. result = JSON.parse(@response.body)
  260. assert_equal(Hash, result.class)
  261. assert_equal('Need at least article: { body: "some text" }', result['error'])
  262. end
  263. test '01.11 ticket create with agent - minimal article and attachment with customer' do
  264. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  265. params = {
  266. title: 'a new ticket #11',
  267. group: 'Users',
  268. customer_id: @customer_without_org.id,
  269. article: {
  270. subject: 'some test 123',
  271. body: 'some test 123',
  272. attachments: [
  273. 'filename' => 'some_file.txt',
  274. 'data' => 'dGVzdCAxMjM=',
  275. 'mime-type' => 'text/plain',
  276. ],
  277. },
  278. }
  279. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  280. assert_response(201)
  281. result = JSON.parse(@response.body)
  282. assert_equal(Hash, result.class)
  283. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  284. assert_equal('a new ticket #11', result['title'])
  285. assert_equal(@customer_without_org.id, result['customer_id'])
  286. assert_equal(@agent.id, result['updated_by_id'])
  287. assert_equal(@agent.id, result['created_by_id'])
  288. ticket = Ticket.find(result['id'])
  289. assert_equal(1, ticket.articles.count)
  290. assert_equal(1, ticket.articles.first.attachments.count)
  291. file = ticket.articles.first.attachments.first
  292. assert_equal('test 123', file.content)
  293. assert_equal('some_file.txt', file.filename)
  294. assert_equal('text/plain', file.preferences['Mime-Type'])
  295. assert_not(file.preferences['Content-ID'])
  296. end
  297. test '01.12 ticket create with agent - minimal article and attachment with customer' do
  298. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  299. params = {
  300. title: 'a new ticket #12',
  301. group: 'Users',
  302. customer_id: @customer_without_org.id,
  303. article: {
  304. subject: 'some test 123',
  305. body: 'some test 123',
  306. attachments: [
  307. {
  308. 'filename' => 'some_file1.txt',
  309. 'data' => 'dGVzdCAxMjM=',
  310. 'mime-type' => 'text/plain',
  311. },
  312. {
  313. 'filename' => 'some_file2.txt',
  314. 'data' => 'w6TDtsO8w58=',
  315. 'mime-type' => 'text/plain',
  316. },
  317. ],
  318. },
  319. }
  320. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  321. assert_response(201)
  322. result = JSON.parse(@response.body)
  323. assert_equal(Hash, result.class)
  324. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  325. assert_equal('a new ticket #12', result['title'])
  326. assert_equal(@customer_without_org.id, result['customer_id'])
  327. assert_equal(@agent.id, result['updated_by_id'])
  328. assert_equal(@agent.id, result['created_by_id'])
  329. ticket = Ticket.find(result['id'])
  330. assert_equal(1, ticket.articles.count)
  331. assert_equal(2, ticket.articles.first.attachments.count)
  332. file = ticket.articles.first.attachments.first
  333. assert_equal('test 123', file.content)
  334. assert_equal('some_file1.txt', file.filename)
  335. assert_equal('text/plain', file.preferences['Mime-Type'])
  336. assert_not(file.preferences['Content-ID'])
  337. end
  338. test '01.13 ticket create with agent - minimal article and attachment missing mine-type with customer' do
  339. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  340. params = {
  341. title: 'a new ticket #13',
  342. group: 'Users',
  343. customer_id: @customer_without_org.id,
  344. article: {
  345. subject: 'some test 123',
  346. body: 'some test 123',
  347. attachments: [
  348. 'filename' => 'some_file.txt',
  349. 'data' => 'ABC_INVALID_BASE64',
  350. 'mime-type' => 'text/plain',
  351. ],
  352. },
  353. }
  354. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  355. assert_response(422)
  356. result = JSON.parse(@response.body)
  357. assert_equal(Hash, result.class)
  358. assert_equal('Invalid base64 for attachment with index \'0\'', result['error'])
  359. end
  360. test '01.14 ticket create with agent - minimal article and attachment invalid base64 with customer' do
  361. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  362. params = {
  363. title: 'a new ticket #14',
  364. group: 'Users',
  365. customer_id: @customer_without_org.id,
  366. article: {
  367. subject: 'some test 123',
  368. body: 'some test 123',
  369. attachments: [
  370. 'filename' => 'some_file.txt',
  371. 'data' => 'dGVzdCAxMjM=',
  372. ],
  373. },
  374. }
  375. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  376. assert_response(422)
  377. result = JSON.parse(@response.body)
  378. assert_equal(Hash, result.class)
  379. assert_equal('Attachment needs \'mime-type\' param for attachment with index \'0\'', result['error'])
  380. end
  381. test '01.15 ticket create with agent - minimal article and inline attachments with customer' do
  382. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  383. params = {
  384. title: 'a new ticket #15',
  385. group: 'Users',
  386. customer_id: @customer_without_org.id,
  387. article: {
  388. content_type: 'text/html',
  389. subject: 'some test 123',
  390. body: 'some test 123 <img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUA
  391. AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
  392. 9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" /> <img src="data:image/jpeg;base64,/9j/4QAYRXhpZgAASUkqAAgAAAAAAAAAAAAAAP/sABFEdWNreQABAAQAAAAJAAD/4QMtaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLwA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/PiA8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjMtYzAxMSA2Ni4xNDU2NjEsIDIwMTIvMDIvMDYtMTQ6NTY6MjcgICAgICAgICI+IDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+IDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bXA6Q3JlYXRvclRvb2w9IkFkb2JlIFBob3Rvc2hvcCBDUzYgKE1hY2ludG9zaCkiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6QzJCOTE2NzlGQUEwMTFFNjg0M0NGQjU0OUU4MTFEOEIiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6QzJCOTE2N0FGQUEwMTFFNjg0M0NGQjU0OUU4MTFEOEIiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpDMkI5MTY3N0ZBQTAxMUU2ODQzQ0ZCNTQ5RTgxMUQ4QiIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpDMkI5MTY3OEZBQTAxMUU2ODQzQ0ZCNTQ5RTgxMUQ4QiIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pv/uAA5BZG9iZQBkwAAAAAH/2wCEABQRERoTGioZGSo1KCEoNTEpKCgpMUE4ODg4OEFEREREREREREREREREREREREREREREREREREREREREREREREQBFhoaIh0iKRoaKTkpIik5RDktLTlEREREOERERERERERERERERERERERERERERERERERERERERERERERERERERP/AABEIABAADAMBIgACEQEDEQH/xABbAAEBAAAAAAAAAAAAAAAAAAAEBQEBAQAAAAAAAAAAAAAAAAAABAUQAAEEAgMAAAAAAAAAAAAAAAABAhIDESIxBAURAAICAwAAAAAAAAAAAAAAAAESABNRoQP/2gAMAwEAAhEDEQA/AJDq1rfF3Imeg/1+lFy2oR564DKWWWbweV+Buf/Z">',
  393. },
  394. }
  395. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  396. assert_response(201)
  397. result = JSON.parse(@response.body)
  398. assert_equal(Hash, result.class)
  399. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  400. assert_equal('a new ticket #15', result['title'])
  401. assert_equal(@customer_without_org.id, result['customer_id'])
  402. assert_equal(@agent.id, result['updated_by_id'])
  403. assert_equal(@agent.id, result['created_by_id'])
  404. ticket = Ticket.find(result['id'])
  405. assert_equal(1, ticket.articles.count)
  406. assert_equal(2, ticket.articles.first.attachments.count)
  407. file = ticket.articles.first.attachments[0]
  408. assert_equal('d3c1e09bdefb92b6a06b791a24ca9599', Digest::MD5.hexdigest(file.content))
  409. assert_match(/#{ticket.id}\..+?@zammad.example.com/, file.filename)
  410. assert_equal('image/png', file.preferences['Mime-Type'])
  411. assert(file.preferences['Content-ID'])
  412. file = ticket.articles.first.attachments[1]
  413. assert_equal('006a2ca3793b550c8fe444acdeb39252', Digest::MD5.hexdigest(file.content))
  414. assert_match(/#{ticket.id}\..+?@zammad.example.com/, file.filename)
  415. assert_equal('image/jpeg', file.preferences['Mime-Type'])
  416. assert(file.preferences['Content-ID'])
  417. end
  418. test '01.16 ticket create with agent - minimal article and inline attachments with customer' do
  419. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  420. params = {
  421. title: 'a new ticket #16',
  422. group: 'Users',
  423. customer_id: @customer_without_org.id,
  424. article: {
  425. content_type: 'text/html',
  426. subject: 'some test 123',
  427. body: 'some test 123 <img src="data:image/jpeg;base64,/9j/4QAYRXhpZgAASUkqAAgAAAAAAAAAAAAAAP/sABFEdWNreQABAAQAAAAJAAD/4QMtaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLwA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/PiA8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjMtYzAxMSA2Ni4xNDU2NjEsIDIwMTIvMDIvMDYtMTQ6NTY6MjcgICAgICAgICI+IDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+IDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bXA6Q3JlYXRvclRvb2w9IkFkb2JlIFBob3Rvc2hvcCBDUzYgKE1hY2ludG9zaCkiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6QzJCOTE2NzlGQUEwMTFFNjg0M0NGQjU0OUU4MTFEOEIiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6QzJCOTE2N0FGQUEwMTFFNjg0M0NGQjU0OUU4MTFEOEIiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDpDMkI5MTY3N0ZBQTAxMUU2ODQzQ0ZCNTQ5RTgxMUQ4QiIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDpDMkI5MTY3OEZBQTAxMUU2ODQzQ0ZCNTQ5RTgxMUQ4QiIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pv/uAA5BZG9iZQBkwAAAAAH/2wCEABQRERoTGioZGSo1KCEoNTEpKCgpMUE4ODg4OEFEREREREREREREREREREREREREREREREREREREREREREREREQBFhoaIh0iKRoaKTkpIik5RDktLTlEREREOERERERERERERERERERERERERERERERERERERERERERERERERERERP/AABEIABAADAMBIgACEQEDEQH/xABbAAEBAAAAAAAAAAAAAAAAAAAEBQEBAQAAAAAAAAAAAAAAAAAABAUQAAEEAgMAAAAAAAAAAAAAAAABAhIDESIxBAURAAICAwAAAAAAAAAAAAAAAAESABNRoQP/2gAMAwEAAhEDEQA/AJDq1rfF3Imeg/1+lFy2oR564DKWWWbweV+Buf/Z"
  428. >',
  429. attachments: [
  430. 'filename' => 'some_file.txt',
  431. 'data' => 'dGVzdCAxMjM=',
  432. 'mime-type' => 'text/plain',
  433. ],
  434. },
  435. }
  436. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  437. assert_response(201)
  438. result = JSON.parse(@response.body)
  439. assert_equal(Hash, result.class)
  440. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  441. assert_equal('a new ticket #16', result['title'])
  442. assert_equal(@customer_without_org.id, result['customer_id'])
  443. assert_equal(@agent.id, result['updated_by_id'])
  444. assert_equal(@agent.id, result['created_by_id'])
  445. ticket = Ticket.find(result['id'])
  446. assert_equal(1, ticket.articles.count)
  447. assert_equal(2, ticket.articles.first.attachments.count)
  448. file = ticket.articles.first.attachments[0]
  449. assert_equal('006a2ca3793b550c8fe444acdeb39252', Digest::MD5.hexdigest(file.content))
  450. assert_match(/#{ticket.id}\..+?@zammad.example.com/, file.filename)
  451. assert_equal('image/jpeg', file.preferences['Mime-Type'])
  452. assert(file.preferences['Content-ID'])
  453. file = ticket.articles.first.attachments[1]
  454. assert_equal('39d0d586a701e199389d954f2d592720', Digest::MD5.hexdigest(file.content))
  455. assert_equal('some_file.txt', file.filename)
  456. assert_equal('text/plain', file.preferences['Mime-Type'])
  457. assert_not(file.preferences['Content-ID'])
  458. end
  459. test '02.02 ticket create with agent' do
  460. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  461. params = {
  462. title: 'a new ticket #1',
  463. state: 'new',
  464. priority: '2 normal',
  465. group: 'Users',
  466. customer: 'tickets-customer1@example.com',
  467. article: {
  468. content_type: 'text/plain', # or text/html
  469. body: 'some body',
  470. },
  471. links: {
  472. Ticket: {
  473. parent: [1],
  474. }
  475. }
  476. }
  477. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  478. assert_response(201)
  479. result = JSON.parse(@response.body)
  480. assert_equal(Hash, result.class)
  481. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  482. assert_equal('a new ticket #1', result['title'])
  483. assert_equal(@agent.id, result['updated_by_id'])
  484. assert_equal(@agent.id, result['created_by_id'])
  485. links = Link.list(
  486. link_object: 'Ticket',
  487. link_object_value: result['id'],
  488. )
  489. assert_equal('child', links[0]['link_type'])
  490. assert_equal('Ticket', links[0]['link_object'])
  491. assert_equal(1, links[0]['link_object_value'])
  492. end
  493. test '02.03 ticket with wrong ticket id' do
  494. group = Group.create_or_update(
  495. name: "GroupWithoutPermission-#{rand(9_999_999_999)}",
  496. active: true,
  497. updated_by_id: 1,
  498. created_by_id: 1,
  499. )
  500. ticket = Ticket.create!(
  501. title: 'ticket with wrong ticket id',
  502. group_id: group.id,
  503. customer_id: @customer_without_org.id,
  504. state: Ticket::State.lookup(name: 'new'),
  505. priority: Ticket::Priority.lookup(name: '2 normal'),
  506. updated_by_id: 1,
  507. created_by_id: 1,
  508. )
  509. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  510. get "/api/v1/tickets/#{ticket.id}", params: {}, headers: @headers.merge('Authorization' => credentials)
  511. assert_response(401)
  512. result = JSON.parse(@response.body)
  513. assert_equal(Hash, result.class)
  514. assert_equal('Not authorized', result['error'])
  515. params = {
  516. title: 'ticket with wrong ticket id - 2',
  517. }
  518. put "/api/v1/tickets/#{ticket.id}", params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  519. assert_response(401)
  520. result = JSON.parse(@response.body)
  521. assert_equal(Hash, result.class)
  522. assert_equal('Not authorized', result['error'])
  523. delete "/api/v1/tickets/#{ticket.id}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  524. assert_response(401)
  525. result = JSON.parse(@response.body)
  526. assert_equal(Hash, result.class)
  527. assert_equal('Not authorized', result['error'])
  528. end
  529. test '02.04 ticket with correct ticket id' do
  530. title = "ticket with corret ticket id testagent#{rand(999_999_999)}"
  531. ticket = Ticket.create!(
  532. title: title,
  533. group: Group.lookup(name: 'Users'),
  534. customer_id: @customer_without_org.id,
  535. state: Ticket::State.lookup(name: 'new'),
  536. priority: Ticket::Priority.lookup(name: '2 normal'),
  537. updated_by_id: 1,
  538. created_by_id: 1,
  539. )
  540. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-agent@example.com', 'agentpw')
  541. get "/api/v1/tickets/#{ticket.id}", params: {}, headers: @headers.merge('Authorization' => credentials)
  542. assert_response(200)
  543. result = JSON.parse(@response.body)
  544. assert_equal(Hash, result.class)
  545. assert_equal(ticket.id, result['id'])
  546. assert_equal(title, result['title'])
  547. assert_equal(ticket.customer_id, result['customer_id'])
  548. assert_equal(1, result['updated_by_id'])
  549. assert_equal(1, result['created_by_id'])
  550. params = {
  551. title: "#{title} - 2",
  552. customer_id: @agent.id,
  553. }
  554. put "/api/v1/tickets/#{ticket.id}", params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  555. assert_response(200)
  556. result = JSON.parse(@response.body)
  557. assert_equal(Hash, result.class)
  558. assert_equal(ticket.id, result['id'])
  559. assert_equal("#{title} - 2", result['title'])
  560. assert_equal(@agent.id, result['customer_id'])
  561. assert_equal(@agent.id, result['updated_by_id'])
  562. assert_equal(1, result['created_by_id'])
  563. params = {
  564. ticket_id: ticket.id,
  565. subject: 'some subject',
  566. body: 'some body',
  567. }
  568. post '/api/v1/ticket_articles', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  569. assert_response(201)
  570. article_result = JSON.parse(@response.body)
  571. assert_equal(Hash, article_result.class)
  572. assert_equal(ticket.id, article_result['ticket_id'])
  573. assert_equal('Tickets Agent', article_result['from'])
  574. assert_equal('some subject', article_result['subject'])
  575. assert_equal('some body', article_result['body'])
  576. assert_equal('text/plain', article_result['content_type'])
  577. assert_equal(false, article_result['internal'])
  578. assert_equal(@agent.id, article_result['created_by_id'])
  579. assert_equal(Ticket::Article::Sender.lookup(name: 'Agent').id, article_result['sender_id'])
  580. assert_equal(Ticket::Article::Type.lookup(name: 'note').id, article_result['type_id'])
  581. Scheduler.worker(true)
  582. get "/api/v1/tickets/search?query=#{CGI.escape(title)}", params: {}, headers: @headers.merge('Authorization' => credentials)
  583. assert_response(200)
  584. result = JSON.parse(@response.body)
  585. assert_equal(Hash, result.class)
  586. assert_equal(ticket.id, result['tickets'][0])
  587. assert_equal(1, result['tickets_count'])
  588. params = {
  589. condition: {
  590. 'ticket.title' => {
  591. operator: 'contains',
  592. value: title,
  593. },
  594. },
  595. }
  596. post '/api/v1/tickets/search', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  597. assert_response(200)
  598. result = JSON.parse(@response.body)
  599. assert_equal(Hash, result.class)
  600. assert_equal(ticket.id, result['tickets'][0])
  601. assert_equal(1, result['tickets_count'])
  602. delete "/api/v1/ticket_articles/#{article_result['id']}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  603. assert_response(200)
  604. params = {
  605. from: 'something which should not be changed on server side',
  606. ticket_id: ticket.id,
  607. subject: 'some subject',
  608. body: 'some body',
  609. type: 'email',
  610. internal: true,
  611. }
  612. post '/api/v1/ticket_articles', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  613. assert_response(201)
  614. result = JSON.parse(@response.body)
  615. assert_equal(Hash, result.class)
  616. assert_equal(ticket.id, result['ticket_id'])
  617. assert_equal('"Tickets Agent via Zammad" <zammad@localhost>', result['from'])
  618. assert_equal('some subject', result['subject'])
  619. assert_equal('some body', result['body'])
  620. assert_equal('text/plain', result['content_type'])
  621. assert_equal(true, result['internal'])
  622. assert_equal(@agent.id, result['created_by_id'])
  623. assert_equal(Ticket::Article::Sender.lookup(name: 'Agent').id, result['sender_id'])
  624. assert_equal(Ticket::Article::Type.lookup(name: 'email').id, result['type_id'])
  625. params = {
  626. subject: 'new subject',
  627. }
  628. put "/api/v1/ticket_articles/#{result['id']}", params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  629. assert_response(200)
  630. result = JSON.parse(@response.body)
  631. assert_equal(Hash, result.class)
  632. assert_equal(ticket.id, result['ticket_id'])
  633. assert_equal('"Tickets Agent via Zammad" <zammad@localhost>', result['from'])
  634. assert_equal('new subject', result['subject'])
  635. assert_equal('some body', result['body'])
  636. assert_equal('text/plain', result['content_type'])
  637. assert_equal(true, result['internal'])
  638. assert_equal(@agent.id, result['created_by_id'])
  639. assert_equal(Ticket::Article::Sender.lookup(name: 'Agent').id, result['sender_id'])
  640. assert_equal(Ticket::Article::Type.lookup(name: 'email').id, result['type_id'])
  641. delete "/api/v1/ticket_articles/#{result['id']}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  642. assert_response(401)
  643. result = JSON.parse(@response.body)
  644. assert_equal(Hash, result.class)
  645. assert_equal('Not authorized (admin permission required)!', result['error'])
  646. delete "/api/v1/tickets/#{ticket.id}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  647. assert_response(401)
  648. result = JSON.parse(@response.body)
  649. assert_equal(Hash, result.class)
  650. assert_equal('Not authorized (admin permission required)!', result['error'])
  651. end
  652. test '02.05 ticket with correct ticket id' do
  653. ticket = Ticket.create!(
  654. title: 'ticket with corret ticket id',
  655. group: Group.lookup(name: 'Users'),
  656. customer_id: @customer_without_org.id,
  657. state: Ticket::State.lookup(name: 'new'),
  658. priority: Ticket::Priority.lookup(name: '2 normal'),
  659. updated_by_id: 1,
  660. created_by_id: 1,
  661. )
  662. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-admin', 'adminpw')
  663. get "/api/v1/tickets/#{ticket.id}", params: {}, headers: @headers.merge('Authorization' => credentials)
  664. assert_response(200)
  665. result = JSON.parse(@response.body)
  666. assert_equal(Hash, result.class)
  667. assert_equal(ticket.id, result['id'])
  668. assert_equal('ticket with corret ticket id', result['title'])
  669. assert_equal(ticket.customer_id, result['customer_id'])
  670. assert_equal(1, result['updated_by_id'])
  671. assert_equal(1, result['created_by_id'])
  672. params = {
  673. title: 'ticket with corret ticket id - 2',
  674. customer_id: @agent.id,
  675. }
  676. put "/api/v1/tickets/#{ticket.id}", params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  677. assert_response(200)
  678. result = JSON.parse(@response.body)
  679. assert_equal(Hash, result.class)
  680. assert_equal(ticket.id, result['id'])
  681. assert_equal('ticket with corret ticket id - 2', result['title'])
  682. assert_equal(@agent.id, result['customer_id'])
  683. assert_equal(@admin.id, result['updated_by_id'])
  684. assert_equal(1, result['created_by_id'])
  685. params = {
  686. from: 'something which should not be changed on server side',
  687. ticket_id: ticket.id,
  688. subject: 'some subject',
  689. body: 'some body',
  690. }
  691. post '/api/v1/ticket_articles', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  692. assert_response(201)
  693. result = JSON.parse(@response.body)
  694. assert_equal(Hash, result.class)
  695. assert_equal(ticket.id, result['ticket_id'])
  696. assert_equal('Tickets Admin', result['from'])
  697. assert_equal('some subject', result['subject'])
  698. assert_equal('some body', result['body'])
  699. assert_equal('text/plain', result['content_type'])
  700. assert_equal(false, result['internal'])
  701. assert_equal(@admin.id, result['created_by_id'])
  702. assert_equal(Ticket::Article::Sender.lookup(name: 'Agent').id, result['sender_id'])
  703. assert_equal(Ticket::Article::Type.lookup(name: 'note').id, result['type_id'])
  704. params = {
  705. subject: 'new subject',
  706. internal: true,
  707. }
  708. put "/api/v1/ticket_articles/#{result['id']}", params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  709. assert_response(200)
  710. result = JSON.parse(@response.body)
  711. assert_equal(Hash, result.class)
  712. assert_equal(ticket.id, result['ticket_id'])
  713. assert_equal('Tickets Admin', result['from'])
  714. assert_equal('new subject', result['subject'])
  715. assert_equal('some body', result['body'])
  716. assert_equal('text/plain', result['content_type'])
  717. assert_equal(true, result['internal'])
  718. assert_equal(@admin.id, result['created_by_id'])
  719. assert_equal(Ticket::Article::Sender.lookup(name: 'Agent').id, result['sender_id'])
  720. assert_equal(Ticket::Article::Type.lookup(name: 'note').id, result['type_id'])
  721. delete "/api/v1/ticket_articles/#{result['id']}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  722. assert_response(200)
  723. params = {
  724. ticket_id: ticket.id,
  725. subject: 'some subject',
  726. body: 'some body',
  727. type: 'email',
  728. }
  729. post '/api/v1/ticket_articles', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  730. assert_response(201)
  731. result = JSON.parse(@response.body)
  732. assert_equal(Hash, result.class)
  733. assert_equal(ticket.id, result['ticket_id'])
  734. assert_equal('"Tickets Admin via Zammad" <zammad@localhost>', result['from'])
  735. assert_equal('some subject', result['subject'])
  736. assert_equal('some body', result['body'])
  737. assert_equal('text/plain', result['content_type'])
  738. assert_equal(false, result['internal'])
  739. assert_equal(@admin.id, result['created_by_id'])
  740. assert_equal(Ticket::Article::Sender.lookup(name: 'Agent').id, result['sender_id'])
  741. assert_equal(Ticket::Article::Type.lookup(name: 'email').id, result['type_id'])
  742. delete "/api/v1/ticket_articles/#{result['id']}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  743. assert_response(200)
  744. delete "/api/v1/tickets/#{ticket.id}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  745. assert_response(200)
  746. end
  747. test '02.05 ticket pagination' do
  748. title = "ticket pagination #{rand(999_999_999)}"
  749. tickets = []
  750. (1..20).each do |count|
  751. ticket = Ticket.create!(
  752. title: "#{title} - #{count}",
  753. group: Group.lookup(name: 'Users'),
  754. customer_id: @customer_without_org.id,
  755. state: Ticket::State.lookup(name: 'new'),
  756. priority: Ticket::Priority.lookup(name: '2 normal'),
  757. updated_by_id: 1,
  758. created_by_id: 1,
  759. )
  760. Ticket::Article.create!(
  761. type: Ticket::Article::Type.lookup(name: 'note'),
  762. sender: Ticket::Article::Sender.lookup(name: 'Customer'),
  763. from: 'sender',
  764. subject: 'subject',
  765. body: 'some body',
  766. ticket_id: ticket.id,
  767. updated_by_id: 1,
  768. created_by_id: 1,
  769. )
  770. tickets.push ticket
  771. travel 2.seconds
  772. end
  773. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-admin', 'adminpw')
  774. get "/api/v1/tickets/search?query=#{CGI.escape(title)}&limit=40", params: {}, headers: @headers.merge('Authorization' => credentials)
  775. assert_response(200)
  776. result = JSON.parse(@response.body)
  777. assert_equal(Hash, result.class)
  778. assert_equal(tickets[19].id, result['tickets'][0])
  779. assert_equal(tickets[0].id, result['tickets'][19])
  780. assert_equal(20, result['tickets_count'])
  781. get "/api/v1/tickets/search?query=#{CGI.escape(title)}&limit=10", params: {}, headers: @headers.merge('Authorization' => credentials)
  782. assert_response(200)
  783. result = JSON.parse(@response.body)
  784. assert_equal(Hash, result.class)
  785. assert_equal(tickets[19].id, result['tickets'][0])
  786. assert_equal(tickets[10].id, result['tickets'][9])
  787. assert_equal(10, result['tickets_count'])
  788. get "/api/v1/tickets/search?query=#{CGI.escape(title)}&limit=40&page=1&per_page=5", params: {}, headers: @headers.merge('Authorization' => credentials)
  789. assert_response(200)
  790. result = JSON.parse(@response.body)
  791. assert_equal(Hash, result.class)
  792. assert_equal(tickets[19].id, result['tickets'][0])
  793. assert_equal(tickets[15].id, result['tickets'][4])
  794. assert_equal(5, result['tickets_count'])
  795. get "/api/v1/tickets/search?query=#{CGI.escape(title)}&limit=40&page=2&per_page=5", params: {}, headers: @headers.merge('Authorization' => credentials)
  796. assert_response(200)
  797. result = JSON.parse(@response.body)
  798. assert_equal(Hash, result.class)
  799. assert_equal(tickets[14].id, result['tickets'][0])
  800. assert_equal(tickets[10].id, result['tickets'][4])
  801. assert_equal(5, result['tickets_count'])
  802. get '/api/v1/tickets?limit=40&page=1&per_page=5', params: {}, headers: @headers.merge('Authorization' => credentials)
  803. assert_response(200)
  804. result = JSON.parse(@response.body)
  805. assert_equal(Array, result.class)
  806. tickets = Ticket.order(:id).limit(5)
  807. assert_equal(tickets[0].id, result[0]['id'])
  808. assert_equal(tickets[4].id, result[4]['id'])
  809. assert_equal(5, result.count)
  810. get '/api/v1/tickets?limit=40&page=2&per_page=5', params: {}, headers: @headers.merge('Authorization' => credentials)
  811. assert_response(200)
  812. result = JSON.parse(@response.body)
  813. assert_equal(Array, result.class)
  814. tickets = Ticket.order(:id).limit(10)
  815. assert_equal(tickets[5].id, result[0]['id'])
  816. assert_equal(tickets[9].id, result[4]['id'])
  817. assert_equal(5, result.count)
  818. end
  819. test '03.01 ticket create with customer minimal' do
  820. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-customer1@example.com', 'customer1pw')
  821. params = {
  822. title: 'a new ticket #c1',
  823. state: 'new',
  824. priority: '2 normal',
  825. group: 'Users',
  826. article: {
  827. body: 'some body',
  828. },
  829. }
  830. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  831. assert_response(201)
  832. result = JSON.parse(@response.body)
  833. assert_equal(Hash, result.class)
  834. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  835. assert_equal('a new ticket #c1', result['title'])
  836. assert_equal(@customer_without_org.id, result['customer_id'])
  837. assert_equal(@customer_without_org.id, result['updated_by_id'])
  838. assert_equal(@customer_without_org.id, result['created_by_id'])
  839. end
  840. test '03.02 ticket create with customer with wrong customer' do
  841. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-customer1@example.com', 'customer1pw')
  842. params = {
  843. title: 'a new ticket #c2',
  844. state: 'new',
  845. priority: '2 normal',
  846. group: 'Users',
  847. customer_id: @agent.id,
  848. article: {
  849. content_type: 'text/plain', # or text/html
  850. body: 'some body',
  851. sender: 'System',
  852. },
  853. }
  854. post '/api/v1/tickets', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  855. assert_response(201)
  856. result = JSON.parse(@response.body)
  857. assert_equal(Hash, result.class)
  858. assert_equal(Ticket::State.lookup(name: 'new').id, result['state_id'])
  859. assert_equal('a new ticket #c2', result['title'])
  860. assert_equal(@customer_without_org.id, result['customer_id'])
  861. assert_equal(@customer_without_org.id, result['updated_by_id'])
  862. assert_equal(@customer_without_org.id, result['created_by_id'])
  863. end
  864. test '03.03 ticket with wrong ticket id' do
  865. ticket = Ticket.create!(
  866. title: 'ticket with wrong ticket id',
  867. group: Group.lookup(name: 'Users'),
  868. customer_id: @agent.id,
  869. state: Ticket::State.lookup(name: 'new'),
  870. priority: Ticket::Priority.lookup(name: '2 normal'),
  871. updated_by_id: 1,
  872. created_by_id: 1,
  873. )
  874. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-customer1@example.com', 'customer1pw')
  875. get "/api/v1/tickets/#{ticket.id}", params: {}, headers: @headers.merge('Authorization' => credentials)
  876. assert_response(401)
  877. result = JSON.parse(@response.body)
  878. assert_equal(Hash, result.class)
  879. assert_equal('Not authorized', result['error'])
  880. params = {
  881. title: 'ticket with wrong ticket id - 2',
  882. }
  883. put "/api/v1/tickets/#{ticket.id}", params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  884. assert_response(401)
  885. result = JSON.parse(@response.body)
  886. assert_equal(Hash, result.class)
  887. assert_equal('Not authorized', result['error'])
  888. delete "/api/v1/tickets/#{ticket.id}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  889. assert_response(401)
  890. result = JSON.parse(@response.body)
  891. assert_equal(Hash, result.class)
  892. assert_equal('Not authorized', result['error'])
  893. end
  894. test '03.04 ticket with correct ticket id' do
  895. title = "ticket with corret ticket id testme#{rand(999_999_999)}"
  896. ticket = Ticket.create!(
  897. title: title,
  898. group: Group.lookup(name: 'Users'),
  899. customer_id: @customer_without_org.id,
  900. state: Ticket::State.lookup(name: 'new'),
  901. priority: Ticket::Priority.lookup(name: '2 normal'),
  902. updated_by_id: 1,
  903. created_by_id: 1,
  904. )
  905. credentials = ActionController::HttpAuthentication::Basic.encode_credentials('tickets-customer1@example.com', 'customer1pw')
  906. get "/api/v1/tickets/#{ticket.id}", params: {}, headers: @headers.merge('Authorization' => credentials)
  907. assert_response(200)
  908. result = JSON.parse(@response.body)
  909. assert_equal(Hash, result.class)
  910. assert_equal(ticket.id, result['id'])
  911. assert_equal(title, result['title'])
  912. assert_equal(ticket.customer_id, result['customer_id'])
  913. assert_equal(1, result['updated_by_id'])
  914. assert_equal(1, result['created_by_id'])
  915. params = {
  916. title: "#{title} - 2",
  917. customer_id: @agent.id,
  918. }
  919. put "/api/v1/tickets/#{ticket.id}", params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  920. assert_response(200)
  921. result = JSON.parse(@response.body)
  922. assert_equal(Hash, result.class)
  923. assert_equal(ticket.id, result['id'])
  924. assert_equal("#{title} - 2", result['title'])
  925. assert_equal(ticket.customer_id, result['customer_id'])
  926. assert_equal(@customer_without_org.id, result['updated_by_id'])
  927. assert_equal(1, result['created_by_id'])
  928. params = {
  929. ticket_id: ticket.id,
  930. subject: 'some subject',
  931. body: 'some body',
  932. }
  933. post '/api/v1/ticket_articles', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  934. assert_response(201)
  935. article_result = JSON.parse(@response.body)
  936. assert_equal(Hash, article_result.class)
  937. assert_equal(ticket.id, article_result['ticket_id'])
  938. assert_equal('Tickets Customer1', article_result['from'])
  939. assert_equal('some subject', article_result['subject'])
  940. assert_equal('some body', article_result['body'])
  941. assert_equal('text/plain', article_result['content_type'])
  942. assert_equal(@customer_without_org.id, article_result['created_by_id'])
  943. assert_equal(Ticket::Article::Sender.lookup(name: 'Customer').id, article_result['sender_id'])
  944. assert_equal(Ticket::Article::Type.lookup(name: 'note').id, article_result['type_id'])
  945. Scheduler.worker(true)
  946. get "/api/v1/tickets/search?query=#{CGI.escape(title)}", params: {}, headers: @headers.merge('Authorization' => credentials)
  947. assert_response(200)
  948. result = JSON.parse(@response.body)
  949. assert_equal(Hash, result.class)
  950. assert_equal(ticket.id, result['tickets'][0])
  951. assert_equal(1, result['tickets_count'])
  952. params = {
  953. condition: {
  954. 'ticket.title' => {
  955. operator: 'contains',
  956. value: title,
  957. },
  958. },
  959. }
  960. post '/api/v1/tickets/search', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  961. assert_response(200)
  962. result = JSON.parse(@response.body)
  963. assert_equal(Hash, result.class)
  964. assert_equal(ticket.id, result['tickets'][0])
  965. assert_equal(1, result['tickets_count'])
  966. delete "/api/v1/ticket_articles/#{article_result['id']}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  967. assert_response(401)
  968. result = JSON.parse(@response.body)
  969. assert_equal(Hash, result.class)
  970. assert_equal('Not authorized (admin permission required)!', result['error'])
  971. params = {
  972. ticket_id: ticket.id,
  973. subject: 'some subject',
  974. body: 'some body',
  975. type: 'email',
  976. sender: 'Agent',
  977. }
  978. post '/api/v1/ticket_articles', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  979. assert_response(201)
  980. result = JSON.parse(@response.body)
  981. assert_equal(Hash, result.class)
  982. assert_equal(ticket.id, result['ticket_id'])
  983. assert_equal('Tickets Customer1', result['from'])
  984. assert_equal('some subject', result['subject'])
  985. assert_equal('some body', result['body'])
  986. assert_equal('text/plain', result['content_type'])
  987. assert_equal(@customer_without_org.id, result['created_by_id'])
  988. assert_equal(Ticket::Article::Sender.lookup(name: 'Customer').id, result['sender_id'])
  989. assert_equal(Ticket::Article::Type.lookup(name: 'note').id, result['type_id'])
  990. delete "/api/v1/ticket_articles/#{result['id']}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  991. assert_response(401)
  992. result = JSON.parse(@response.body)
  993. assert_equal(Hash, result.class)
  994. assert_equal('Not authorized (admin permission required)!', result['error'])
  995. params = {
  996. from: 'something which should not be changed on server side',
  997. ticket_id: ticket.id,
  998. subject: 'some subject',
  999. body: 'some body',
  1000. type: 'web',
  1001. sender: 'Agent',
  1002. internal: true,
  1003. }
  1004. post '/api/v1/ticket_articles', params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  1005. assert_response(201)
  1006. result = JSON.parse(@response.body)
  1007. assert_equal(Hash, result.class)
  1008. assert_equal(ticket.id, result['ticket_id'])
  1009. assert_equal('Tickets Customer1 <tickets-customer1@example.com>', result['from'])
  1010. assert_equal('some subject', result['subject'])
  1011. assert_equal('some body', result['body'])
  1012. assert_equal('text/plain', result['content_type'])
  1013. assert_equal(false, result['internal'])
  1014. assert_equal(@customer_without_org.id, result['created_by_id'])
  1015. assert_equal(Ticket::Article::Sender.lookup(name: 'Customer').id, result['sender_id'])
  1016. assert_equal(Ticket::Article::Type.lookup(name: 'web').id, result['type_id'])
  1017. params = {
  1018. subject: 'new subject',
  1019. }
  1020. put "/api/v1/ticket_articles/#{result['id']}", params: params.to_json, headers: @headers.merge('Authorization' => credentials)
  1021. assert_response(401)
  1022. result = JSON.parse(@response.body)
  1023. assert_equal(Hash, result.class)
  1024. assert_equal('Not authorized (ticket.agent or admin permission required)!', result['error'])
  1025. delete "/api/v1/tickets/#{ticket.id}", params: {}.to_json, headers: @headers.merge('Authorization' => credentials)
  1026. assert_response(401)
  1027. result = JSON.parse(@response.body)
  1028. assert_equal(Hash, result.class)
  1029. assert_equal('Not authorized (admin permission required)!', result['error'])
  1030. end
  1031. end