gdpr_rails 0.3.0 → 0.3.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (255) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +10 -6
  3. data/app/controllers/policy_manager/application_controller.rb +1 -1
  4. data/app/controllers/policy_manager/portability_requests_controller.rb +6 -2
  5. data/app/controllers/policy_manager/terms_controller.rb +3 -1
  6. data/app/controllers/policy_manager/user_portability_requests_controller.rb +23 -20
  7. data/app/controllers/policy_manager/user_terms_controller.rb +6 -3
  8. data/app/mailers/policy_manager/application_mailer.rb +4 -2
  9. data/app/mailers/policy_manager/portability_mailer.rb +3 -3
  10. data/app/models/policy_manager/concerns/user_behavior.rb +1 -0
  11. data/app/models/policy_manager/user_term.rb +4 -3
  12. data/app/views/layouts/policy_manager/application.html.erb +2 -2
  13. data/app/views/layouts/policy_manager/portability.erb +5 -0
  14. data/app/views/policy_manager/401.erb +1 -0
  15. data/app/views/policy_manager/user_terms/show.html.erb +1 -1
  16. data/app/views/policy_manager/user_terms/show.json.jbuilder +2 -2
  17. data/lib/policy_manager/config.rb +2 -1
  18. data/lib/policy_manager/engine.rb +6 -0
  19. data/lib/policy_manager/exporter.rb +1 -1
  20. data/lib/policy_manager/exporter/handler.rb +1 -1
  21. data/lib/policy_manager/exporter/view.rb +0 -1
  22. data/lib/policy_manager/version.rb +1 -1
  23. data/spec/controllers/policy_manager/categories_controller_spec.rb +51 -0
  24. data/spec/controllers/policy_manager/portability_requests_controller_spec.rb +85 -0
  25. data/spec/controllers/policy_manager/terms_controller_spec.rb +125 -0
  26. data/spec/controllers/policy_manager/user_portability_requests_controller_spec.rb +76 -0
  27. data/spec/controllers/policy_manager/user_terms_controller_test.rb +92 -0
  28. data/spec/dummy/Rakefile +6 -0
  29. data/spec/dummy/app/assets/config/manifest.js +5 -0
  30. data/spec/dummy/app/assets/javascripts/application.js +13 -0
  31. data/spec/dummy/app/assets/javascripts/cable.js +13 -0
  32. data/spec/dummy/app/assets/stylesheets/application.css +15 -0
  33. data/spec/dummy/app/channels/application_cable/channel.rb +4 -0
  34. data/spec/dummy/app/channels/application_cable/connection.rb +4 -0
  35. data/spec/dummy/app/controllers/application_controller.rb +4 -0
  36. data/spec/dummy/app/helpers/application_helper.rb +3 -0
  37. data/spec/dummy/app/helpers/user_helper.rb +2 -0
  38. data/spec/dummy/app/jobs/application_job.rb +2 -0
  39. data/spec/dummy/app/mailers/application_mailer.rb +4 -0
  40. data/spec/dummy/app/models/application_record.rb +3 -0
  41. data/spec/dummy/app/models/user.rb +26 -0
  42. data/spec/dummy/app/views/collection.json.jbuilder +11 -0
  43. data/spec/dummy/app/views/layouts/application.html.erb +14 -0
  44. data/spec/dummy/app/views/layouts/mailer.html.erb +13 -0
  45. data/spec/dummy/app/views/layouts/mailer.text.erb +1 -0
  46. data/spec/dummy/app/views/layouts/portability.erb +15 -0
  47. data/spec/dummy/app/views/layouts/portability_requests.erb +14 -0
  48. data/spec/dummy/app/views/template.erb +1 -0
  49. data/spec/dummy/app/views/template.haml +1 -0
  50. data/spec/dummy/app/views/template.json.jbuilder +16 -0
  51. data/spec/dummy/app/views/test.erb +2 -0
  52. data/spec/dummy/app/views/user_mailer/admin.html.erb +1 -0
  53. data/spec/dummy/app/views/user_mailer/complete.html.erb +5 -0
  54. data/spec/dummy/app/views/user_mailer/progress.html.erb +1 -0
  55. data/spec/dummy/bin/bundle +3 -0
  56. data/spec/dummy/bin/rails +4 -0
  57. data/spec/dummy/bin/rake +4 -0
  58. data/spec/dummy/bin/setup +38 -0
  59. data/spec/dummy/bin/update +29 -0
  60. data/spec/dummy/bin/yarn +11 -0
  61. data/spec/dummy/config.ru +5 -0
  62. data/spec/dummy/config/application.rb +18 -0
  63. data/spec/dummy/config/boot.rb +5 -0
  64. data/spec/dummy/config/cable.yml +10 -0
  65. data/spec/dummy/config/database.yml +40 -0
  66. data/spec/dummy/config/database.yml.test +11 -0
  67. data/spec/dummy/config/environment.rb +5 -0
  68. data/spec/dummy/config/environments/development.rb +54 -0
  69. data/spec/dummy/config/environments/production.rb +91 -0
  70. data/spec/dummy/config/environments/test.rb +42 -0
  71. data/spec/dummy/config/initializers/application_controller_renderer.rb +8 -0
  72. data/spec/dummy/config/initializers/assets.rb +14 -0
  73. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
  74. data/spec/dummy/config/initializers/cookies_serializer.rb +5 -0
  75. data/spec/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  76. data/spec/dummy/config/initializers/inflections.rb +16 -0
  77. data/spec/dummy/config/initializers/mime_types.rb +4 -0
  78. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
  79. data/spec/dummy/config/locales/en.yml +33 -0
  80. data/spec/dummy/config/puma.rb +56 -0
  81. data/spec/dummy/config/routes.rb +3 -0
  82. data/spec/dummy/config/secrets.yml +32 -0
  83. data/spec/dummy/config/spring.rb +6 -0
  84. data/spec/dummy/db/development.sqlite3 +0 -0
  85. data/spec/dummy/db/migrate/20180326193826_create_users.rb +9 -0
  86. data/spec/dummy/db/schema.rb +56 -0
  87. data/spec/dummy/log/development.log +326 -0
  88. data/spec/dummy/log/test.log +191664 -0
  89. data/spec/dummy/package.json +5 -0
  90. data/spec/dummy/public/401.html +67 -0
  91. data/spec/dummy/public/404.html +67 -0
  92. data/spec/dummy/public/422.html +67 -0
  93. data/spec/dummy/public/500.html +66 -0
  94. data/spec/dummy/public/apple-touch-icon-precomposed.png +0 -0
  95. data/spec/dummy/public/apple-touch-icon.png +0 -0
  96. data/spec/dummy/public/favicon.ico +0 -0
  97. data/spec/dummy/test/fixtures/users.yml +7 -0
  98. data/spec/dummy/test/models/user_test.rb +7 -0
  99. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/--/--mfnHuBeUWp4S0t5Gy9k8VFIhwH9_LeypHDTu0Tr_Y.cache +1 -0
  100. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/-N/-NoFiyuUvy7n3K1PxiEyF7_ntONf3urTihjqgwKchcg.cache +0 -0
  101. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/-X/-XFR33TgzW2uZ8FmmS1qlvD_wt-ox_qSWUqkuGQ6bNY.cache +1 -0
  102. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/-Y/-YgMOSbIN0nMswWct7su9H9L0ICRZaRq34uti66AccM.cache +0 -0
  103. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/0D/0DLlhyih7JQM6a36xn80gBEsL2G82TErD8Dj_whhN-U.cache +0 -0
  104. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/0g/0gU8kGXleEoducYsLkjy0I4rqnsgoWaK8lr0kAj6bp8.cache +1 -0
  105. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/1v/1vjyDvVwQZlnzxWly1brkoOTCuyetgHeuvD_e6dGKyM.cache +0 -0
  106. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/27/27CLtUz28kIcg6tIfaI14dpsrgCp7ic4eWUty-oq-sU.cache +3 -0
  107. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/2F/2FM4u0wEV34qcad5bAQ22XooiME80Q0nmdLaov7r7rE.cache +0 -0
  108. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/2y/2Y306WtiuaczRMe98h_Ef4LsZ7wmIC8iaa8c8EJinbs.cache +0 -0
  109. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/2y/2yX2unfUzEDiZ4-YOag_nKmTGmuMxpM11mKaJOvfOlQ.cache +1 -0
  110. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/3M/3Me2fKJpLVszUwxPRDsRAmn-4i9xo32wikeSt4U2wP8.cache +1 -0
  111. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/45/45ictadc7ZQCwBtuyUUnDphpgBJ7TJ6pcfxw3Rm8Vrs.cache +1 -0
  112. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/4P/4PwXz69YXiFINqI_IN8j6RKuEt3OdudXYYLnaUq7rjo.cache +1 -0
  113. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/4h/4hzVRVCmNzCaipE8Gr5-DBLrbCGbWpjcyBY9LdEj3jo.cache +0 -0
  114. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/4x/4xpoeWRviufHh_q5whnyBr0pk8UQxCZPYQ6ftOStGLU.cache +0 -0
  115. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/54/54rewMnifJtcFqBk72TyTygb95Ttwy9bKfBZExpc-C0.cache +1 -0
  116. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/58/58sAgzwP4eFt7yuB9XYB1mxdOz0FJEh-xIOdTwXXE2Y.cache +0 -0
  117. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/5h/5hHJvRWBp2bv5Ree05fgFaFaPqfaRhMLTEdkG-O6aVM.cache +0 -0
  118. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/5m/5mO5S2MfbEUVxkXH46amJgMg-T2BHvPkW-PHDU1kP68.cache +0 -0
  119. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/5r/5rJJjxkhn8Z92_UbvZfgoL5BcowL6nZNszQvsginLnk.cache +1 -0
  120. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/6B/6B2r6p0vt9YHgITkhKEgJagg9pCZvP28XC8UOVcbLSQ.cache +1 -0
  121. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/7d/7dwWkcsTuGWyWtwftKHD_gXp9W4odm_5You_aKR4fsg.cache +0 -0
  122. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/7g/7gQSNgL-2DO1ds5Jv0PIG150XXV5HrGgSE1_9Y9lTGw.cache +0 -0
  123. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/87/87l8g48DzMElacGqDKT2Tw4SN-vPuWe-87l1WVSGGSU.cache +0 -0
  124. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/8M/8MYgLnjJJ3blsJWL9xRH67td4kEWctoW8vYSPk16D4E.cache +1 -0
  125. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/8r/8rGgH_J5ehLhHbE7cWWoP9Zec-2rlNUjBS9UFF-2ZIM.cache +3 -0
  126. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/9j/9j6v9HXgAkMtDkZYoqP7GOaorSZsL5Rj7hbAazvTOzc.cache +0 -0
  127. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/A0/A0XqQCJjWHzYPT5e9-HBsso43aW4FSEDl0k6e4VGR2k.cache +0 -0
  128. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Aw/AwefclPt5cLFlWCSECVgQvodBrq_1V9JWkOGvfpoVe0.cache +1 -0
  129. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Bm/Bm3fgDgbZDpu1Tg8RWJNvhqP_EtKfEUezpd5RtvfnVY.cache +0 -0
  130. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/DU/DUUFwyjNig6oW4WouEVhntJB_JYYRXhEnvXjUhz2SS8.cache +1 -0
  131. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Ex/ExToesB1w5_4dhyfTB7w2rnEW3JYsyiDCwQS5YryS6c.cache +1 -0
  132. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/FG/FGTqZQ-ICnWRw_FIx5roRi8IATSdS5OkwrMtS3XtXBY.cache +0 -0
  133. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Fi/Fi7XjszeLrn8TVUuJQRwrmmVolcJXedDZtlfXb0e0_8.cache +0 -0
  134. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Gk/GkeSNzAIKac6T0REp80cIYHQW869pVVY8_jS7YbxfXQ.cache +0 -0
  135. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/H0/H0IluIpOXOr2BxNlpAjzwArc75w56IB4mlScIpBdQ24.cache +1 -0
  136. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/H1/H1LhaUgwIO1D2k0RMMo2na3l-Elc5xpQKK5iBOp4F5I.cache +0 -0
  137. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/JU/JUxqlgeXXBppIjEN9UyWuqzr4PfBPsUj011p_oO71do.cache +1 -0
  138. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/K_/K_D8m4e3tDZRmnK3CKTP8bP5kmay4w-Td9Cu5U-ED-I.cache +0 -0
  139. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Kb/KbL79CL_ql47tz33zx6iBjdGneWja5vKKEEAkW_w7NM.cache +0 -0
  140. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Kb/KbZGMmB8DJ2BA4mcdSXN4bebOMd0j8s4PkB0S-23XfE.cache +0 -0
  141. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/L3/L31_eyjOuFh92q-RAafvpnxszCNW9HoObtWVS4gpQHo.cache +1 -0
  142. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/LL/LLlnPIuN7QMIMMQ5nRnTNtLtkMx1LXfhg6fs2tDYaSk.cache +0 -0
  143. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Lm/LmnZza-YSYZY-dEHFm3EWLFVvsxsIOnCKJ5-3zlrOKk.cache +0 -0
  144. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Lu/LuFRHx4qb0l1K_A0pjAOQO8llKL2WaJRMKuH9JMNVw0.cache +0 -0
  145. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/OA/OAtvFgJJQnarYrhlAK-vSgn9egwT1NDz78YqjstXCBA.cache +1 -0
  146. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/OY/OYj0e5ox1ill6KB0XxgjT7dpx88kd1ow52UsaJwSHtE.cache +1 -0
  147. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Oc/OcrdvWm5dtFEHIomtrRuAU5SquzymBRnNyRpx-cEWvw.cache +2 -0
  148. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Qo/QoIXukdcQouQLyMkre-k41LX_pHd0kKo57VZ79D9GS8.cache +0 -0
  149. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Qp/QpwXeqd_RNMk--6i6e5jHxRvn5PaARBKDucD5In1F-s.cache +0 -0
  150. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/TN/TN4TNVw5nI_0WW6X9CsSG4eDr1LJQclFhQNHtGOb2QA.cache +1 -0
  151. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/U0/U0FxO18TfrZeRQx8V4zoWPSskXIA2s9MHtP3lJfONWs.cache +1 -0
  152. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/UC/UCvPD9uXZwJeEm-1pmKEMfgj4DjvUOf4dx2jhhhlv6k.cache +3 -0
  153. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Ue/UeAHhO5lBiMllQvT8e5iL1ddSRsZxH0BHjYjHdjcSTY.cache +3 -0
  154. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Ui/UiRXGeBaY88moPjIjUguzeNSGWaRyVS8tSCNjnwfwy8.cache +0 -0
  155. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Us/Us-RVGQ4-a94Pu0yyugJVYf4RxGXf-xlPqYtAiwYWjU.cache +0 -0
  156. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Ut/UtGzFRo4wbBgA2fF_MZ8krZa159Z1A6aoxGAXDPmZVw.cache +2 -0
  157. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/VG/VGChoLzfgrn9FobW4pun_Jde-mQ3MgDloMfYR8m6drM.cache +1 -0
  158. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Vk/VkQUb2zhn-uTclXve3ha-oUJAN9l-rmuxFVuNSz9KYk.cache +1 -0
  159. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Vm/VmFxkBmoolMrxZI2hEaFfp8wPGc33_oxQoGyaFsh70M.cache +0 -0
  160. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/W-/W-pTadlsf_Vpkn5yWhaLXUV1aKGLvP0nhxewZnwjGBc.cache +0 -0
  161. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/W3/W3Hibs-2ZXTSO00vDV2YhmzHjmvegpc-rARFtZTgyy8.cache +1 -0
  162. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/X-/X-RlCEy2cN8eQ1d2pqsNwUZ4H4ej8ztuZ0MvZKgKmkk.cache +2 -0
  163. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/X8/X8wS5wYKKTutqBv6YpD5Gpm2s_wyBehAQww9qxgE96Q.cache +1 -0
  164. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Yc/Yc2cY6cLNXFppCCbQSm3-FiGXtBtRa3Tq1RKxgARljA.cache +1 -0
  165. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Yo/YoZWJS_zeJGl5xpGe-YaWy9J3RRNaVwVnMLNbrWN6oM.cache +1 -0
  166. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/ZI/ZIsNAJOrG64AKjeXnqm0vARAqYLKq6PVhiiYDZXsuCg.cache +1 -0
  167. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/ZX/ZX7fzX0ySlnLNNqdDO5sM6XA_ajPzRgqPCnLt8hVYcA.cache +1 -0
  168. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Zy/Zy0_Bbsl6EQYVutKT0oH9YCq2Cl53wPVkZn0dqjK4xk.cache +1 -0
  169. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/_c/_c__nkkVWonX6jTabzOJ1VjpZtlO8F43EC-KB4ZaIZg.cache +1 -0
  170. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/a5/A5zisQ1zyxFgISw9mztcz0XbHTdurklNjleMx1aUA5U.cache +1 -0
  171. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/a5/a5O3NIdzPl0cdbCdVkYA9P9lpNRPjyMCViolW9XhLVo.cache +1 -0
  172. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/aS/aS6nnaCaO7L6EkZaEVpCmd8KMTcB7_Z2RzKYn9y4EQ0.cache +1 -0
  173. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/am/amrEpszeLKtdRNJO_wvfR4CrCz0Ir06_TX8B7pq1cBg.cache +0 -0
  174. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/bD/bD1YRW0nGSZSi6Yjf72ndpk0mSsnE2bIqF9HFpuQvJQ.cache +1 -0
  175. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/bL/bLTJSRS-mPPtzb3ADwW73pG5RKqBMNyRSzmSykFI4aE.cache +1 -0
  176. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/bL/bLpXenoWnkxKfzeQ13hl4RPrP7Bz-CtaezkMzIQlza8.cache +1 -0
  177. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/b_/b_Itlk9QZZd7Rvf8kcA4yLP1R5Acu7jB-m1xQiSU0qE.cache +0 -0
  178. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/dG/dGSOHXa2AZ0InnD5tvsjuust4kitbUMQ2Sl_m8wAyf8.cache +1 -0
  179. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/dk/dkEweQBtw4njrs6iVJnj7ETQ4TymXPZEco06LxR-GkU.cache +0 -0
  180. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/dt/dtAVvVgzfd4QVeFVwgVQEqfOZHSLv31NAGS--_AFFbk.cache +1 -0
  181. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/dv/DvhTH0zff-ovDk0WuxtJVX52w1Dsj8mpTrlu13gFZLk.cache +0 -0
  182. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/dv/dvFJw0JQySkre2qTOuLi3LGVG3Ph4EZAlO6DGxv-NnU.cache +0 -0
  183. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/eE/eEuAk0x0P4OKjqc5gajF3htm7mCKzyqIXg6J12bCC3I.cache +2 -0
  184. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/ef/efZTW0s76NnPeT2AOVM0HzsJS1xLONNJUHYE1zdCwGY.cache +0 -0
  185. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/el/elst6LxDf6uiVQqncFBRktiesQ9v596iWdTQYZawHEM.cache +0 -0
  186. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/eu/euKy5W1SAHGCFuJPKmIrFquEdTMDPZUo6cDEhrPTLls.cache +0 -0
  187. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/fA/fAViRsSZA5XPpdMKXZISeo6pwTqQvSbgV3DwDIabGNo.cache +0 -0
  188. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/fD/fDLaGMMGspyWygH8LlU0lxLyilp70uVzb4RCmhjbnhM.cache +0 -0
  189. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/fP/FPY6pMfBVF2ZZFxjkNoHy-pIX28YUKhYxeA3NetoKcc.cache +1 -0
  190. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/fP/fPpdI9YznBUi8ANFCN5U-ZVmPliuf4NEJVoXO51WvJc.cache +1 -0
  191. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/fP/fpQeY6CbAun98ZHomPg7-bNYZhRLvsamvuecQS5LMBU.cache +1 -0
  192. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/g0/g0330d9boKb5chcX02AeoulsGjVEEjZJWdlpD_XpJY4.cache +2 -0
  193. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/gD/gD6ot5sYgE-WBfmqQ7IaCYuSjtyIndn5s8O2MW6o8GU.cache +1 -0
  194. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/im/im-Ko494HDK7aTzKHqKNowN3DyIBJn4TiHUm2mn2dhM.cache +1 -0
  195. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/j6/j65tprlPKeR-CehSzEgLSiUFS3AaYIJuzAKEk61ZA1Y.cache +1 -0
  196. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/j8/j8dyiExD2nG1_gMxpZvzzwB0yaR1R5ENefU2luvhl7Y.cache +2 -0
  197. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/jP/jPNHfJkhkye_m0cM-YrVn04QupctcHRhUu8iwOOqhtw.cache +1 -0
  198. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/kc/kcFhYA0d3emrDxUmud7c48o5u6yQwyeOVtMmwORgpBw.cache +0 -0
  199. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/lk/lk9QnvV0ljxlBsK_QCOrLY03_QjoK5h_pKjjxNEd3SA.cache +1 -0
  200. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/lr/lrTlK4TrzHJzJlyneDsyErO7wWUWPDmftoHVW7Rgj-0.cache +0 -0
  201. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/lt/lty3VRZktpe4UVJ4_zXLYxW4_kA4BxdzbEJsDuzd2B0.cache +1 -0
  202. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/mE/mESJqSh3IknWVtFxGBdjfQ7ucP3Qr3AnX_VN5XI8H9E.cache +1 -0
  203. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/mN/mNRYoOqJlB5Q4bgxmEEBCwKWfK7rMHv78T86bTHR--Q.cache +1 -0
  204. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/mX/mX1nlsL_SWOB4y22W5FheRX0YEONKyOY7xUeIvRiHco.cache +0 -0
  205. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/nB/nBZaod2TAg-SCCdhqam2NT8yByjFoYKRNsrK2yYoQh8.cache +1 -0
  206. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/nU/nUx82NupskukOpC2x2UWPfPZYfcqn_YiCdpx9zoDLSA.cache +1 -0
  207. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/n_/n_xYqQYhwEMQknb3jFQnjlxxBE9TzMNHCdJ-bEyZFIw.cache +0 -0
  208. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/nx/nxTv3sKVUQZADJyM3dPaVmUA78MIsMLD_K279yN_GsI.cache +0 -0
  209. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/o1/o14kRWbYMyhU0inykrB0P9jKoKHqRF0SwhpubuX6taU.cache +0 -0
  210. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/oQ/oQLnX-2tNalupH2T660cx2Bv3YARzSKu8JZKCLp0j20.cache +1 -0
  211. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/oQ/oQcpLerwTeJdicTzkZbtuTnmEkICELpCDAJS7ItOd7U.cache +0 -0
  212. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/ob/obVCEvP8Mw6ENSbPK7wgHTWZpqyjoex_URTP6dey67g.cache +2 -0
  213. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/oz/ozRNsKle-0dkVv9TVQv2L4j0KHKVorNn-Y1ZoqeH23k.cache +0 -0
  214. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/pG/pGx8dgb85gcQO3XOrNlHmvafHPF-lL3uSCNTdhqPX18.cache +1 -0
  215. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/p_/p_PWUDJLQf1atvZhhoyb-0AaUsrtHK8KU7kagZ2zyRM.cache +1 -0
  216. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/pm/pmbWi2btd3KtBAF8CYhiLr2-ukFXxId0ylowGfqydkY.cache +0 -0
  217. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/q2/q2K0N7MblONWdUKKS4c9bfwNHDWuRkYadJCjok9UCXI.cache +1 -0
  218. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/qu/qu7l1v4I55NHtTUGNIuAM2wJ3QBOQhANIRUwle_j1Y4.cache +1 -0
  219. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/rV/rVSAQ3sTHbGs4UPCwZRbSQjlbfOm8AzJqR4k2gkf9hM.cache +1 -0
  220. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/sH/sHXKrc5B3KBol-bEZM0XIznn6_BQVCPF7hasOTXNyO8.cache +1 -0
  221. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/sM/sMKpdRSlEcVRbOqSsc__aw5mVMuXK3ZEPZCvViYNda8.cache +0 -0
  222. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/sc/scdDaFuy71mZQ2arS0dSZNmPLSmiIMZa0swBAmPyiU8.cache +1 -0
  223. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/uU/uUt5sf6NA2ya1M2MpCcLhrhyUw4WeEGEa8vsf7cekBQ.cache +0 -0
  224. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/ug/ug5RHgJJ200_4orxQv-xqHnZDyPiPjgRhTVz7vgzWY4.cache +1 -0
  225. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/v6/v6_ojZlJ1QDYoLVNY2SApvICGklrej1fxYJxFWb8IM4.cache +0 -0
  226. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/va/Vad7m3FUgOsZS7pl3DgNAPEvfAqBAG1_WKjqpGlJTG8.cache +0 -0
  227. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/va/va5poKCjsL5Wp3j5hL7wFbD7TcPBzheI2tiSnBh_3tM.cache +1 -0
  228. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/xs/xsgBreUPfNwnblzhAkGChr7kJbU7PqO8PWyEW-CfEQY.cache +1 -0
  229. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/y7/y7F3_2-J_Arx_AkD0P3mAkqOjZ9JiMlGaxpmSM7lsRc.cache +1 -0
  230. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/yF/yFPchNl88oBAJTCBwi9H9eL9EV2D7fNcEM7JjPpgg_k.cache +2 -0
  231. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/z4/z4D0MyZoHMzE_XiqOnR-a9JLt4SpmpFAFHiFUNIKEV8.cache +1 -0
  232. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/zP/zPFxDYRLW-AMnp9IbPtHKk_--8Iy8dluhgknBCcqZcA.cache +0 -0
  233. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/zZ/zZiuImW-YlPd_8deyKGG-Wku7gzX-sxgPRUJTBOpO0U.cache +1 -0
  234. data/spec/dummy/tmp/portability/1/build.zip +0 -0
  235. data/spec/dummy/tmp/portability/11/build.zip +0 -0
  236. data/spec/dummy/tmp/portability/14/build.zip +0 -0
  237. data/spec/dummy/tmp/portability/15/build.zip +0 -0
  238. data/spec/dummy/tmp/portability/17/build.zip +0 -0
  239. data/spec/dummy/tmp/portability/2/build.zip +0 -0
  240. data/spec/dummy/tmp/portability/4/build.zip +0 -0
  241. data/spec/dummy/tmp/portability/8/build.zip +0 -0
  242. data/spec/dummy/tmp/portability/9/build.zip +0 -0
  243. data/spec/dummy/tmp/restart.txt +0 -0
  244. data/spec/mailers/policy_manager/portability_mailer_spec.rb +194 -0
  245. data/spec/mailers/previews/policy_manager/portability_mailer_preview.rb +6 -0
  246. data/spec/models/policy_manager/config_spec.rb +29 -0
  247. data/spec/models/policy_manager/exporter_spec.rb +99 -0
  248. data/spec/models/policy_manager/portability_request_spec.rb +78 -0
  249. data/spec/models/policy_manager/portability_rule_spec.rb +56 -0
  250. data/spec/models/policy_manager/term_spec.rb +29 -0
  251. data/spec/models/policy_manager/user_spec.rb +118 -0
  252. data/spec/models/policy_manager/user_term_spec.rb +4 -0
  253. data/spec/rails_helper.rb +79 -0
  254. data/spec/spec_helper.rb +107 -0
  255. metadata +484 -18
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: b43a8ecf784c5fe1b24530af6c767b88c0af6d54
4
- data.tar.gz: 492df811d80c74b0c28b69dde3e3bba0feeebf64
3
+ metadata.gz: 70a54c711a8c434950a40e3aae520b540d3ff731
4
+ data.tar.gz: 19e30660f9b8d32290c53f8a1601920295d62ed1
5
5
  SHA512:
6
- metadata.gz: 53f0054aaeafad9a6e64022609bbccfbf0417b0488291b33b578c93ea07e8cd57000c03f6c549824ada0e7115b33843d97bd9bba9c428bfefaae7779dcf66183
7
- data.tar.gz: 3e366811b4af4b5dc8f5dac5bf2448e1b9c05379de27ab4fd9a701c4ae0b1def7f5a117bfe3c1f4f972d8dc06ac571d6744525b68b81efce9103ff1b372c2e10
6
+ metadata.gz: 316a1b707c726b8384c5a18464429aa2b95e8738322ded3f1c711ed4a46e6b03b0ef0a2e2b9eab36a5d9fe801c21001659cc38cdb0c60916a7ff6feafc3316ed
7
+ data.tar.gz: 5bf69e3583ec2e3374a8018e9f4085b5b0a83a9674f0cf347911ab6c70dca6e26053cb6c7aef51e934c0bb21a08b8452ae7ec0dc195433fd5d4b1be9ccaaab6a
data/Rakefile CHANGED
@@ -14,14 +14,10 @@ RDoc::Task.new(:rdoc) do |rdoc|
14
14
  rdoc.rdoc_files.include('lib/**/*.rb')
15
15
  end
16
16
 
17
- APP_RAKEFILE = File.expand_path("../test/dummy/Rakefile", __FILE__)
17
+ APP_RAKEFILE = File.expand_path("../spec/dummy/Rakefile", __FILE__)
18
18
  load 'rails/tasks/engine.rake'
19
-
20
-
21
19
  load 'rails/tasks/statistics.rake'
22
20
 
23
-
24
-
25
21
  require 'bundler/gem_tasks'
26
22
 
27
23
  require 'rake/testtask'
@@ -33,4 +29,12 @@ Rake::TestTask.new(:test) do |t|
33
29
  end
34
30
 
35
31
 
36
- task default: :test
32
+ require 'rspec/core'
33
+ require 'rspec/core/rake_task'
34
+
35
+ desc "Run all specs in spec directory (excluding plugin specs)"
36
+ RSpec::Core::RakeTask.new(:spec => 'app:db:test:prepare')
37
+
38
+ task :default => :spec
39
+
40
+ #task default: :test
@@ -14,7 +14,7 @@ module PolicyManager
14
14
 
15
15
  def user_authenticated?
16
16
  if !current_user
17
- render :file => "public/401.html", :layout => false, :status => :unauthorized
17
+ render :file => "401.erb", :layout => false, :status => :unauthorized
18
18
  end
19
19
  end
20
20
 
@@ -7,7 +7,11 @@ module PolicyManager
7
7
 
8
8
  # GET /portability_requests
9
9
  def index
10
- @portability_requests = PortabilityRequest.order(created_at: :desc).paginate(:page => params[:page], :per_page => 10)
10
+ @portability_requests = PortabilityRequest.order(created_at: :desc)
11
+ .paginate(
12
+ :page => params[:page],
13
+ :per_page => 10
14
+ )
11
15
  end
12
16
 
13
17
  def confirm
@@ -19,7 +23,7 @@ module PolicyManager
19
23
 
20
24
  # DELETE /portability_requests/1
21
25
  def destroy
22
- @portability_request.destroy
26
+ @portability_request = PortabilityRequest.find(params[:id]).destroy
23
27
  redirect_to portability_requests_url, notice: I18n.t("terms_app.portability_requests.index.destroyed")
24
28
  end
25
29
 
@@ -7,7 +7,9 @@ module PolicyManager
7
7
 
8
8
  # GET /terms
9
9
  def index
10
- @terms = Term.all
10
+ @terms = Term.where(rule: params[:category_id]).paginate(
11
+ :page => params[:page],
12
+ :per_page => 10)
11
13
  end
12
14
 
13
15
  # GET /terms/1
@@ -4,38 +4,41 @@ module PolicyManager
4
4
  class UserPortabilityRequestsController < ApplicationController
5
5
 
6
6
  def index
7
- @user_portability_requests = current_user.portability_requests.order(created_at: :desc).paginate(:page => params[:page], :per_page => 10)
7
+ @user_portability_requests = current_user.portability_requests
8
+ .order(created_at: :desc)
9
+ .paginate(
10
+ :page => params[:page],
11
+ :per_page => 10)
8
12
  end
9
13
 
10
14
  def create
11
15
  respond_to do |format|
12
- format.html{
16
+
13
17
  if current_user.can_request_portability?
14
18
  if current_user.portability_requests.create
15
- redirect_to user_portability_requests_path, notice: I18n.t("terms_app.user_portability_requests.index.created")
19
+ format.html{
20
+ redirect_to user_portability_requests_path, notice: I18n.t("terms_app.user_portability_requests.index.created")
21
+ }
22
+ format.json{
23
+ render json: {notice: I18n.t("terms_app.user_portability_requests.index.created")}
24
+ }
16
25
  end
17
26
  else
18
- redirect_to user_portability_requests_path, notice: I18n.t("terms_app.user_portability_requests.index.has_pending")
27
+ format.html{
28
+ redirect_to user_portability_requests_path, notice: I18n.t("terms_app.user_portability_requests.index.has_pending")
29
+ }
30
+ format.json{
31
+ render json: {notice: I18n.t("terms_app.user_portability_requests.index.has_pending")}, status: 422
32
+ }
19
33
  end
20
- }
21
- format.json{
22
- if current_user.can_request_portability?
23
- if current_user.portability_requests.create
24
- render json: {notice: I18n.t("terms_app.user_portability_requests.index.created")}
25
- end
26
- else
27
- render json: {notice: I18n.t("terms_app.user_portability_requests.index.has_pending")}, status: 422
28
- end
29
- }
34
+
30
35
  end
31
36
  end
32
37
 
33
- def destroy
34
- PortabilityRequest.find(params[:id]).destroy
35
- redirect_to user_portability_requests_url, notice: I18n.t("terms_app.portability_requests.index.destroyed")
36
- end
37
-
38
- private
38
+ #def destroy
39
+ # PortabilityRequest.find(params[:id]).destroy
40
+ # redirect_to user_portability_requests_url, notice: I18n.t("terms_app.portability_requests.index.destroyed")
41
+ #end
39
42
 
40
43
  end
41
44
  end
@@ -24,7 +24,10 @@ module PolicyManager
24
24
  def blocking_terms
25
25
  respond_to do |format|
26
26
  format.html{ }
27
- format.json{ render json: PolicyManager::Config.rules.map{|p| p.name if p.blocking == true }.compact! }
27
+ format.json{ render json: PolicyManager::Config.rules
28
+ .select{|p| p.blocking }
29
+ .map(&:name)
30
+ }
28
31
  end
29
32
  end
30
33
 
@@ -32,7 +35,6 @@ module PolicyManager
32
35
  rules = current_user.pending_policies.map{|o| "policy_rule_#{o.name}"}
33
36
  resource_params = params.require(:user).permit(rules)
34
37
  current_user.update_attributes(resource_params)
35
-
36
38
  @pending_policies = current_user.pending_policies
37
39
 
38
40
  respond_to do |format|
@@ -63,7 +65,6 @@ module PolicyManager
63
65
  end
64
66
 
65
67
  def reject
66
-
67
68
  handle_term_reject
68
69
 
69
70
  respond_to do |format|
@@ -87,6 +88,7 @@ module PolicyManager
87
88
  end
88
89
  end
89
90
 
91
+ =begin
90
92
  # GET /user_terms/new
91
93
  def new
92
94
  @user_term = UserTerm.new
@@ -117,6 +119,7 @@ module PolicyManager
117
119
  @user_term.destroy
118
120
  redirect_to user_terms_url, notice: 'User term was successfully destroyed.'
119
121
  end
122
+ =end
120
123
 
121
124
  private
122
125
 
@@ -4,8 +4,10 @@ module PolicyManager
4
4
  layout 'mailer'
5
5
 
6
6
  # configurable mailer helpers
7
- Config.exporter.mail_helpers.each do |helpers|
8
- add_template_helper(helpers)
7
+ if Config.exporter.present?
8
+ Config.exporter.mail_helpers.each do |helpers|
9
+ add_template_helper(helpers)
10
+ end
9
11
  end
10
12
  end
11
13
  end
@@ -5,7 +5,7 @@ module PolicyManager
5
5
  @portability_request = PortabilityRequest.find(portability_request_id)
6
6
  @user = Config.user_resource.find(@portability_request.user_id)
7
7
 
8
- opts = { :to => @user.email, :subject => I18n.t("terms_app.mails.progress.subject") }
8
+ opts = { from: Config.from_email, to: @user.email, subject: I18n.t("terms_app.mails.progress.subject") }
9
9
  opts.merge!({
10
10
  template_path: PolicyManager::Config.exporter.mailer_templates[:path].to_s,
11
11
  template_name: PolicyManager::Config.exporter.mailer_templates[:progress]
@@ -21,7 +21,7 @@ module PolicyManager
21
21
  @user = Config.user_resource.find(@portability_request.user_id)
22
22
  @link = @portability_request.download_link
23
23
 
24
- opts = { :to => @user.email, :subject => I18n.t("terms_app.mails.completed.subject") }
24
+ opts = { from: Config.from_email, to: @user.email, subject: I18n.t("terms_app.mails.completed.subject") }
25
25
  opts.merge!({
26
26
  template_path: PolicyManager::Config.exporter.mailer_templates[:path].to_s,
27
27
  template_name: PolicyManager::Config.exporter.mailer_templates[:complete]
@@ -35,7 +35,7 @@ module PolicyManager
35
35
  def admin_notification(user_id)
36
36
  @user = Config.user_resource.find(user_id)
37
37
 
38
- opts = { :to => Config.admin_email(@user), :subject => I18n.t("terms_app.mails.admin.subject", email: @user.email) }
38
+ opts = { from: Config.from_email, to: Config.admin_email(@user), subject: I18n.t("terms_app.mails.admin.subject", email: @user.email) }
39
39
  opts.merge!({
40
40
  template_path: PolicyManager::Config.exporter.mailer_templates[:path].to_s,
41
41
  template_name: PolicyManager::Config.exporter.mailer_templates[:admin]
@@ -107,6 +107,7 @@ module PolicyManager::Concerns::UserBehavior
107
107
 
108
108
  def policy_term_on(rule)
109
109
  category = PolicyManager::Config.rules.find{|o| o.name == rule}
110
+ #binding.pry if category.blank?
110
111
  term = category.terms.where(state: "published").last
111
112
  raise "no term for #{rule} policy" if term.blank?
112
113
  term
@@ -10,15 +10,16 @@ module PolicyManager
10
10
  validates_uniqueness_of :term_id, :scope => :user_id
11
11
 
12
12
  aasm :column => :state do
13
- state :rejected, :initial => true
13
+ state :passive, :initial => true
14
+ state :rejected
14
15
  state :accepted
15
16
 
16
17
  event :accept do
17
- transitions from: :rejected, to: :accepted
18
+ transitions from: [:passive, :rejected], to: :accepted
18
19
  end
19
20
 
20
21
  event :reject do
21
- transitions from: :accepted, to: :rejected
22
+ transitions from: [:passive, :accepted], to: :rejected
22
23
  end
23
24
  end
24
25
 
@@ -41,7 +41,7 @@
41
41
  <nav class="col-md-2 d-none d-md-block bg-light sidebar">
42
42
  <div class="sidebar-sticky">
43
43
  <ul class="nav flex-column">
44
- <% if PolicyManager::Config.is_admin?(current_user) %>
44
+ <% if PolicyManager::Config.is_admin?(controller.current_user) %>
45
45
 
46
46
  <li class="nav-item">
47
47
  <a class="nav-link" href="<%= categories_path %>">
@@ -59,7 +59,7 @@
59
59
 
60
60
  <% end %>
61
61
 
62
- <% if current_user.is_a? PolicyManager::Config.user_resource %>
62
+ <% if controller.current_user.is_a? PolicyManager::Config.user_resource %>
63
63
 
64
64
  <li class="separator"></li>
65
65
 
@@ -0,0 +1,5 @@
1
+ <body>
2
+ eeeee
3
+ <%= yield %>
4
+ eeee
5
+ </body>
@@ -0,0 +1 @@
1
+ <h1>access denied</h1>
@@ -17,7 +17,7 @@
17
17
 
18
18
  <% else %>
19
19
  <strong>
20
- <%= current_user.email %>
20
+ <%= controller.current_user.email %>
21
21
  </strong> <%= I18n.t("terms_app.user_terms.show.pending.message") %>
22
22
 
23
23
  <hr/>
@@ -5,9 +5,9 @@ if @user_term.persisted? && @user_term.state == "accepted"
5
5
  json.message "#{I18n.t("terms_app.user_terms.show.accepted.message")}"
6
6
  json.url reject_user_term_path(params[:id])
7
7
  json.method :put
8
- elsif current_user.present?
8
+ elsif controller.current_user.present?
9
9
  json.status "pending"
10
- json.message "#{current_user.email} #{I18n.t("terms_app.user_terms.show.pending.message")}"
10
+ json.message "#{controller.current_user.email} #{I18n.t("terms_app.user_terms.show.pending.message")}"
11
11
  json.url accept_user_term_path(params[:id])
12
12
  json.method :put
13
13
  else
@@ -44,7 +44,8 @@ module PolicyManager
44
44
  if has_different_admin_user_resource?
45
45
  user.is_a? admin_user_resource
46
46
  else
47
- @@is_admin_method.call(user)
47
+ raise Rails.logger.error("GDPR ERROR! please add is_admin_method to your gdpr initializer") if @@is_admin_method.blank?
48
+ @@is_admin_method.call(user)
48
49
  end
49
50
  end
50
51
 
@@ -1,5 +1,11 @@
1
1
  module PolicyManager
2
2
  class Engine < ::Rails::Engine
3
3
  isolate_namespace PolicyManager
4
+ config.generators do |g|
5
+ g.test_framework :rspec, :fixture => false
6
+ #g.fixture_replacement :factory_girl, :dir => 'spec/factories'
7
+ g.assets false
8
+ g.helper false
9
+ end
4
10
  end
5
11
  end
@@ -42,7 +42,7 @@ module PolicyManager
42
42
  end
43
43
 
44
44
  def layout
45
- handled_template(@layout) || '<body> eeeee <%= yield %> eeee</body>'
45
+ handled_template(@layout) || 'policy_manager/portability'
46
46
  end
47
47
 
48
48
  def mail_helpers
@@ -24,7 +24,7 @@ module PolicyManager
24
24
  create_sections
25
25
  generate_zip
26
26
  handle_zip_upload
27
- after_zip.call(zip_path, resource)
27
+ after_zip.call(zip_path, resource) if after_zip.is_a?(Proc)
28
28
  clear!
29
29
  end
30
30
 
@@ -1,6 +1,5 @@
1
1
  require "erb"
2
2
  require 'open-uri'
3
- require "tilt"
4
3
  require "will_paginate"
5
4
  require 'will_paginate/view_helpers'
6
5
  require 'will_paginate/view_helpers/action_view'
@@ -1,3 +1,3 @@
1
1
  module PolicyManager
2
- VERSION = '0.3.0'
2
+ VERSION = '0.3.1'
3
3
  end
@@ -0,0 +1,51 @@
1
+ require 'spec_helper'
2
+
3
+ describe PolicyManager::CategoriesController do
4
+ routes { PolicyManager::Engine.routes }
5
+ render_views
6
+
7
+ before :each do
8
+
9
+ @config = PolicyManager::Config.setup do |c|
10
+ c.is_admin_method = ->(o){true}
11
+ c.add_rule({name: "age",
12
+ validates_on: [:create, :update],
13
+ blocking: true,
14
+ if: ->(o){ o.enabled_for_validation }
15
+ })
16
+ end
17
+
18
+ @category = @config.rules.first.name
19
+
20
+ pr = PolicyManager::Term.create(description: "el", rule: "age")
21
+ pr.publish!
22
+
23
+ User.any_instance.stubs(:enabled_for_validation).returns(false)
24
+ @user = User.new
25
+ @user.email = "a@a.cl"
26
+ @user.save
27
+ PolicyManager::ApplicationController.any_instance.stubs(:current_user).returns(User.first)
28
+
29
+ end
30
+
31
+ it "should get index" do
32
+ ApplicationController.any_instance.stubs(:current_user).returns(User.first)
33
+
34
+ PolicyManager::Config.stubs(:is_admin?).returns(true)
35
+
36
+ get :index
37
+ assert_response :success
38
+ assert_select "table td", "age"
39
+ end
40
+
41
+ it "should show category" do
42
+
43
+ PolicyManager::Config.stubs(:is_admin?).returns(true)
44
+ get :show , params: {id: @category}
45
+ assert_response :success
46
+ assert_select "h2", "age Policy"
47
+ assert_select ".btn", "New Term"
48
+ end
49
+
50
+
51
+ end
@@ -0,0 +1,85 @@
1
+ require 'spec_helper'
2
+ module PolicyManager
3
+ describe PortabilityRequestsController do
4
+
5
+ routes { PolicyManager::Engine.routes }
6
+ render_views
7
+
8
+ before :each do
9
+
10
+ @config = PolicyManager::Config.setup do |c|
11
+ c.is_admin_method = ->(o){true}
12
+ c.user_resource = User
13
+ c.from_email = "admin@acme.com"
14
+ c.admin_email_inbox = "admin@acme.com"
15
+ c.add_rule({name: "age",
16
+ validates_on: [:create, :update],
17
+ blocking: true,
18
+ if: ->(o){ o.enabled_for_validation }
19
+ })
20
+ c.exporter = {
21
+ path: Rails.root + "tmp/export",
22
+ resource: User
23
+ }
24
+ end
25
+
26
+ if defined?(PolicyManager::PortabilityRequest)
27
+ PolicyManager.send(:remove_const, :"PortabilityRequest")
28
+ load PolicyManager::Engine.root + 'app/models/policy_manager/portability_request.rb'
29
+ end
30
+
31
+ @category = @config.rules.first.name
32
+
33
+ @term = PolicyManager::Term.create(description: "desc 1", rule: "age")
34
+ @term.publish!
35
+
36
+ User.any_instance.stubs(:enabled_for_validation).returns(false)
37
+ @user = User.new
38
+ @user.email = "a@a.cl"
39
+ @user.save
40
+ PolicyManager::PortabilityRequest.delete_all
41
+ end
42
+
43
+ it "should get index empty records" do
44
+ @controller.stubs(:allow_admins).returns(true)
45
+ @controller.stubs(:current_user).returns(User.last)
46
+
47
+ get :index
48
+ assert PortabilityRequest.count == 0
49
+ assert_response :success
50
+ end
51
+
52
+ it "should get index with records" do
53
+ @controller.stubs(:allow_admins).returns(true)
54
+ @controller.stubs(:current_user).returns(User.last)
55
+
56
+ @user.portability_requests.create
57
+ get :index
58
+ assert PortabilityRequest.count == 1
59
+ assert_response :success
60
+ end
61
+
62
+ it "confirm" do
63
+ @controller.stubs(:allow_admins).returns(true)
64
+ @controller.stubs(:current_user).returns(User.last)
65
+
66
+ @user.portability_requests.create
67
+ get :confirm, params: {id: @user.portability_requests.first.id }
68
+
69
+ assert_response :redirect
70
+ assert_predicate @user.portability_requests.first, :completed?
71
+ end
72
+
73
+ it "destroy" do
74
+ @controller.stubs(:allow_admins).returns(true)
75
+ @controller.stubs(:current_user).returns(User.last)
76
+
77
+ @user.portability_requests.create
78
+ delete :destroy, params: {id: @user.portability_requests.first.id }
79
+ #follow_redirect!
80
+ assert_response :redirect
81
+ assert_equal @user.portability_requests.size, 0
82
+ end
83
+
84
+ end
85
+ end