user_test.rb 36 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198
  1. # Copyright (C) 2012-2023 Zammad Foundation, https://zammad-foundation.org/
  2. require 'test_helper'
  3. class UserTest < ActiveSupport::TestCase
  4. test 'user' do
  5. tests = [
  6. {
  7. name: '#1 - simple create',
  8. create: {
  9. firstname: 'Firstname',
  10. lastname: 'Lastname',
  11. email: 'some@example.com',
  12. login: 'some@example.com',
  13. updated_by_id: 1,
  14. created_by_id: 1,
  15. },
  16. create_verify: {
  17. firstname: 'Firstname',
  18. lastname: 'Lastname',
  19. image: nil,
  20. fullname: 'Firstname Lastname',
  21. email: 'some@example.com',
  22. login: 'some@example.com',
  23. },
  24. },
  25. {
  26. name: '#2 - simple create - no lastname',
  27. create: {
  28. firstname: 'Firstname Lastname',
  29. lastname: '',
  30. email: 'some@example.com',
  31. login: 'some@example.com',
  32. updated_by_id: 1,
  33. created_by_id: 1,
  34. },
  35. create_verify: {
  36. firstname: 'Firstname',
  37. lastname: 'Lastname',
  38. image: nil,
  39. email: 'some@example.com',
  40. login: 'some@example.com',
  41. },
  42. },
  43. {
  44. name: '#3 - simple create - no firstname',
  45. create: {
  46. firstname: '',
  47. lastname: 'Firstname Lastname',
  48. email: 'some@example.com',
  49. login: 'some@example.com',
  50. updated_by_id: 1,
  51. created_by_id: 1,
  52. },
  53. create_verify: {
  54. firstname: 'Firstname',
  55. lastname: 'Lastname',
  56. image: nil,
  57. email: 'some@example.com',
  58. login: 'some@example.com',
  59. },
  60. },
  61. {
  62. name: '#4 - simple create - nil as lastname',
  63. create: {
  64. firstname: 'Firstname Lastname',
  65. lastname: '',
  66. email: 'some@example.com',
  67. login: 'some@example.com',
  68. updated_by_id: 1,
  69. created_by_id: 1,
  70. },
  71. create_verify: {
  72. firstname: 'Firstname',
  73. lastname: 'Lastname',
  74. image: nil,
  75. email: 'some@example.com',
  76. login: 'some@example.com',
  77. },
  78. },
  79. {
  80. name: '#5 - simple create - no lastname, firstname with ","',
  81. create: {
  82. firstname: 'Lastname, Firstname',
  83. lastname: '',
  84. email: 'some@example.com',
  85. login: 'some@example.com',
  86. updated_by_id: 1,
  87. created_by_id: 1,
  88. },
  89. create_verify: {
  90. firstname: 'Firstname',
  91. lastname: 'Lastname',
  92. email: 'some@example.com',
  93. login: 'some@example.com',
  94. },
  95. },
  96. {
  97. name: '#6 - simple create - no lastname/firstname',
  98. create: {
  99. firstname: '',
  100. lastname: '',
  101. email: 'firstname.lastname@example.com',
  102. login: 'login-1',
  103. updated_by_id: 1,
  104. created_by_id: 1,
  105. },
  106. create_verify: {
  107. firstname: 'Firstname',
  108. lastname: 'Lastname',
  109. fullname: 'Firstname Lastname',
  110. email: 'firstname.lastname@example.com',
  111. login: 'login-1',
  112. },
  113. },
  114. {
  115. name: '#7 - simple create - no lastname/firstnam',
  116. create: {
  117. firstname: '',
  118. lastname: '',
  119. email: 'FIRSTNAME.lastname@example.com',
  120. login: 'login-2',
  121. updated_by_id: 1,
  122. created_by_id: 1,
  123. },
  124. create_verify: {
  125. firstname: 'Firstname',
  126. lastname: 'Lastname',
  127. email: 'firstname.lastname@example.com',
  128. login: 'login-2',
  129. },
  130. },
  131. {
  132. name: '#8 - simple create - nill as fristname and lastname',
  133. create: {
  134. firstname: '',
  135. lastname: '',
  136. email: 'FIRSTNAME.lastname@example.com',
  137. login: 'login-3',
  138. updated_by_id: 1,
  139. created_by_id: 1,
  140. },
  141. create_verify: {
  142. firstname: 'Firstname',
  143. lastname: 'Lastname',
  144. email: 'firstname.lastname@example.com',
  145. login: 'login-3',
  146. },
  147. },
  148. {
  149. name: '#11 - update create with login/email check',
  150. create: {
  151. firstname: '',
  152. lastname: '',
  153. email: 'caoyaoewfzfw@21222cn.com',
  154. updated_by_id: 1,
  155. created_by_id: 1,
  156. },
  157. create_verify: {
  158. firstname: '',
  159. lastname: '',
  160. fullname: 'caoyaoewfzfw@21222cn.com',
  161. email: 'caoyaoewfzfw@21222cn.com',
  162. login: 'caoyaoewfzfw@21222cn.com',
  163. },
  164. update: {
  165. email: 'caoyaoewfzfw@212224cn.com',
  166. },
  167. update_verify: {
  168. firstname: '',
  169. lastname: '',
  170. email: 'caoyaoewfzfw@212224cn.com',
  171. fullname: 'caoyaoewfzfw@212224cn.com',
  172. login: 'caoyaoewfzfw@212224cn.com',
  173. }
  174. },
  175. {
  176. name: '#12 - update create with login/email check',
  177. create: {
  178. firstname: 'Firstname',
  179. lastname: 'Lastname',
  180. email: 'some_tEst11@example.com',
  181. updated_by_id: 1,
  182. created_by_id: 1,
  183. },
  184. create_verify: {
  185. firstname: 'Firstname',
  186. lastname: 'Lastname',
  187. fullname: 'Firstname Lastname',
  188. email: 'some_test11@example.com',
  189. },
  190. update: {
  191. email: 'some_Test11-1@example.com',
  192. },
  193. update_verify: {
  194. firstname: 'Firstname',
  195. lastname: 'Lastname',
  196. email: 'some_test11-1@example.com',
  197. fullname: 'Firstname Lastname',
  198. login: 'some_test11-1@example.com',
  199. }
  200. },
  201. ]
  202. default_disable_in_test_env = Service::Image::Zammad.const_get(:DISABLE_IN_TEST_ENV)
  203. silence_warnings do
  204. Service::Image::Zammad.const_set(:DISABLE_IN_TEST_ENV, false)
  205. end
  206. tests.each do |test|
  207. # check if user exists
  208. user = User.find_by(login: test[:create][:login])
  209. user&.destroy!
  210. user = User.create!(test[:create])
  211. test[:create_verify].each do |key, value|
  212. next if key == :image_md5
  213. if user.respond_to?(key)
  214. result = user.send(key)
  215. if value.nil?
  216. assert_nil(result, "create check #{key} in (#{test[:name]})")
  217. else
  218. assert_equal(result, value, "create check #{key} in (#{test[:name]})")
  219. end
  220. else
  221. assert_equal(user[key], value, "create check #{key} in (#{test[:name]})")
  222. end
  223. end
  224. if test[:update]
  225. user.update!(test[:update])
  226. test[:update_verify].each do |key, value|
  227. next if key == :image_md5
  228. if user.respond_to?(key)
  229. assert_equal(user.send(key), value, "update check #{key} in (#{test[:name]})")
  230. else
  231. assert_equal(user[key], value, "update check #{key} in (#{test[:name]})")
  232. end
  233. end
  234. end
  235. user.destroy!
  236. end
  237. silence_warnings do
  238. Service::Image::Zammad.const_set(:DISABLE_IN_TEST_ENV, default_disable_in_test_env)
  239. end
  240. end
  241. test 'strange spaces' do
  242. name = "#{Time.zone.now.to_i}-#{SecureRandom.uuid}"
  243. email = "customer_email#{name}@example.com"
  244. customer = User.create!(
  245. firstname: 'Role',
  246. lastname: "Customer#{name}",
  247. email: " #{email} ",
  248. password: 'customerpw',
  249. active: true,
  250. roles: Role.where(name: %w[Customer]),
  251. updated_by_id: 1,
  252. created_by_id: 1,
  253. )
  254. assert(customer)
  255. assert_equal(email, customer.email)
  256. customer.destroy!
  257. name = "#{Time.zone.now.to_i}-#{SecureRandom.uuid}"
  258. email = "customer_email#{name}@example.com"
  259. customer = User.create!(
  260. firstname: "\u{00a0}\u{00a0}Role",
  261. lastname: "Customer#{name} \u{00a0}",
  262. email: "\u{00a0}#{email}\u{00a0}",
  263. password: 'customerpw',
  264. active: true,
  265. roles: Role.where(name: %w[Customer]),
  266. updated_by_id: 1,
  267. created_by_id: 1,
  268. )
  269. assert(customer)
  270. assert_equal('Role', customer.firstname)
  271. assert_equal("Customer#{name}", customer.lastname)
  272. assert_equal(email, customer.email)
  273. customer.destroy!
  274. name = "#{Time.zone.now.to_i}-#{SecureRandom.uuid}"
  275. email = "customer_email#{name}@example.com"
  276. customer = User.create!(
  277. firstname: "\u{200B}\u{200B}Role",
  278. lastname: "Customer#{name} \u{200B}",
  279. email: "\u{200B}#{email}\u{200B}",
  280. password: 'customerpw',
  281. active: true,
  282. roles: Role.where(name: %w[Customer]),
  283. updated_by_id: 1,
  284. created_by_id: 1,
  285. )
  286. assert(customer)
  287. assert_equal('Role', customer.firstname)
  288. assert_equal("Customer#{name}", customer.lastname)
  289. assert_equal(email, customer.email)
  290. customer.destroy!
  291. name = "#{Time.zone.now.to_i}-#{SecureRandom.uuid}"
  292. email = "customer_email#{name}@example.com"
  293. customer = User.create!(
  294. firstname: "\u{200B}\u{200B}Role\u{00a0}",
  295. lastname: "\u{00a0}\u{00a0}Customer#{name} \u{200B}",
  296. email: "\u{200B}#{email}\u{200B}",
  297. password: 'customerpw',
  298. active: true,
  299. roles: Role.where(name: %w[Customer]),
  300. updated_by_id: 1,
  301. created_by_id: 1,
  302. )
  303. assert(customer)
  304. assert_equal('Role', customer.firstname)
  305. assert_equal("Customer#{name}", customer.lastname)
  306. assert_equal(email, customer.email)
  307. customer.destroy!
  308. name = "#{Time.zone.now.to_i}-#{SecureRandom.uuid}"
  309. email = "customer_email#{name}@example.com"
  310. customer = User.create!(
  311. firstname: "\u{200a}\u{200b}\u{202F}\u{205F}Role\u{2007}\u{2008}",
  312. lastname: "\u{00a0}\u{00a0}Customer#{name}\u{3000}\u{FEFF}\u{2000}",
  313. email: "\u{200B}#{email}\u{200B}\u{2007}\u{2008}",
  314. password: 'customerpw',
  315. active: true,
  316. roles: Role.where(name: %w[Customer]),
  317. updated_by_id: 1,
  318. created_by_id: 1,
  319. )
  320. assert(customer)
  321. assert_equal('Role', customer.firstname)
  322. assert_equal("Customer#{name}", customer.lastname)
  323. assert_equal(email, customer.email)
  324. customer.destroy!
  325. end
  326. test 'without email - but login eq email' do
  327. name = SecureRandom.uuid
  328. login = "admin-role_without_email#{name}@example.com"
  329. email = "admin-role_without_email#{name}@example.com"
  330. admin = User.create_or_update(
  331. login: login,
  332. firstname: 'Role',
  333. lastname: "Admin#{name}",
  334. # email: "",
  335. password: 'adminpw',
  336. active: true,
  337. roles: Role.where(name: %w[Admin Agent]),
  338. updated_by_id: 1,
  339. created_by_id: 1,
  340. )
  341. assert(admin.id)
  342. assert_equal(admin.login, login)
  343. assert_equal(admin.email, '')
  344. admin.email = email
  345. admin.save!
  346. assert_equal(admin.login, login)
  347. assert_equal(admin.email, email)
  348. admin.email = ''
  349. admin.save!
  350. assert(admin.id)
  351. assert(admin.login)
  352. assert_not_equal(admin.login, login)
  353. assert_equal(admin.email, '')
  354. admin.destroy!
  355. end
  356. test 'without email - but login ne email' do
  357. name = SecureRandom.uuid
  358. login = "admin-role_without_email#{name}"
  359. email = "admin-role_without_email#{name}@example.com"
  360. admin = User.create_or_update(
  361. login: login,
  362. firstname: 'Role',
  363. lastname: "Admin#{name}",
  364. # email: "",
  365. password: 'adminpw',
  366. active: true,
  367. roles: Role.where(name: %w[Admin Agent]),
  368. updated_by_id: 1,
  369. created_by_id: 1,
  370. )
  371. assert(admin.id)
  372. assert_equal(admin.login, login)
  373. assert_equal(admin.email, '')
  374. admin.email = email
  375. admin.save!
  376. assert_equal(admin.login, login)
  377. assert_equal(admin.email, email)
  378. admin.email = ''
  379. admin.save!
  380. assert(admin.id)
  381. assert_equal(admin.login, login)
  382. assert_equal(admin.email, '')
  383. admin.destroy!
  384. end
  385. test 'uniq email' do
  386. name = SecureRandom.uuid
  387. email1 = "admin1-role_without_email#{name}@example.com"
  388. admin1 = User.create!(
  389. login: email1,
  390. firstname: 'Role',
  391. lastname: "Admin1#{name}",
  392. email: email1,
  393. password: 'adminpw',
  394. active: true,
  395. roles: Role.where(name: %w[Admin Agent]),
  396. updated_by_id: 1,
  397. created_by_id: 1,
  398. )
  399. assert(admin1.id)
  400. assert_equal(admin1.email, email1)
  401. assert_raises(ActiveRecord::RecordInvalid) do
  402. User.create!(
  403. login: "#{email1}-1",
  404. firstname: 'Role',
  405. lastname: "Admin1#{name}",
  406. email: email1,
  407. password: 'adminpw',
  408. active: true,
  409. roles: Role.where(name: %w[Admin Agent]),
  410. updated_by_id: 1,
  411. created_by_id: 1,
  412. )
  413. end
  414. email2 = "admin2-role_without_email#{name}@example.com"
  415. admin2 = User.create!(
  416. firstname: 'Role',
  417. lastname: "Admin2#{name}",
  418. email: email2,
  419. password: 'adminpw',
  420. active: true,
  421. roles: Role.where(name: %w[Admin Agent]),
  422. updated_by_id: 1,
  423. created_by_id: 1,
  424. )
  425. assert_raises(ActiveRecord::RecordInvalid) do
  426. admin2.email = email1
  427. admin2.save!
  428. end
  429. admin1.email = admin1.email
  430. admin1.save!
  431. admin2.destroy!
  432. admin1.destroy!
  433. end
  434. test 'uniq email - multiple use' do
  435. Setting.set('user_email_multiple_use', true)
  436. name = SecureRandom.uuid
  437. email1 = "admin1-role_without_email#{name}@example.com"
  438. admin1 = User.create!(
  439. login: email1,
  440. firstname: 'Role',
  441. lastname: "Admin1#{name}",
  442. email: email1,
  443. password: 'adminpw',
  444. active: true,
  445. roles: Role.where(name: %w[Admin Agent]),
  446. updated_by_id: 1,
  447. created_by_id: 1,
  448. )
  449. assert(admin1.id)
  450. assert_equal(admin1.email, email1)
  451. admin2 = User.create!(
  452. login: "#{email1}-1",
  453. firstname: 'Role',
  454. lastname: "Admin1#{name}",
  455. email: email1,
  456. password: 'adminpw',
  457. active: true,
  458. roles: Role.where(name: %w[Admin Agent]),
  459. updated_by_id: 1,
  460. created_by_id: 1,
  461. )
  462. assert_equal(admin2.email, email1)
  463. admin2.destroy!
  464. admin1.destroy!
  465. Setting.set('user_email_multiple_use', false)
  466. end
  467. test 'ensure roles' do
  468. name = SecureRandom.uuid
  469. admin = User.create_or_update(
  470. login: "admin-role#{name}@example.com",
  471. firstname: 'Role',
  472. lastname: "Admin#{name}",
  473. email: "admin-role#{name}@example.com",
  474. password: 'adminpw',
  475. active: true,
  476. roles: Role.where(name: %w[Admin Agent]),
  477. updated_by_id: 1,
  478. created_by_id: 1,
  479. )
  480. customer1 = User.create_or_update(
  481. login: "user-ensure-role1-#{name}@example.com",
  482. firstname: 'Role',
  483. lastname: "Customer#{name}",
  484. email: "user-ensure-role1-#{name}@example.com",
  485. password: 'customerpw',
  486. active: true,
  487. updated_by_id: 1,
  488. created_by_id: 1,
  489. )
  490. assert_equal(customer1.role_ids.sort, Role.signup_role_ids)
  491. roles = Role.where(name: 'Agent')
  492. customer1.roles = roles
  493. customer1.save!
  494. assert_equal(customer1.role_ids.count, 1)
  495. assert_equal(customer1.role_ids.first, roles.first.id)
  496. assert_equal(customer1.roles.first.id, roles.first.id)
  497. customer1.roles = []
  498. customer1.save!
  499. assert_equal(customer1.role_ids.sort, Role.signup_role_ids)
  500. customer1.destroy!
  501. customer2 = User.create_or_update(
  502. login: "user-ensure-role2-#{name}@example.com",
  503. firstname: 'Role',
  504. lastname: "Customer#{name}",
  505. email: "user-ensure-role2-#{name}@example.com",
  506. password: 'customerpw',
  507. roles: roles,
  508. active: true,
  509. updated_by_id: 1,
  510. created_by_id: 1,
  511. )
  512. assert_equal(customer2.role_ids.count, 1)
  513. assert_equal(customer2.role_ids.first, roles.first.id)
  514. assert_equal(customer2.roles.first.id, roles.first.id)
  515. roles = Role.where(name: 'Admin')
  516. customer2.role_ids = [roles.first.id]
  517. customer2.save!
  518. assert_equal(customer2.role_ids.count, 1)
  519. assert_equal(customer2.role_ids.first, roles.first.id)
  520. assert_equal(customer2.roles.first.id, roles.first.id)
  521. customer2.roles = []
  522. customer2.save!
  523. assert_equal(customer2.role_ids.sort, Role.signup_role_ids)
  524. customer2.destroy!
  525. customer3 = User.create_or_update(
  526. login: "user-ensure-role2-#{name}@example.com",
  527. firstname: 'Role',
  528. lastname: "Customer#{name}",
  529. email: "user-ensure-role2-#{name}@example.com",
  530. password: 'customerpw',
  531. roles: roles,
  532. active: true,
  533. updated_by_id: 1,
  534. created_by_id: 1,
  535. )
  536. customer3.roles = Role.where(name: %w[Admin Agent])
  537. customer3.roles.each do |role|
  538. assert_not_equal(role.name, 'Customer')
  539. end
  540. customer3.roles = Role.where(name: 'Admin')
  541. customer3.roles.each do |role|
  542. assert_not_equal(role.name, 'Customer')
  543. end
  544. customer3.roles = Role.where(name: 'Agent')
  545. customer3.roles.each do |role|
  546. assert_not_equal(role.name, 'Customer')
  547. end
  548. customer3.destroy!
  549. admin.destroy!
  550. end
  551. test 'permission' do
  552. test_role_1 = Role.create_or_update(
  553. name: 'Test1',
  554. note: 'To configure your system.',
  555. preferences: {
  556. not: ['Test3'],
  557. },
  558. updated_by_id: 1,
  559. created_by_id: 1
  560. )
  561. test_role_2 = Role.create_or_update(
  562. name: 'Test2',
  563. note: 'To work on Tickets.',
  564. preferences: {
  565. not: ['Test3'],
  566. },
  567. updated_by_id: 1,
  568. created_by_id: 1
  569. )
  570. test_role_3 = Role.create_or_update(
  571. name: 'Test3',
  572. note: 'People who create Tickets ask for help.',
  573. preferences: {
  574. not: %w[Test1 Test2],
  575. },
  576. updated_by_id: 1,
  577. created_by_id: 1
  578. )
  579. test_role_4 = Role.create_or_update(
  580. name: 'Test4',
  581. note: 'Access the report area.',
  582. preferences: {},
  583. created_by_id: 1,
  584. updated_by_id: 1,
  585. )
  586. name = SecureRandom.uuid
  587. assert_raises(RuntimeError) do
  588. User.create_or_update(
  589. login: "customer-role#{name}@example.com",
  590. firstname: 'Role',
  591. lastname: "Customer#{name}",
  592. email: "customer-role#{name}@example.com",
  593. password: 'customerpw',
  594. active: true,
  595. roles: [test_role_1, test_role_3],
  596. updated_by_id: 1,
  597. created_by_id: 1,
  598. )
  599. end
  600. assert_raises(RuntimeError) do
  601. User.create_or_update(
  602. login: "customer-role#{name}@example.com",
  603. firstname: 'Role',
  604. lastname: "Customer#{name}",
  605. email: "customer-role#{name}@example.com",
  606. password: 'customerpw',
  607. active: true,
  608. roles: [test_role_2, test_role_3],
  609. updated_by_id: 1,
  610. created_by_id: 1,
  611. )
  612. end
  613. user1 = User.create_or_update(
  614. login: "customer-role#{name}@example.com",
  615. firstname: 'Role',
  616. lastname: "Customer#{name}",
  617. email: "customer-role#{name}@example.com",
  618. password: 'customerpw',
  619. active: true,
  620. roles: [test_role_1, test_role_2],
  621. updated_by_id: 1,
  622. created_by_id: 1,
  623. )
  624. assert(user1.role_ids.include?(test_role_1.id))
  625. assert(user1.role_ids.include?(test_role_2.id))
  626. assert_not(user1.role_ids.include?(test_role_3.id))
  627. assert_not(user1.role_ids.include?(test_role_4.id))
  628. user1 = User.create_or_update(
  629. login: "customer-role#{name}@example.com",
  630. firstname: 'Role',
  631. lastname: "Customer#{name}",
  632. email: "customer-role#{name}@example.com",
  633. password: 'customerpw',
  634. active: true,
  635. roles: [test_role_1, test_role_4],
  636. updated_by_id: 1,
  637. created_by_id: 1,
  638. )
  639. assert(user1.role_ids.include?(test_role_1.id))
  640. assert_not(user1.role_ids.include?(test_role_2.id))
  641. assert_not(user1.role_ids.include?(test_role_3.id))
  642. assert(user1.role_ids.include?(test_role_4.id))
  643. assert_raises(RuntimeError) do
  644. User.create_or_update(
  645. login: "customer-role#{name}@example.com",
  646. firstname: 'Role',
  647. lastname: "Customer#{name}",
  648. email: "customer-role#{name}@example.com",
  649. password: 'customerpw',
  650. active: true,
  651. roles: [test_role_1, test_role_3],
  652. updated_by_id: 1,
  653. created_by_id: 1,
  654. )
  655. end
  656. assert_raises(RuntimeError) do
  657. User.create_or_update(
  658. login: "customer-role#{name}@example.com",
  659. firstname: 'Role',
  660. lastname: "Customer#{name}",
  661. email: "customer-role#{name}@example.com",
  662. password: 'customerpw',
  663. active: true,
  664. roles: [test_role_2, test_role_3],
  665. updated_by_id: 1,
  666. created_by_id: 1,
  667. )
  668. end
  669. assert(user1.role_ids.include?(test_role_1.id))
  670. assert_not(user1.role_ids.include?(test_role_2.id))
  671. assert_not(user1.role_ids.include?(test_role_3.id))
  672. assert(user1.role_ids.include?(test_role_4.id))
  673. end
  674. test 'permission default' do
  675. name = SecureRandom.uuid
  676. admin_count = User.with_permissions('admin').count
  677. admin = User.create_or_update(
  678. login: "admin-role#{name}@example.com",
  679. firstname: 'Role',
  680. lastname: "Admin#{name}",
  681. email: "admin-role#{name}@example.com",
  682. password: 'adminpw',
  683. active: true,
  684. roles: Role.where(name: %w[Admin Agent]),
  685. updated_by_id: 1,
  686. created_by_id: 1,
  687. )
  688. agent_count = User.with_permissions('ticket.agent').count
  689. agent = User.create_or_update(
  690. login: "agent-role#{name}@example.com",
  691. firstname: 'Role',
  692. lastname: "Agent#{name}",
  693. email: "agent-role#{name}@example.com",
  694. password: 'agentpw',
  695. active: true,
  696. roles: Role.where(name: 'Agent'),
  697. updated_by_id: 1,
  698. created_by_id: 1,
  699. )
  700. customer_count = User.with_permissions('ticket.customer').count
  701. customer = User.create_or_update(
  702. login: "customer-role#{name}@example.com",
  703. firstname: 'Role',
  704. lastname: "Customer#{name}",
  705. email: "customer-role#{name}@example.com",
  706. password: 'customerpw',
  707. active: true,
  708. roles: Role.where(name: 'Customer'),
  709. updated_by_id: 1,
  710. created_by_id: 1,
  711. )
  712. users = User.with_permissions('not_existing')
  713. assert(users.blank?)
  714. users = User.with_permissions('admin')
  715. assert_equal(admin_count + 1, users.count)
  716. assert_equal(admin.login, users.last.login)
  717. users = User.with_permissions('admin.session')
  718. assert_equal(admin_count + 1, users.count)
  719. assert_equal(admin.login, users.last.login)
  720. users = User.with_permissions(['admin.session', 'not_existing'])
  721. assert_equal(admin_count + 1, users.count)
  722. assert_equal(admin.login, users.last.login)
  723. users = User.with_permissions('ticket.agent')
  724. assert_equal(agent_count + 1, users.count)
  725. assert_equal(agent.login, users.last.login)
  726. users = User.with_permissions(['ticket.agent', 'not_existing'])
  727. assert_equal(agent_count + 1, users.count)
  728. assert_equal(agent.login, users.last.login)
  729. users = User.with_permissions('ticket.customer')
  730. assert_equal(customer_count + 1, users.count)
  731. assert_equal(customer.login, users.last.login)
  732. users = User.with_permissions(['ticket.customer', 'not_existing'])
  733. assert_equal(customer_count + 1, users.count)
  734. assert_equal(customer.login, users.last.login)
  735. end
  736. test 'min admin permission check' do
  737. # delete inital admin
  738. User.find_by(login: 'admin@example.com').destroy
  739. # store current admin count
  740. admin_count_inital = User.with_permissions('admin').count
  741. assert_equal(0, admin_count_inital)
  742. # create two admin users
  743. random = SecureRandom.uuid
  744. admin1 = User.create_or_update(
  745. login: "1admin-role#{random}@example.com",
  746. firstname: 'Role',
  747. lastname: "Admin#{random}",
  748. email: "admin-role#{random}@example.com",
  749. password: 'adminpw',
  750. active: true,
  751. roles: Role.where(name: %w[Admin Agent]),
  752. updated_by_id: 1,
  753. created_by_id: 1,
  754. )
  755. random = SecureRandom.uuid
  756. admin2 = User.create_or_update(
  757. login: "2admin-role#{random}@example.com",
  758. firstname: 'Role',
  759. lastname: "Admin#{random}",
  760. email: "admin-role#{random}@example.com",
  761. password: 'adminpw',
  762. active: true,
  763. roles: Role.where(name: %w[Admin Agent]),
  764. updated_by_id: 1,
  765. created_by_id: 1,
  766. )
  767. random = SecureRandom.uuid
  768. admin3 = User.create_or_update(
  769. login: "2admin-role#{random}@example.com",
  770. firstname: 'Role',
  771. lastname: "Admin#{random}",
  772. email: "admin-role#{random}@example.com",
  773. password: 'adminpw',
  774. active: true,
  775. roles: Role.where(name: %w[Admin Agent]),
  776. updated_by_id: 1,
  777. created_by_id: 1,
  778. )
  779. admin_count_inital = User.with_permissions('admin').count
  780. assert_equal(3, admin_count_inital)
  781. admin1.update!(roles: Role.where(name: %w[Agent]))
  782. admin_count_inital = User.with_permissions('admin').count
  783. assert_equal(2, admin_count_inital)
  784. admin2.update!(roles: Role.where(name: %w[Agent]))
  785. admin_count_inital = User.with_permissions('admin').count
  786. assert_equal(1, admin_count_inital)
  787. assert_raises(Exceptions::UnprocessableEntity) do
  788. admin3.update!(roles: Role.where(name: %w[Agent]))
  789. end
  790. admin_count_inital = User.with_permissions('admin').count
  791. assert_equal(1, admin_count_inital)
  792. assert_raises(Exceptions::UnprocessableEntity) do
  793. admin3.active = false
  794. admin3.save!
  795. end
  796. assert_equal(1, User.with_permissions('admin').count)
  797. admin_role = Role.find_by(name: 'Admin')
  798. assert_raises(Exceptions::UnprocessableEntity) do
  799. admin_role.active = false
  800. admin_role.save!
  801. end
  802. assert_raises(Exceptions::UnprocessableEntity) do
  803. admin_role.permission_revoke('admin')
  804. end
  805. assert_equal(1, User.with_permissions('admin').count)
  806. end
  807. test 'only valid agent in group permission check' do
  808. name = SecureRandom.uuid
  809. group = Group.create!(
  810. name: "ValidAgentGroupPermission-#{name}",
  811. active: true,
  812. updated_by_id: 1,
  813. created_by_id: 1,
  814. )
  815. roles = Role.where(name: 'Agent')
  816. User.create_or_update(
  817. login: "valid_agent_permission-1#{name}@example.com",
  818. firstname: 'valid_agent_group_permission-1',
  819. lastname: "Agent#{name}",
  820. email: "valid_agent_permission-1#{name}@example.com",
  821. password: 'agentpw',
  822. active: true,
  823. roles: roles,
  824. groups: [group],
  825. updated_by_id: 1,
  826. created_by_id: 1,
  827. )
  828. agent2 = User.create_or_update(
  829. login: "valid_agent_permission-2#{name}@example.com",
  830. firstname: 'valid_agent_group_permission-2',
  831. lastname: "Agent#{name}",
  832. email: "valid_agent_permission-2#{name}@example.com",
  833. password: 'agentpw',
  834. active: true,
  835. roles: roles,
  836. groups: [group],
  837. updated_by_id: 1,
  838. created_by_id: 1,
  839. )
  840. assert_equal(2, User.group_access(group.id, 'full').count)
  841. agent2.active = false
  842. agent2.save!
  843. assert_equal(1, User.group_access(group.id, 'full').count)
  844. agent2.active = true
  845. agent2.save!
  846. assert_equal(2, User.group_access(group.id, 'full').count)
  847. roles = Role.where(name: 'Customer')
  848. agent2.roles = roles
  849. agent2.save!
  850. assert_equal(1, User.group_access(group.id, 'full').count)
  851. end
  852. test 'preferences[:notification_sound][:enabled] value check' do
  853. name = SecureRandom.uuid
  854. roles = Role.where(name: 'Agent')
  855. agent1 = User.create!(
  856. login: "agent-default-preferences-1#{name}@example.com",
  857. firstname: 'valid_agent_group_permission-1',
  858. lastname: "Agent#{name}",
  859. email: "agent-default-preferences-1#{name}@example.com",
  860. password: 'agentpw',
  861. active: true,
  862. roles: roles,
  863. preferences: {
  864. notification_sound: {
  865. enabled: true,
  866. }
  867. },
  868. updated_by_id: 1,
  869. created_by_id: 1,
  870. )
  871. assert_equal(true, agent1.preferences[:notification_sound][:enabled])
  872. agent2 = User.create!(
  873. login: "agent-default-preferences-2#{name}@example.com",
  874. firstname: 'valid_agent_group_permission-2',
  875. lastname: "Agent#{name}",
  876. email: "agent-default-preferences-2#{name}@example.com",
  877. password: 'agentpw',
  878. active: true,
  879. roles: roles,
  880. preferences: {
  881. notification_sound: {
  882. enabled: false,
  883. }
  884. },
  885. updated_by_id: 1,
  886. created_by_id: 1,
  887. )
  888. assert_equal(false, agent2.preferences[:notification_sound][:enabled])
  889. agent3 = User.create!(
  890. login: "agent-default-preferences-3#{name}@example.com",
  891. firstname: 'valid_agent_group_permission-3',
  892. lastname: "Agent#{name}",
  893. email: "agent-default-preferences-3#{name}@example.com",
  894. password: 'agentpw',
  895. active: true,
  896. roles: roles,
  897. preferences: {
  898. notification_sound: {
  899. enabled: true,
  900. }
  901. },
  902. updated_by_id: 1,
  903. created_by_id: 1,
  904. )
  905. assert_equal(true, agent3.preferences[:notification_sound][:enabled])
  906. agent3.preferences[:notification_sound][:enabled] = 'false'
  907. agent3.save!
  908. agent3.reload
  909. assert_equal(false, agent3.preferences[:notification_sound][:enabled])
  910. agent4 = User.create!(
  911. login: "agent-default-preferences-4#{name}@example.com",
  912. firstname: 'valid_agent_group_permission-4',
  913. lastname: "Agent#{name}",
  914. email: "agent-default-preferences-4#{name}@example.com",
  915. password: 'agentpw',
  916. active: true,
  917. roles: roles,
  918. preferences: {
  919. notification_sound: {
  920. enabled: false,
  921. }
  922. },
  923. updated_by_id: 1,
  924. created_by_id: 1,
  925. )
  926. assert_equal(false, agent4.preferences[:notification_sound][:enabled])
  927. agent4.preferences[:notification_sound][:enabled] = 'true'
  928. agent4.save!
  929. agent4.reload
  930. assert_equal(true, agent4.preferences[:notification_sound][:enabled])
  931. agent4.preferences[:notification_sound][:enabled] = 'invalid'
  932. assert_raises(Exceptions::UnprocessableEntity) do
  933. agent4.save!
  934. end
  935. assert_raises(Exceptions::UnprocessableEntity) do
  936. User.create!(
  937. login: "agent-default-preferences-5#{name}@example.com",
  938. firstname: 'valid_agent_group_permission-5',
  939. lastname: "Agent#{name}",
  940. email: "agent-default-preferences-5#{name}@example.com",
  941. password: 'agentpw',
  942. active: true,
  943. roles: roles,
  944. preferences: {
  945. notification_sound: {
  946. enabled: 'invalid string',
  947. }
  948. },
  949. updated_by_id: 1,
  950. created_by_id: 1,
  951. )
  952. end
  953. end
  954. test 'cleanup references on destroy' do
  955. agent1 = User.create!(
  956. login: "agent-cleanup_check-1#{name}@example.com",
  957. firstname: 'valid_agent_group_permission-1',
  958. lastname: "Agent#{name}",
  959. email: "agent-cleanup_check-1#{name}@example.com",
  960. password: 'agentpw',
  961. active: true,
  962. roles: Role.where(name: 'Agent'),
  963. groups: Group.all,
  964. updated_by_id: 1,
  965. created_by_id: 1,
  966. )
  967. agent1_id = agent1.id
  968. assert_equal(1, Avatar.list('User', agent1_id).count)
  969. UserDevice.add(
  970. 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/44.0.2403.107 Safari/537.36',
  971. '91.115.248.231',
  972. agent1_id,
  973. 'fingerprint1234',
  974. 'session',
  975. )
  976. assert_equal(1, UserDevice.where(user_id: agent1_id).count)
  977. OnlineNotification.add(
  978. type: 'Assigned to you',
  979. object: 'Ticket',
  980. o_id: 1,
  981. seen: false,
  982. user_id: agent1_id,
  983. created_by_id: 1,
  984. updated_by_id: 1,
  985. created_at: Time.zone.now,
  986. updated_at: Time.zone.now,
  987. )
  988. assert_equal(1, OnlineNotification.where(user_id: agent1_id).count)
  989. Authorization.create!(
  990. user: agent1,
  991. uid: '123',
  992. username: '123',
  993. provider: 'some',
  994. token: 'token',
  995. secret: 'secret',
  996. )
  997. assert_equal(1, Authorization.where(user_id: agent1_id).count)
  998. Cti::CallerId.maybe_add(
  999. caller_id: '49123456789',
  1000. comment: 'Hairdresser Bob Smith, San Francisco', # optional
  1001. level: 'maybe', # known|maybe
  1002. user_id: agent1_id, # optional
  1003. object: 'Ticket',
  1004. o_id: 1,
  1005. )
  1006. assert_equal(1, Cti::CallerId.where(user_id: agent1_id).count)
  1007. Taskbar.create!(
  1008. key: 'Ticket-1',
  1009. callback: 'TicketZoom',
  1010. params: {
  1011. id: 1,
  1012. },
  1013. state: {},
  1014. user_id: agent1_id,
  1015. prio: 1,
  1016. notify: false,
  1017. )
  1018. assert_equal(1, Taskbar.where(user_id: agent1_id).count)
  1019. ticket1 = Ticket.create!(
  1020. title: 'test 1234-1',
  1021. group: Group.lookup(name: 'Users'),
  1022. customer_id: 2,
  1023. owner_id: 2,
  1024. updated_by_id: 1,
  1025. created_by_id: 1,
  1026. )
  1027. RecentView.log(ticket1.class.to_s, ticket1.id, agent1)
  1028. assert_equal(1, RecentView.where(created_by_id: agent1_id).count)
  1029. Token.create!(action: 'api', user_id: agent1_id)
  1030. StatsStore.create(
  1031. stats_storable: agent1,
  1032. key: 'some_key',
  1033. data: { A: 1, B: 2 },
  1034. created_at: Time.zone.now,
  1035. created_by_id: 1,
  1036. )
  1037. item = StatsStore.find_by(
  1038. stats_storable: agent1,
  1039. key: 'some_key',
  1040. )
  1041. assert(item)
  1042. agent1.destroy!
  1043. assert_equal(0, UserDevice.where(user_id: agent1_id).count)
  1044. assert_equal(0, Avatar.list('User', agent1_id, false).count)
  1045. assert_equal(0, OnlineNotification.where(user_id: agent1_id).count)
  1046. assert_equal(0, Authorization.where(user_id: agent1_id).count)
  1047. assert_equal(0, Cti::CallerId.where(user_id: agent1_id).count)
  1048. assert_equal(0, Taskbar.where(user_id: agent1_id).count)
  1049. assert_equal(0, RecentView.where(created_by_id: agent1_id).count)
  1050. assert_equal(0, Token.where(user_id: agent1_id).count)
  1051. assert_equal(0, Token.where(user_id: agent1_id).count)
  1052. item = StatsStore.find_by(
  1053. stats_storable: agent1,
  1054. key: 'some_key',
  1055. )
  1056. assert_nil(item)
  1057. end
  1058. test 'adding group drops cache' do
  1059. agent1 = User.create!(
  1060. login: "agent-cleanup_check-1#{name}@example.com",
  1061. firstname: 'valid_agent_group_permission-1',
  1062. lastname: "Agent#{name}",
  1063. email: "agent-cleanup_check-1#{name}@example.com",
  1064. password: 'agentpw',
  1065. active: true,
  1066. roles: Role.where(name: 'Agent'),
  1067. groups: Group.all,
  1068. updated_by_id: 1,
  1069. created_by_id: 1,
  1070. )
  1071. group1 = Group.create_or_update(
  1072. name: "GroupWithoutPermission-#{SecureRandom.uuid}",
  1073. active: true,
  1074. updated_by_id: 1,
  1075. created_by_id: 1,
  1076. )
  1077. differences = %w[
  1078. group1.attributes_with_association_ids['user_ids'].count
  1079. agent1.attributes_with_association_ids['group_ids'].keys.count
  1080. ]
  1081. assert_difference differences, 1 do
  1082. agent1.groups << group1
  1083. end
  1084. end
  1085. end