cmor_user_area 0.0.1.pre

Sign up to get free protection for your applications and to get access to all the features.
Files changed (392) hide show
  1. checksums.yaml +7 -0
  2. data/MIT-LICENSE +20 -0
  3. data/README.rdoc +78 -0
  4. data/Rakefile +19 -0
  5. data/app/concerns/cmor/user_area/controller/current_user_concern.rb +64 -0
  6. data/app/concerns/cmor/user_area/controller/redirect_back_concern.rb +32 -0
  7. data/app/concerns/cmor/user_area/controller/store_current_user_concern.rb +25 -0
  8. data/app/controllers/cmor/user_area/current_users_controller.rb +11 -0
  9. data/app/controllers/cmor/user_area/password_reset_requests.rb +6 -0
  10. data/app/controllers/cmor/user_area/password_reset_requests/base_controller.rb +48 -0
  11. data/app/controllers/cmor/user_area/password_resets.rb +6 -0
  12. data/app/controllers/cmor/user_area/password_resets/base_controller.rb +48 -0
  13. data/app/controllers/cmor/user_area/sessions.rb +6 -0
  14. data/app/controllers/cmor/user_area/sessions/base_controller.rb +53 -0
  15. data/app/controllers/cmor/user_area/user_password_reset_requests_controller.rb +15 -0
  16. data/app/controllers/cmor/user_area/user_password_resets_controller.rb +9 -0
  17. data/app/controllers/cmor/user_area/user_sessions_controller.rb +9 -0
  18. data/app/controllers/cmor/user_area/users.rb +6 -0
  19. data/app/controllers/cmor/user_area/users/base_controller.rb +48 -0
  20. data/app/helpers/cmor/user_area_helper.rb +15 -0
  21. data/app/mailers/cmor/user_area/user_mailer.rb +12 -0
  22. data/app/models/cmor/user_area/user.rb +80 -0
  23. data/app/models/cmor/user_area/user_password_reset_request.rb +42 -0
  24. data/app/serializers/cmor/user_area/user_serializer.rb +7 -0
  25. data/app/services/cmor/user_area/application_service.rb +8 -0
  26. data/app/services/cmor/user_area/create_default_user_service.rb +36 -0
  27. data/app/sessions/cmor/user_area/session/base.rb +8 -0
  28. data/app/sessions/cmor/user_area/user_session.rb +8 -0
  29. data/app/view_helpers/cmor/user_area/application_view_helper.rb +44 -0
  30. data/app/views/cmor/user_area/_navigation.html.haml +13 -0
  31. data/app/views/cmor/user_area/current_users/_form.html.haml +3 -0
  32. data/app/views/cmor/user_area/current_users/_form_errors.html.haml +6 -0
  33. data/app/views/cmor/user_area/current_users/_head_extras.html.haml +0 -0
  34. data/app/views/cmor/user_area/current_users/_show.html.haml +14 -0
  35. data/app/views/cmor/user_area/current_users/_show_extras.html.haml +0 -0
  36. data/app/views/cmor/user_area/current_users/edit.html.haml +17 -0
  37. data/app/views/cmor/user_area/current_users/new.html.haml +15 -0
  38. data/app/views/cmor/user_area/current_users/show.html.haml +34 -0
  39. data/app/views/cmor/user_area/navigation_dropdown/_bootstrap3.html.haml +16 -0
  40. data/app/views/cmor/user_area/navigation_dropdown/_bootstrap4.html.haml +14 -0
  41. data/app/views/cmor/user_area/navigation_view_helper/bootstrap_4/_render.html.haml +10 -0
  42. data/app/views/cmor/user_area/navigation_view_helper/bootstrap_4/_render_dropdown.html.haml +15 -0
  43. data/app/views/cmor/user_area/password_reset_requests/base/_form.html.haml +1 -0
  44. data/app/views/cmor/user_area/password_reset_requests/base/_form_errors.html.haml +6 -0
  45. data/app/views/cmor/user_area/password_reset_requests/base/_head_extras.html.haml +0 -0
  46. data/app/views/cmor/user_area/password_reset_requests/base/new.haml +15 -0
  47. data/app/views/cmor/user_area/password_resets/base/_form.html.haml +2 -0
  48. data/app/views/cmor/user_area/password_resets/base/_form_errors.html.haml +6 -0
  49. data/app/views/cmor/user_area/password_resets/base/_head_extras.html.haml +0 -0
  50. data/app/views/cmor/user_area/password_resets/base/edit.haml +15 -0
  51. data/app/views/cmor/user_area/sessions/base/_form.html.haml +2 -0
  52. data/app/views/cmor/user_area/sessions/base/_form_errors.html.haml +6 -0
  53. data/app/views/cmor/user_area/sessions/base/_head_extras.html.haml +0 -0
  54. data/app/views/cmor/user_area/sessions/base/new.html.haml +17 -0
  55. data/app/views/cmor/user_area/user_mailer/password_reset_email.de.html.erb +11 -0
  56. data/app/views/cmor/user_area/user_mailer/password_reset_email.de.text.erb +9 -0
  57. data/app/views/cmor/user_area/user_mailer/password_reset_email.en.html.erb +12 -0
  58. data/app/views/cmor/user_area/user_mailer/password_reset_email.en.text.erb +9 -0
  59. data/app/views/home/index.html.erb +0 -0
  60. data/config/locales/authlogic.de.yml +24 -0
  61. data/config/locales/de.yml +132 -0
  62. data/config/locales/en.yml +126 -0
  63. data/config/routes.rb +19 -0
  64. data/db/migrate/20160115181043_create_cmor_user_area_users.rb +37 -0
  65. data/lib/cmor/user_area.rb +30 -0
  66. data/lib/cmor/user_area/configuration.rb +32 -0
  67. data/lib/cmor/user_area/engine.rb +8 -0
  68. data/lib/cmor/user_area/spec_helpers/feature.rb +62 -0
  69. data/lib/cmor/user_area/version.rb +7 -0
  70. data/lib/cmor_user_area.rb +10 -0
  71. data/lib/generators/cmor/user_area/install/install_generator.rb +38 -0
  72. data/lib/generators/cmor/user_area/install/templates/application_controller.source +3 -0
  73. data/lib/generators/cmor/user_area/install/templates/initializer.rb +60 -0
  74. data/lib/generators/cmor/user_area/install/templates/routes.source +2 -0
  75. data/lib/tasks/cmor_user_area_tasks.rake +8 -0
  76. data/spec/dummy/app/assets/config/manifest.js +3 -0
  77. data/spec/dummy/app/assets/javascripts/cable.js +13 -0
  78. data/spec/dummy/app/channels/application_cable/channel.rb +4 -0
  79. data/spec/dummy/app/channels/application_cable/connection.rb +4 -0
  80. data/spec/dummy/app/jobs/application_job.rb +2 -0
  81. data/spec/dummy/app/mailers/application_mailer.rb +4 -0
  82. data/spec/dummy/app/models/application_record.rb +3 -0
  83. data/spec/dummy/app/views/layouts/mailer.html.erb +13 -0
  84. data/spec/dummy/app/views/layouts/mailer.text.erb +1 -0
  85. data/spec/dummy/bin/update +31 -0
  86. data/spec/dummy/bin/yarn +11 -0
  87. data/spec/dummy/config/cable.yml +10 -0
  88. data/spec/dummy/config/initializers/application_controller_renderer.rb +8 -0
  89. data/spec/dummy/config/initializers/content_security_policy.rb +25 -0
  90. data/spec/dummy/config/puma.rb +34 -0
  91. data/spec/dummy/config/spring.rb +6 -0
  92. data/spec/dummy/config/storage.yml +34 -0
  93. data/spec/dummy/db/development.sqlite3 +0 -0
  94. data/spec/dummy/db/migrate/20190325192603_create_active_storage_tables.active_storage.rb +27 -0
  95. data/spec/dummy/db/migrate/20190325192624_create_cmor_user_area_users.cmor_user_area.rb +38 -0
  96. data/spec/dummy/db/test.sqlite3 +0 -0
  97. data/spec/dummy/lib/templates/haml/scaffold/_form.html.haml +12 -0
  98. data/spec/dummy/log/development.log +108 -0
  99. data/spec/dummy/log/test.log +509 -0
  100. data/spec/dummy/package.json +5 -0
  101. data/spec/dummy/public/apple-touch-icon-precomposed.png +0 -0
  102. data/spec/dummy/public/apple-touch-icon.png +0 -0
  103. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/-w/-wwQdyEeejIS0ptNkDb8CotcFEz8shbr_mHkZA7OevQ.cache +0 -0
  104. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/2J/2JZ8VAYhkBcWE3sok5fqFK1opx8vf16OKQxVHfUPn4k.cache +1 -0
  105. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/4T/4TkMgJg6Zk3-hcNYiEywIW5XROuYtAcnmPk9_0I7clg.cache +0 -0
  106. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/58/584AkuPUz7HNQZLo41hVlC43-zDp6wQiwQjwuqNORRY.cache +0 -0
  107. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/5L/5L-FSYLjBxDmPgzI_CAYGDk-9Mni9w9C57XkJeyt5LA.cache +1 -0
  108. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/6e/6eHLns1-9lpL1ONXkJHSM9src6rLg-c1X_ABZTpGJU0.cache +1 -0
  109. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/79/79jR4Uf_pUhttCKeRR-xEPMITP6aTnSgtQIa8EfUW8E.cache +2 -0
  110. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/7R/7RJVJLrYkQmkJ9Sl8MmsOoQEZ8h9ZjROviFb0SniYcs.cache +1 -0
  111. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/8-/8-QQLtMujDnjyd2fI0Ygw5qXaATxumVuyPKDpUWewKE.cache +2 -0
  112. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/8B/8BjefZm87J3KSHa70sBrLglaelKVHts_WPz85SBILbw.cache +0 -0
  113. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/8Q/8Qv0pOFexuQn3xn0g8_E7UAZoZjcSudR3eCadt2r1ic.cache +0 -0
  114. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/AE/AEkMvfX2UxO0g0t28U8GjbECOIWvVNlR03X0ab1M4tE.cache +1 -0
  115. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/AR/ARfYs31IhL3pDDp_oJE4RzmDigur1JRJkqZpRTyt1M8.cache +0 -0
  116. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Aq/AqM1YgA1Ku-odROqZQDyMn3C45ppUn4qo1QscS5TAL4.cache +0 -0
  117. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Bz/BzORlUIjpUN9Hsz7XbBmcaQFd_l4HfoJkJw0t4nAKjc.cache +0 -0
  118. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/C5/C5D4T0_nOZRxlB1Kr3YBjpAz13VAaGm5141p_IqSHEw.cache +3 -0
  119. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/D2/D2ri1FdDjnUlgaCehETUAH9MBudGFni8BhvIeGwF46s.cache +1 -0
  120. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/DX/DXbHDrIcECN1YE2zwFlHXwUEsa9Nc1OnPX_baI13PI8.cache +1 -0
  121. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/EK/EK4OLCBAIT0sqfYnC571wtOio3A88k5mjqemmHXRvME.cache +0 -0
  122. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Ex/Exni9T-N0D00xhk9o73AIRL5YUOyHlJTj0i9YuzvnvQ.cache +1 -0
  123. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/F7/F74fucogx91yB5PW70H7x0uAJV_sYuVfbAg73rR-wUI.cache +3 -0
  124. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/H5/H5OObbRUl_LDveW5FbD_ypXLGfV1jkVsOYxMVonPdRU.cache +0 -0
  125. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/HC/HCDOUd7-S45aJ_PjVAC_Vmjyud3i1aQv4cE3t9_Z3Dw.cache +2 -0
  126. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/HZ/HZ1iRdzAHZ8o4HrWUPniUmrldI0rrw3czGHIlhKx20Q.cache +2 -0
  127. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Hx/HxDhLNAjgpAjWKLIYCTcv1gXd11GGWXDRkGMlW1ZL4o.cache +1 -0
  128. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Ia/Iamg0tlKTyWQONN43wFwQ4e-seFD8rm8Tf-G72HPyP4.cache +1 -0
  129. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/K9/K9crSvC2UPnYrdvz_jmuiFaHNpGz63JZnWi2--YxO7A.cache +1 -0
  130. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/KU/KUadIyonXR1Vyz07b6lra7kQIWQVonzIiOzZCJOK4IE.cache +3 -0
  131. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Kq/Kqu-8GldLxbnQ5PYr_P_Xv6O-g9ty5ReXacceHUMDiY.cache +0 -0
  132. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Kz/KzLDCKAT9oKrukAg9tFB8mtVV7bPiIGpiFUeS1TljEQ.cache +0 -0
  133. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/LW/LWYc1nv4Bh5BbSrhl4B1cnaH5Qqks2CqNagjBrxfoDY.cache +0 -0
  134. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/MC/MCuEd_HWd5C2COVhVm23pI9wjRXLZI7gB5cNb6b_5X4.cache +1 -0
  135. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Mb/MbgYygU0CWG73XoEOS94Vyil9b_iyKja00eXefGa5LM.cache +0 -0
  136. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Mm/MmSp1Be-PB_hAasIwNDehj1aIpBVchE9WrMEIgD67SA.cache +1 -0
  137. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/NA/NA7TG8OGXra5NGU5ptqd0TbvuCX0sB2U1SUbbOgo_ik.cache +1 -0
  138. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Ng/NgoumFe4ZOSieHJ2XRgYhOlgTLS35s0DyU58x7HfI2A.cache +0 -0
  139. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Oo/OoGJC7rHNFMAE-SQlL4eOy8lPJR8Y4cN0zSRnygkHY8.cache +1 -0
  140. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/PD/PD99Bcd5AQWB3NVDhz4dX9LI8A31bqUs4N-qUdEFCAE.cache +1 -0
  141. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/PI/PIysz08byyvXlaQfthLgm79fjzz0rZ0el42dAQq2hf8.cache +1 -0
  142. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/P_/P_UMpytd32vzaBB9OmSyfMhsloRkvkvWbGJU1cY-_T0.cache +1 -0
  143. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Q7/Q7JnF7XNGFTeq0tZ_T2eaASvv6XImGz7QxxPWYcA3g0.cache +1 -0
  144. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Qn/QntQgTSCYnhbiX4LoprBXIqyz2RyRzOJiKazX9xHuu8.cache +1 -0
  145. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/R6/R6W1OhmXADlwn2paOoImbgcKCpB8tY4uwtVA27HImuc.cache +3 -0
  146. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Rs/RscE5VBWfyXMQo35So2JtRTyNa8kpDdAjWTM96exJtw.cache +1 -0
  147. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/SB/SByKDoOgon_c4yw7Hg6SUt7e3nBnAiFe0PmKjQKgP38.cache +1 -0
  148. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/SC/SCj7IBUBBJModudbkHhWngiTTDj1t5ZhW5PfZA0HGHQ.cache +1 -0
  149. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/TM/TMb1cGxkrsKz17sDCtqbWN-Jh6QxyKU_ltbBTBTsZVc.cache +0 -0
  150. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Tp/TpmeWw1QJfLYcmHo3aqXMUTmK3_tppjOTY6Bhmm5z4c.cache +1 -0
  151. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/U2/U2ziIOj8cbeulgezpTOzcrhnd7Z8mGLcFNHHLRS6v_w.cache +2 -0
  152. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Uz/UzRlBw63ovNsxNNbz6WVQPkQx_g01AT7k9JzvmLbmZ8.cache +0 -0
  153. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/VS/VSliUoy2QKm5bR_26CTaylVZY4o61YuE0gr5kqU6UJE.cache +0 -0
  154. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Vr/VrtEHnJmqjZwGxBqPWkxmfbuNoZ_ZlWNmLzKRC924FU.cache +1 -0
  155. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/W5/W5NIwCJ2YK1p63ZkfQtu4M00FVW772ITtEBrY9xYfYI.cache +1 -0
  156. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Xk/XkVHFvPaI-xAbAcXZSv_EslOO0sXQSOJi2v9-w5UyE4.cache +1 -0
  157. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Xv/XvoUclLVplyO9UQw8e-98EJElxKytnIKdeiw8cN1tAk.cache +1 -0
  158. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Yp/YpBWosQuOX-dGPr1EDa4wnkCPyZdLhq-0vKhfbMWsUY.cache +0 -0
  159. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Yu/YubKG280u8nFXEY4CvadpgzyDbeevIL7SFUQeFA_0X4.cache +0 -0
  160. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/Zj/ZjK1fvOKdajGTfU5pRn8x2UWgX8GWvuTXo24RENXREM.cache +1 -0
  161. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/_U/_Uz5da-URnRhVpIycPwOq3dvEZay17seoAYyPNNT_d4.cache +1 -0
  162. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/_v/_vHhLuv_HO3ndie5PLld1rfmAfh8Y54vtbj14lnA97w.cache +0 -0
  163. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/aQ/aQL0CNPS5ESzN5XcS9o8NF7i4bv4pCm0xdrA7vfw5fc.cache +2 -0
  164. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/aR/aR5t7yCAR6IoNonATlf4QuZZSFc4k_ERK1u2fltqois.cache +1 -0
  165. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/bD/bDIuRJAlDi98cyI-tv6gf95cK6b2lDclVk6gw7-4yQE.cache +1 -0
  166. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/bl/blP7I9wrpMZirmqxSinkxvHgn7dwfxBAvHlUkCTQf9Q.cache +1 -0
  167. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/bu/buXbbv7z8SqC7DAPe_4Oip10Xm9GRMFE9VIlCHH3pDQ.cache +1 -0
  168. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/c7/c7CooReQb2ejxEumMNCGRid6lhlPFxxlYhiSx0BnFf4.cache +1 -0
  169. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/dG/dG2st3mUGsh-8yC115nqU2IltElHJVNhu2vRfijxs20.cache +1 -0
  170. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/dp/dpzW4cK3NsJEHAYf7z-nszapTBk7oQrhBPjmkIoZoXQ.cache +1 -0
  171. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/eJ/eJhiyiHTMJUDd_OqCXD93jBwAivnKRBa5x5qtFrxQj8.cache +1 -0
  172. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/fR/fRbCj1aNB38O-9pznPKZJ-EZoFXBeVilAs0WroTkIEM.cache +1 -0
  173. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/fU/fUQKkajuOuSLJQtRtjum4rOrJsTBFTgtwktNG4QVlrQ.cache +1 -0
  174. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/fq/fqqy6XMocl_Tx0nWsOC1LQ_uj3jUrV-CN8kMgtDR0Bc.cache +2 -0
  175. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/gd/gdC8KjHpTRTYsyeT0HoM5RR_ZKDCK_4XKXQO81ArNlM.cache +0 -0
  176. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/iJ/iJM3CTsQFj5rof3eJPd4ioz8cgWWJie0byeOy7L6Nng.cache +1 -0
  177. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/i_/i_s59CkDPBCbkVzR2yxiT9kpEI1B0pO0OYOIwTGpkcI.cache +2 -0
  178. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/ip/ipi1NeZWfWKRKJ3wXF6d_iPE8V0BdYHjDxYhBLc98A8.cache +0 -0
  179. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/j1/j1BQXikuCXkgfl_ekvX7byh1qZLEg4hhbmTdGdJVijs.cache +0 -0
  180. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/jK/jKHqW1VBzFtw_WgOZ-5WFrod_nbiYJ_Duey1VZXs3Mo.cache +0 -0
  181. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/jU/jUmxOIOwQBdZhDyVmTtD0UUEWZz_9Iu64WY59bXHgs0.cache +1 -0
  182. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/kD/kDartayL6A6j26rd-NkFIU9yqvIIJh9IUdiLsbuHoPY.cache +1 -0
  183. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/lD/lDkdR_Yvju7JvBiTO_3OE9ADzuVk-4T_JvDZhPSpmXk.cache +1 -0
  184. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/lS/lStvx9Beg2l4s8L-QdTSKuc5_qQPQAZPnIcRI7JkpPE.cache +2 -0
  185. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/nI/nIKQa784qYcxM8_rmLncqiSL4jWWsKrqq19GrEprQ34.cache +1 -0
  186. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/n_/n_xYqQYhwEMQknb3jFQnjlxxBE9TzMNHCdJ-bEyZFIw.cache +2 -0
  187. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/nq/nqBvCfX72u2EvAyNfHt3upjIFz009V5YYgwPmmaNRH4.cache +3 -0
  188. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/nt/ntry6y5LOGB3mXS76ylx-eIcul__UqoQoqB4-0eaNnI.cache +2 -0
  189. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/nx/nxTv3sKVUQZADJyM3dPaVmUA78MIsMLD_K279yN_GsI.cache +2 -0
  190. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/qq/qqeUBxpDPTNXL2hYWXX8t_E_jxRkRpjhJR-FcdiLWr0.cache +3 -0
  191. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/qt/qtFUQpglBnMnPpRsGKkhr2rqj9Ub3yOf_h01fudm3pc.cache +0 -0
  192. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/sm/smkjNAEzX7uLiRZnQA38poQvnhHE5uHIlMpkirr_K04.cache +2 -0
  193. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/v_/v_O7CAdXG7icZucqoA971FxfXpz7XWC8PtjH-Z1HIFU.cache +3 -0
  194. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/vw/vw4hWcAaXGLEo2E8KRM86fVgJAvs7q3qkZYmkI2UYG0.cache +2 -0
  195. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/w8/w8XS90xe44-zLTirkVNvEMgky0Iu-y4R4tWoQTHOkWA.cache +1 -0
  196. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/wH/wHiXMAfKVNHdoxvX_7U_fJX97Kv2TDg5VZs6QQGgM7k.cache +1 -0
  197. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/wY/wYXscG863_Dznp_gsU3c1NlFGjKgloZPKnaFeHYhgLg.cache +0 -0
  198. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/wi/win_v0ZNu-l7AoRx8w3ls1xcy0mUExLBVMCSr5oaJFc.cache +0 -0
  199. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/ws/wsn2nUkOEHSwCK9Q1WpZekvvnYE5COQwF3keiKR9-0A.cache +1 -0
  200. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/yM/yMREEbi29WAWRdWlQTj_ovW5SHtEt1exOy8aWy1PCI4.cache +1 -0
  201. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/yq/yqxTsMP8kmCSie9aYhLgHs_Db7h-sSa5vmqZZJUtwv0.cache +0 -0
  202. data/spec/dummy/tmp/cache/assets/sprockets/v3.0/yr/yrp_60uUSk5SlU1028XR4AIpun11BkJJOvIgatVUYBQ.cache +2 -0
  203. data/spec/dummy/tmp/development_secret.txt +1 -0
  204. data/spec/dummy~/Rakefile +6 -0
  205. data/spec/dummy~/app/assets/config/manifest.js +3 -0
  206. data/spec/dummy~/app/assets/javascripts/application.js +15 -0
  207. data/spec/dummy~/app/assets/javascripts/cable.js +13 -0
  208. data/spec/dummy~/app/assets/stylesheets/application.css +15 -0
  209. data/spec/dummy~/app/channels/application_cable/channel.rb +4 -0
  210. data/spec/dummy~/app/channels/application_cable/connection.rb +4 -0
  211. data/spec/dummy~/app/controllers/application_controller.rb +7 -0
  212. data/spec/dummy~/app/controllers/home_controller.rb +3 -0
  213. data/spec/dummy~/app/helpers/application_helper.rb +2 -0
  214. data/spec/dummy~/app/jobs/application_job.rb +2 -0
  215. data/spec/dummy~/app/mailers/application_mailer.rb +4 -0
  216. data/spec/dummy~/app/models/application_record.rb +3 -0
  217. data/spec/dummy~/app/views/home/index.html.erb +1 -0
  218. data/spec/dummy~/app/views/layouts/application.html.erb +17 -0
  219. data/spec/dummy~/app/views/layouts/mailer.html.erb +13 -0
  220. data/spec/dummy~/app/views/layouts/mailer.text.erb +1 -0
  221. data/spec/dummy~/bin/bundle +3 -0
  222. data/spec/dummy~/bin/rails +4 -0
  223. data/spec/dummy~/bin/rake +4 -0
  224. data/spec/dummy~/bin/setup +36 -0
  225. data/spec/dummy~/bin/update +31 -0
  226. data/spec/dummy~/bin/yarn +11 -0
  227. data/spec/dummy~/config.ru +5 -0
  228. data/spec/dummy~/config/application.rb +30 -0
  229. data/spec/dummy~/config/boot.rb +5 -0
  230. data/spec/dummy~/config/cable.yml +10 -0
  231. data/spec/dummy~/config/database.yml +25 -0
  232. data/spec/dummy~/config/environment.rb +5 -0
  233. data/spec/dummy~/config/environments/development.rb +61 -0
  234. data/spec/dummy~/config/environments/production.rb +94 -0
  235. data/spec/dummy~/config/environments/test.rb +46 -0
  236. data/spec/dummy~/config/initializers/application_controller_renderer.rb +8 -0
  237. data/spec/dummy~/config/initializers/assets.rb +14 -0
  238. data/spec/dummy~/config/initializers/backtrace_silencers.rb +7 -0
  239. data/spec/dummy~/config/initializers/cmor_user_area.rb +60 -0
  240. data/spec/dummy~/config/initializers/content_security_policy.rb +25 -0
  241. data/spec/dummy~/config/initializers/cookies_serializer.rb +5 -0
  242. data/spec/dummy~/config/initializers/filter_parameter_logging.rb +4 -0
  243. data/spec/dummy~/config/initializers/i18n.rb +2 -0
  244. data/spec/dummy~/config/initializers/inflections.rb +16 -0
  245. data/spec/dummy~/config/initializers/mime_types.rb +4 -0
  246. data/spec/dummy~/config/initializers/route_translator.rb +3 -0
  247. data/spec/dummy~/config/initializers/simple_form.rb +179 -0
  248. data/spec/dummy~/config/initializers/simple_form_bootstrap.rb +439 -0
  249. data/spec/dummy~/config/initializers/wrap_parameters.rb +14 -0
  250. data/spec/dummy~/config/locales/en.yml +33 -0
  251. data/spec/dummy~/config/locales/simple_form.en.yml +31 -0
  252. data/spec/dummy~/config/puma.rb +34 -0
  253. data/spec/dummy~/config/routes.rb +6 -0
  254. data/spec/dummy~/config/spring.rb +6 -0
  255. data/spec/dummy~/config/storage.yml +34 -0
  256. data/spec/dummy~/db/development.sqlite3 +0 -0
  257. data/spec/dummy~/db/migrate/20190325182101_create_active_storage_tables.active_storage.rb +27 -0
  258. data/spec/dummy~/db/migrate/20190325182124_create_cmor_user_area_users.cmor_user_area.rb +38 -0
  259. data/spec/dummy~/db/schema.rb +57 -0
  260. data/spec/dummy~/db/test.sqlite3 +0 -0
  261. data/spec/dummy~/lib/templates/haml/scaffold/_form.html.haml +12 -0
  262. data/spec/dummy~/log/development.log +108 -0
  263. data/spec/dummy~/log/test.log +2471 -0
  264. data/spec/dummy~/package.json +5 -0
  265. data/spec/dummy~/public/404.html +67 -0
  266. data/spec/dummy~/public/422.html +67 -0
  267. data/spec/dummy~/public/500.html +66 -0
  268. data/spec/dummy~/public/apple-touch-icon-precomposed.png +0 -0
  269. data/spec/dummy~/public/apple-touch-icon.png +0 -0
  270. data/spec/dummy~/public/favicon.ico +0 -0
  271. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/-w/-wwQdyEeejIS0ptNkDb8CotcFEz8shbr_mHkZA7OevQ.cache +0 -0
  272. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/0L/0L3l7M3Aw2FFbzcBBR_--7OUYxk8hcS4Wlu_XsRSDM8.cache +2 -0
  273. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/2J/2JZ8VAYhkBcWE3sok5fqFK1opx8vf16OKQxVHfUPn4k.cache +1 -0
  274. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/4T/4TkMgJg6Zk3-hcNYiEywIW5XROuYtAcnmPk9_0I7clg.cache +0 -0
  275. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/58/584AkuPUz7HNQZLo41hVlC43-zDp6wQiwQjwuqNORRY.cache +0 -0
  276. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/5L/5L-FSYLjBxDmPgzI_CAYGDk-9Mni9w9C57XkJeyt5LA.cache +1 -0
  277. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/6e/6eHLns1-9lpL1ONXkJHSM9src6rLg-c1X_ABZTpGJU0.cache +1 -0
  278. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/79/79jR4Uf_pUhttCKeRR-xEPMITP6aTnSgtQIa8EfUW8E.cache +2 -0
  279. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/7R/7RJVJLrYkQmkJ9Sl8MmsOoQEZ8h9ZjROviFb0SniYcs.cache +1 -0
  280. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/8-/8-QQLtMujDnjyd2fI0Ygw5qXaATxumVuyPKDpUWewKE.cache +2 -0
  281. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/8B/8BjefZm87J3KSHa70sBrLglaelKVHts_WPz85SBILbw.cache +0 -0
  282. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/8Q/8Qv0pOFexuQn3xn0g8_E7UAZoZjcSudR3eCadt2r1ic.cache +0 -0
  283. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/AE/AEkMvfX2UxO0g0t28U8GjbECOIWvVNlR03X0ab1M4tE.cache +1 -0
  284. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/AR/ARfYs31IhL3pDDp_oJE4RzmDigur1JRJkqZpRTyt1M8.cache +0 -0
  285. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Bz/BzORlUIjpUN9Hsz7XbBmcaQFd_l4HfoJkJw0t4nAKjc.cache +0 -0
  286. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/C5/C5D4T0_nOZRxlB1Kr3YBjpAz13VAaGm5141p_IqSHEw.cache +3 -0
  287. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/D2/D2ri1FdDjnUlgaCehETUAH9MBudGFni8BhvIeGwF46s.cache +1 -0
  288. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/DX/DXbHDrIcECN1YE2zwFlHXwUEsa9Nc1OnPX_baI13PI8.cache +1 -0
  289. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/EK/EK4OLCBAIT0sqfYnC571wtOio3A88k5mjqemmHXRvME.cache +0 -0
  290. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/ER/ERPQ7A3b0mTnn9d8QlhN1aXbgctkxjyHHMSFndZKr8Q.cache +1 -0
  291. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Ex/Exni9T-N0D00xhk9o73AIRL5YUOyHlJTj0i9YuzvnvQ.cache +1 -0
  292. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/F7/F74fucogx91yB5PW70H7x0uAJV_sYuVfbAg73rR-wUI.cache +3 -0
  293. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/H5/H5OObbRUl_LDveW5FbD_ypXLGfV1jkVsOYxMVonPdRU.cache +0 -0
  294. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/HC/HCDOUd7-S45aJ_PjVAC_Vmjyud3i1aQv4cE3t9_Z3Dw.cache +2 -0
  295. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/HZ/HZ1iRdzAHZ8o4HrWUPniUmrldI0rrw3czGHIlhKx20Q.cache +2 -0
  296. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Hx/HxDhLNAjgpAjWKLIYCTcv1gXd11GGWXDRkGMlW1ZL4o.cache +1 -0
  297. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/IW/IWKVc2Gu-3rbS86e5x9A7ObGXbPJIewKUHDwr5iVfF0.cache +1 -0
  298. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/K9/K9crSvC2UPnYrdvz_jmuiFaHNpGz63JZnWi2--YxO7A.cache +1 -0
  299. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/KU/KUadIyonXR1Vyz07b6lra7kQIWQVonzIiOzZCJOK4IE.cache +3 -0
  300. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Kq/Kqu-8GldLxbnQ5PYr_P_Xv6O-g9ty5ReXacceHUMDiY.cache +0 -0
  301. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Kz/KzLDCKAT9oKrukAg9tFB8mtVV7bPiIGpiFUeS1TljEQ.cache +0 -0
  302. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/LG/LGE964MRn5WMX_YbXsO2igHkYOYhxyjImaCJDwBtS3Y.cache +1 -0
  303. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/LW/LWYc1nv4Bh5BbSrhl4B1cnaH5Qqks2CqNagjBrxfoDY.cache +0 -0
  304. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/MC/MCuEd_HWd5C2COVhVm23pI9wjRXLZI7gB5cNb6b_5X4.cache +1 -0
  305. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Mb/MbgYygU0CWG73XoEOS94Vyil9b_iyKja00eXefGa5LM.cache +0 -0
  306. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Mm/MmSp1Be-PB_hAasIwNDehj1aIpBVchE9WrMEIgD67SA.cache +1 -0
  307. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/NA/NA7TG8OGXra5NGU5ptqd0TbvuCX0sB2U1SUbbOgo_ik.cache +1 -0
  308. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Ng/NgoumFe4ZOSieHJ2XRgYhOlgTLS35s0DyU58x7HfI2A.cache +0 -0
  309. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/PD/PD99Bcd5AQWB3NVDhz4dX9LI8A31bqUs4N-qUdEFCAE.cache +1 -0
  310. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/PI/PIysz08byyvXlaQfthLgm79fjzz0rZ0el42dAQq2hf8.cache +1 -0
  311. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/P_/P_UMpytd32vzaBB9OmSyfMhsloRkvkvWbGJU1cY-_T0.cache +1 -0
  312. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Q7/Q7JnF7XNGFTeq0tZ_T2eaASvv6XImGz7QxxPWYcA3g0.cache +1 -0
  313. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/R6/R6W1OhmXADlwn2paOoImbgcKCpB8tY4uwtVA27HImuc.cache +3 -0
  314. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Rs/RscE5VBWfyXMQo35So2JtRTyNa8kpDdAjWTM96exJtw.cache +1 -0
  315. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/SB/SByKDoOgon_c4yw7Hg6SUt7e3nBnAiFe0PmKjQKgP38.cache +1 -0
  316. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/TM/TMb1cGxkrsKz17sDCtqbWN-Jh6QxyKU_ltbBTBTsZVc.cache +0 -0
  317. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Tp/TpmeWw1QJfLYcmHo3aqXMUTmK3_tppjOTY6Bhmm5z4c.cache +1 -0
  318. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Uv/UvwNLurdraCmHtUt2p2sAyLjc0CLIi4rMrgbZ_gX3QU.cache +0 -0
  319. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Uz/UzRlBw63ovNsxNNbz6WVQPkQx_g01AT7k9JzvmLbmZ8.cache +0 -0
  320. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/VS/VSliUoy2QKm5bR_26CTaylVZY4o61YuE0gr5kqU6UJE.cache +0 -0
  321. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Vr/VrtEHnJmqjZwGxBqPWkxmfbuNoZ_ZlWNmLzKRC924FU.cache +1 -0
  322. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/W5/W5NIwCJ2YK1p63ZkfQtu4M00FVW772ITtEBrY9xYfYI.cache +1 -0
  323. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Xk/XkVHFvPaI-xAbAcXZSv_EslOO0sXQSOJi2v9-w5UyE4.cache +1 -0
  324. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Xv/XvoUclLVplyO9UQw8e-98EJElxKytnIKdeiw8cN1tAk.cache +1 -0
  325. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Yp/YpBWosQuOX-dGPr1EDa4wnkCPyZdLhq-0vKhfbMWsUY.cache +0 -0
  326. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Yu/YubKG280u8nFXEY4CvadpgzyDbeevIL7SFUQeFA_0X4.cache +0 -0
  327. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/Zj/ZjK1fvOKdajGTfU5pRn8x2UWgX8GWvuTXo24RENXREM.cache +1 -0
  328. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/_U/_Uz5da-URnRhVpIycPwOq3dvEZay17seoAYyPNNT_d4.cache +1 -0
  329. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/_v/_vHhLuv_HO3ndie5PLld1rfmAfh8Y54vtbj14lnA97w.cache +0 -0
  330. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/aF/aFH86QOIHdQC7ZEGpM8MR_9E4H3_VvYLHAQpVSe7foc.cache +1 -0
  331. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/aQ/aQL0CNPS5ESzN5XcS9o8NF7i4bv4pCm0xdrA7vfw5fc.cache +2 -0
  332. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/aR/aR5t7yCAR6IoNonATlf4QuZZSFc4k_ERK1u2fltqois.cache +1 -0
  333. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/bD/bDIuRJAlDi98cyI-tv6gf95cK6b2lDclVk6gw7-4yQE.cache +1 -0
  334. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/bl/blP7I9wrpMZirmqxSinkxvHgn7dwfxBAvHlUkCTQf9Q.cache +1 -0
  335. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/bu/buXbbv7z8SqC7DAPe_4Oip10Xm9GRMFE9VIlCHH3pDQ.cache +1 -0
  336. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/c7/c7CooReQb2ejxEumMNCGRid6lhlPFxxlYhiSx0BnFf4.cache +1 -0
  337. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/dA/dAHQRa7vNh2S7w1XeJtr1U_6dY_0QjlBx4dYo1UQHOg.cache +1 -0
  338. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/dG/dG2st3mUGsh-8yC115nqU2IltElHJVNhu2vRfijxs20.cache +1 -0
  339. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/dp/dpzW4cK3NsJEHAYf7z-nszapTBk7oQrhBPjmkIoZoXQ.cache +1 -0
  340. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/eJ/eJhiyiHTMJUDd_OqCXD93jBwAivnKRBa5x5qtFrxQj8.cache +1 -0
  341. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/fR/fRbCj1aNB38O-9pznPKZJ-EZoFXBeVilAs0WroTkIEM.cache +1 -0
  342. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/fU/fUQKkajuOuSLJQtRtjum4rOrJsTBFTgtwktNG4QVlrQ.cache +1 -0
  343. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/fq/fqqy6XMocl_Tx0nWsOC1LQ_uj3jUrV-CN8kMgtDR0Bc.cache +2 -0
  344. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/gd/gdC8KjHpTRTYsyeT0HoM5RR_ZKDCK_4XKXQO81ArNlM.cache +0 -0
  345. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/i_/i_s59CkDPBCbkVzR2yxiT9kpEI1B0pO0OYOIwTGpkcI.cache +2 -0
  346. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/ip/ipi1NeZWfWKRKJ3wXF6d_iPE8V0BdYHjDxYhBLc98A8.cache +0 -0
  347. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/j1/j1BQXikuCXkgfl_ekvX7byh1qZLEg4hhbmTdGdJVijs.cache +0 -0
  348. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/jK/jKHqW1VBzFtw_WgOZ-5WFrod_nbiYJ_Duey1VZXs3Mo.cache +0 -0
  349. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/jU/jUmxOIOwQBdZhDyVmTtD0UUEWZz_9Iu64WY59bXHgs0.cache +1 -0
  350. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/kD/kDartayL6A6j26rd-NkFIU9yqvIIJh9IUdiLsbuHoPY.cache +1 -0
  351. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/lS/lStvx9Beg2l4s8L-QdTSKuc5_qQPQAZPnIcRI7JkpPE.cache +2 -0
  352. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/nI/nIKQa784qYcxM8_rmLncqiSL4jWWsKrqq19GrEprQ34.cache +1 -0
  353. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/n_/n_xYqQYhwEMQknb3jFQnjlxxBE9TzMNHCdJ-bEyZFIw.cache +2 -0
  354. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/nq/nqBvCfX72u2EvAyNfHt3upjIFz009V5YYgwPmmaNRH4.cache +3 -0
  355. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/nt/ntry6y5LOGB3mXS76ylx-eIcul__UqoQoqB4-0eaNnI.cache +2 -0
  356. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/nx/nxTv3sKVUQZADJyM3dPaVmUA78MIsMLD_K279yN_GsI.cache +2 -0
  357. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/qq/qqeUBxpDPTNXL2hYWXX8t_E_jxRkRpjhJR-FcdiLWr0.cache +3 -0
  358. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/qt/qtFUQpglBnMnPpRsGKkhr2rqj9Ub3yOf_h01fudm3pc.cache +0 -0
  359. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/sm/smkjNAEzX7uLiRZnQA38poQvnhHE5uHIlMpkirr_K04.cache +2 -0
  360. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/tT/tTXQZvDRiDXhq7fbuy2-ynEkHbWEWkZixvWp8TOC7vQ.cache +1 -0
  361. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/v_/v_O7CAdXG7icZucqoA971FxfXpz7XWC8PtjH-Z1HIFU.cache +3 -0
  362. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/vw/vw4hWcAaXGLEo2E8KRM86fVgJAvs7q3qkZYmkI2UYG0.cache +2 -0
  363. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/w8/w8XS90xe44-zLTirkVNvEMgky0Iu-y4R4tWoQTHOkWA.cache +1 -0
  364. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/wH/wHiXMAfKVNHdoxvX_7U_fJX97Kv2TDg5VZs6QQGgM7k.cache +1 -0
  365. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/wY/wYXscG863_Dznp_gsU3c1NlFGjKgloZPKnaFeHYhgLg.cache +0 -0
  366. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/wi/win_v0ZNu-l7AoRx8w3ls1xcy0mUExLBVMCSr5oaJFc.cache +0 -0
  367. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/ws/wsn2nUkOEHSwCK9Q1WpZekvvnYE5COQwF3keiKR9-0A.cache +1 -0
  368. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/yM/yMREEbi29WAWRdWlQTj_ovW5SHtEt1exOy8aWy1PCI4.cache +1 -0
  369. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/yq/yqxTsMP8kmCSie9aYhLgHs_Db7h-sSa5vmqZZJUtwv0.cache +0 -0
  370. data/spec/dummy~/tmp/cache/assets/sprockets/v3.0/yr/yrp_60uUSk5SlU1028XR4AIpun11BkJJOvIgatVUYBQ.cache +2 -0
  371. data/spec/dummy~/tmp/development_secret.txt +1 -0
  372. data/spec/factories/cmor/user_area/users.rb +15 -0
  373. data/spec/features/authentication_feature_spec.rb +32 -0
  374. data/spec/features/registration_feature_spec.rb +76 -0
  375. data/spec/models/cmor/user_area/user_spec.rb +7 -0
  376. data/spec/models/generic_spec.rb +49 -0
  377. data/spec/models/i18n_spec.rb +40 -0
  378. data/spec/models~/generic_spec.rb +33 -0
  379. data/spec/rails_helper.rb +62 -0
  380. data/spec/rails_helper.rb~ +57 -0
  381. data/spec/services/cmor/user_area/create_default_user_service_spec.rb +36 -0
  382. data/spec/spec_helper.rb +96 -0
  383. data/spec/spec_helper.rb~ +90 -0
  384. data/spec/support/capybara.rb +1 -0
  385. data/spec/support/factory_bot.rb +5 -0
  386. data/spec/support/pry-rails.rb +1 -0
  387. data/spec/support/rao-shoulda_matchers.rb +5 -0
  388. data/spec/support/shoulda_matchers.rb +8 -0
  389. data/spec/support~/capybara.rb +1 -0
  390. data/spec/support~/factory_girl.rb +5 -0
  391. data/spec/support~/formulaic.rb +5 -0
  392. metadata +797 -0
@@ -0,0 +1 @@
1
+ "%�d�������f�C��R�旔������P�
@@ -0,0 +1 @@
1
+ I"�/home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor_core.css?type=text/css&id=3106045334470e1c15d2d2ef95d3845f4903d8deed3139f775fdb8f7ef1c67b3:ET
@@ -0,0 +1,2 @@
1
+ [o:Set:
2
+ @hash}I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI">processors:type=text/css&file_type=text/css&pipeline=self;TTI"^file-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor_core.css;TTI".file-digest://app/assets/config/cmor/core;TTI":file-digest://app/assets/config/cmor/core/application;TTI".file-digest://app/assets/images/cmor/core;TTI":file-digest://app/assets/images/cmor/core/application;TTI"3file-digest://app/assets/javascripts/cmor/core;TTI"?file-digest://app/assets/javascripts/cmor/core/application;TTI"3file-digest://app/assets/stylesheets/cmor/core;TTI"?file-digest://app/assets/stylesheets/cmor/core/application;TTI"yfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/rao-component-0.0.15.pre/app/assets/javascripts/cmor/core;TTI"�file-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/rao-component-0.0.15.pre/app/assets/javascripts/cmor/core/application;TTI"Ufile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/config/cmor/core;TTI"afile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/config/cmor/core/application;TTI"Ufile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/images/cmor/core;TTI"afile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/images/cmor/core/application;TTI"Zfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core;TTI"ffile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/application;TTI"Zfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core;TTI"ffile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core/application;TTI"jfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core/application.css;TTF
@@ -0,0 +1,2 @@
1
+ [o:Set:
2
+ @hash} I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI"Zprocessors:type=application/javascript&file_type=application/javascript&pipeline=self;TTI"qfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/backend/application.js;TTI"nfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/backend/application;TTI"vfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/backend/application/keep.js;TTF
@@ -0,0 +1 @@
1
+ I"�/home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/application/keep.js?type=application/javascript&pipeline=self&id=3ea7e06c061e4f379a08c66ea86096d21bb19814bf17997ad083c4f0b5f53ccf:ET
@@ -0,0 +1 @@
1
+ "%n��Y�3�>�ǖk��k�q����l�o�:b
@@ -0,0 +1,2 @@
1
+ [o:Set:
2
+ @hash}1I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI"Zprocessors:type=application/javascript&file_type=application/javascript&pipeline=self;TTI"8file-digest://app/assets/javascripts/application.js;TTI"$file-digest://app/assets/config;TTI".file-digest://app/assets/config/rails-ujs;TTI"$file-digest://app/assets/images;TTI".file-digest://app/assets/images/rails-ujs;TTI")file-digest://app/assets/javascripts;TTI"3file-digest://app/assets/javascripts/rails-ujs;TTI")file-digest://app/assets/stylesheets;TTI"3file-digest://app/assets/stylesheets/rails-ujs;TTI"ofile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/rao-component-0.0.15.pre/app/assets/javascripts;TTI"yfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/rao-component-0.0.15.pre/app/assets/javascripts/rails-ujs;TTI"Kfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/config;TTI"Ufile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/config/rails-ujs;TTI"Kfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/images;TTI"Ufile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/images/rails-ujs;TTI"Pfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts;TTI"Zfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/rails-ujs;TTI"Pfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets;TTI"Zfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/rails-ujs;TTI"gfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/actioncable-5.2.2.1/lib/assets/compiled;TTI"qfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/actioncable-5.2.2.1/lib/assets/compiled/rails-ujs;TTI"lfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/activestorage-5.2.2.1/app/assets/javascripts;TTI"vfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/activestorage-5.2.2.1/app/assets/javascripts/rails-ujs;TTI"ffile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/actionview-5.2.2.1/lib/assets/compiled;TTI"pfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/actionview-5.2.2.1/lib/assets/compiled/rails-ujs;TTI"sfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/actionview-5.2.2.1/lib/assets/compiled/rails-ujs.js;TTI"2file-digest://app/assets/config/activestorage;TTI"2file-digest://app/assets/images/activestorage;TTI"7file-digest://app/assets/javascripts/activestorage;TTI"7file-digest://app/assets/stylesheets/activestorage;TTI"}file-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/rao-component-0.0.15.pre/app/assets/javascripts/activestorage;TTI"Yfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/config/activestorage;TTI"Yfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/images/activestorage;TTI"^file-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/activestorage;TTI"^file-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/activestorage;TTI"ufile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/actioncable-5.2.2.1/lib/assets/compiled/activestorage;TTI"zfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/activestorage-5.2.2.1/app/assets/javascripts/activestorage;TTI"}file-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/activestorage-5.2.2.1/app/assets/javascripts/activestorage.js;TTI"2file-digest://app/assets/javascripts/channels;TTI"2file-digest://app/assets/javascripts/cable.js;TTF
@@ -0,0 +1 @@
1
+ I"�app/assets/stylesheets/application.css?type=text/css&pipeline=self&id=4067352bb926ec726bd3f882c41f3ac83dd4080f4c35acce623661467d3d46a4:ET
@@ -0,0 +1,2 @@
1
+ [o:Set:
2
+ @hash} I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI">processors:type=text/css&file_type=text/css&pipeline=self;TTI"9file-digest://app/assets/stylesheets/application.css;TTI")file-digest://app/assets/stylesheets;TTF
@@ -0,0 +1,3 @@
1
+ [o:Set:
2
+ @hash}
3
+ I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI">processors:type=text/css&file_type=text/css&pipeline=self;TTI"xfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core/application/bottom-margin.css;TTF
@@ -0,0 +1,2 @@
1
+ [o:Set:
2
+ @hash}I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI"0processors:type=text/css&file_type=text/css;TTI"jfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core/application.css;TTI">processors:type=text/css&file_type=text/css&pipeline=self;TTI"}file-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core/application/bootstrap-flex-row.css;TTI"xfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core/application/bottom-margin.css;TTI"ffile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core/application;TTF
@@ -0,0 +1,2 @@
1
+ [o:Set:
2
+ @hash} I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI"0processors:type=text/css&file_type=text/css;TTI"9file-digest://app/assets/stylesheets/application.css;TTI">processors:type=text/css&file_type=text/css&pipeline=self;TTI")file-digest://app/assets/stylesheets;TTF
@@ -0,0 +1,3 @@
1
+ [o:Set:
2
+ @hash}
3
+ I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI"Zprocessors:type=application/javascript&file_type=application/javascript&pipeline=self;TTI"vfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/backend/application/keep.js;TTF
@@ -0,0 +1,2 @@
1
+ [o:Set:
2
+ @hash}I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI"Lprocessors:type=application/javascript&file_type=application/javascript;TTI"]file-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor_core.js;TTI"Zprocessors:type=application/javascript&file_type=application/javascript&pipeline=self;TTI"nfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/application/keep.js;TTI"ifile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/application.js;TTI"ffile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/application;TTI"Zfile-digest:///home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core;TTF
@@ -0,0 +1 @@
1
+ "%A��G �{h t�l�m�V���NE���f���
@@ -0,0 +1,3 @@
1
+ [o:Set:
2
+ @hash}
3
+ I"environment-version:ETTI"environment-paths;TTI"rails-env;TTI"Zprocessors:type=application/javascript&file_type=application/javascript&pipeline=self;TTI"wfile-digest:///home/vagrant/.rvm/gems/ruby-2.3.7@cmor/gems/actioncable-5.2.2.1/lib/assets/compiled/action_cable.js;TTF
@@ -0,0 +1 @@
1
+ "%�I̳jF�`P$�^1o�E���wC4�����1
@@ -0,0 +1 @@
1
+ I"�/home/vagrant/rails/ecm/cmor/cmor_core/app/assets/javascripts/cmor/core/backend/application/keep.js?type=application/javascript&pipeline=self&id=0a81aed37b90bb7ca515b87bfb8f06404eed2b02041e31d90ad9084d3f674d07:ET
@@ -0,0 +1 @@
1
+ I"�app/assets/javascripts/application.js?type=application/javascript&id=1dcff876b6b5329d79887bdcbfbb1f29f01e2bbf7755810c7ed6122a70058d53:ET
@@ -0,0 +1 @@
1
+ I"�/home/vagrant/rails/ecm/cmor/cmor_core/app/assets/stylesheets/cmor/core/application.css?type=text/css&id=8a2ca7a56f2368de43a9dceabbdfac1e879db3f0da26b7c0930597ae0ce1fe8f:ET
@@ -0,0 +1 @@
1
+ ad7d0dd17ccb560c6f02d75173624944883ec3dfdbc3008ef9d551a2fee94a2f9fbd663c7c3037b13c3b2e7687859ed170ae9ca50162b397a43c5d2c058dc57c
@@ -0,0 +1,15 @@
1
+ # Read about factories at https://github.com/thoughtbot/factory_girl
2
+
3
+ FactoryBot.define do
4
+ factory :cmor_user_area_user, class: 'Cmor::UserArea::User' do
5
+ sequence(:email) { |n| "user#{n}@example.com" }
6
+ password { 'password' }
7
+ password_confirmation { 'password' }
8
+
9
+ trait :authenticable do
10
+ active { true }
11
+ confirmed { true }
12
+ approved { true }
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,32 @@
1
+ require 'rails_helper'
2
+ require 'cmor/user_area/spec_helpers/feature'
3
+
4
+ RSpec.describe 'User Area -> Authentication', type: :feature do
5
+ include Cmor::UserArea::SpecHelpers::Feature
6
+
7
+ before(:each) { I18n.locale = :de }
8
+
9
+ describe 'sign in' do
10
+ context 'with an existant user' do
11
+ let(:user) { Cmor::UserArea::CreateDefaultUserService.call.user }
12
+
13
+ before(:each) { user }
14
+
15
+ it 'should sign in' do
16
+ sign_in(user)
17
+ expect(page.body).to include(I18n.t('messages.success.cmor_user_area.signed_in'))
18
+ end
19
+ end
20
+ end
21
+
22
+ describe 'sign out' do
23
+ let(:user) { Cmor::UserArea::CreateDefaultUserService.call.user }
24
+
25
+ before(:each) { sign_in(user) }
26
+
27
+ it 'should redirect to the home page' do
28
+ click_link('Ausloggen')
29
+ page.current_path.should eq('/de')
30
+ end
31
+ end # describe 'logout'
32
+ end
@@ -0,0 +1,76 @@
1
+ require 'rails_helper'
2
+ require 'cmor/user_area/spec_helpers/feature'
3
+
4
+ RSpec.describe 'User Area -> Registration', type: :feature do
5
+ include Cmor::UserArea::SpecHelpers::Feature
6
+
7
+ before(:each) { I18n.locale = :de }
8
+
9
+ describe 'new registration' do
10
+ around(:each) { |example| with_enabled_registrations { example } }
11
+
12
+ context 'when not signed in' do
13
+ let(:user_attributes) { attributes_for(:cmor_user_area_user) }
14
+
15
+ it 'should create a user' do
16
+ expect { sign_up(user_attributes) }.to change { Cmor::UserArea::User.count }.from(0).to(1)
17
+ end
18
+
19
+ it 'should redirect to root' do
20
+ sign_up(user_attributes)
21
+ expect(page.current_path).to eq(main_app.root_path)
22
+ end
23
+
24
+ it 'should show a success message' do
25
+ sign_up(user_attributes)
26
+ expect(page.body).to include(I18n.t('messages.confirmations.cmor_user_area.send_instructions'))
27
+ end
28
+ end
29
+ end
30
+
31
+ describe 'editing a registration' do
32
+ let(:edit_current_user_path) { "/de/benutzer/profil/edit" }
33
+
34
+ context 'when signed in' do
35
+ let(:user) { Cmor::UserArea::CreateDefaultUserService.call.user }
36
+
37
+ before(:each) { sign_in(user) }
38
+
39
+ it 'should allow access' do
40
+ visit(edit_current_user_path)
41
+ page.current_path.should eq(edit_current_user_path)
42
+ end
43
+
44
+ context 'changing email' do
45
+ let(:new_user_session_path) { "/de/benutzer/session/new" }
46
+
47
+ before(:each) { visit(edit_current_user_path) }
48
+
49
+ it do
50
+ expect do
51
+ fill_in 'user[email]', with: 'new@example.com'
52
+ within("form.edit_user") { find("input[type='submit']").click }
53
+ end.to change {
54
+ user.reload.email
55
+ }.from(user.email).to('new@example.com')
56
+ end
57
+
58
+ it 'should sign out' do
59
+ fill_in 'user[email]', with: 'new@example.com'
60
+ within("form.edit_user") { find("input[type='submit']").click }
61
+
62
+ expect(page.current_path).to eq(new_user_session_path)
63
+ end
64
+ end
65
+ end
66
+
67
+ context 'when not signed in' do
68
+ let(:new_user_session_path) { "/de/benutzer/session/new" }
69
+
70
+ it 'should redirect to the sign in page' do
71
+ visit(edit_current_user_path)
72
+ page.current_path.should eq(new_user_session_path)
73
+ end
74
+ end
75
+ end
76
+ end
@@ -0,0 +1,7 @@
1
+ require 'rails_helper'
2
+
3
+ module Cmor::UserArea
4
+ describe User do
5
+ it { expect(subject).to respond_to(:human) }
6
+ end
7
+ end
@@ -0,0 +1,49 @@
1
+ require 'rails_helper'
2
+
3
+ RSpec.describe 'ActiveRecord::Base models', type: :model do
4
+ DEFAULT_SPECS_TO_RUN = [
5
+ :is_an_active_record,
6
+ :is_instanciable,
7
+ :valid_with_correct_attributes,
8
+ :not_valid_with_empty_attributes,
9
+ :saves_with_valid_attributes
10
+ ]
11
+
12
+ {
13
+ Cmor::UserArea::User => {},
14
+ }.each do |model, options|
15
+ options.reverse_merge!(specs_to_run: DEFAULT_SPECS_TO_RUN, specs_to_skip: [])
16
+ specs_to_run = options.delete(:specs_to_run)
17
+ specs_to_skip = options.delete(:specs_to_skip)
18
+ specs = specs_to_run - specs_to_skip
19
+
20
+ describe model do
21
+ it 'is an ActiveRecord::Base' do
22
+ expect(ActiveRecord::Base.descendants).to include(model)
23
+ end if specs.include?(:is_an_active_record)
24
+
25
+ it 'is instanciable' do
26
+ instance = model.new
27
+ expect(instance).to be_a(model)
28
+ end if specs.include?(:is_instanciable)
29
+
30
+ it 'is valid with correct attribute values' do
31
+ instance = build(model.to_s.tableize.singularize.underscore.tr('/', '_'))
32
+
33
+ instance.valid?
34
+ expect(instance.errors.full_messages).to eq([])
35
+ end if specs.include?(:valid_with_correct_attributes)
36
+
37
+ it 'is not valid with empty attributes' do
38
+ instance = model.new
39
+ expect(instance).not_to be_valid
40
+ end if specs.include?(:not_valid_with_empty_attributes)
41
+
42
+ it 'saves with valid attributes' do
43
+ instance = build(model.to_s.tableize.singularize.underscore.tr('/', '_'))
44
+ expect(instance.save).to be_truthy
45
+ expect(instance).to be_persisted
46
+ end if specs.include?(:saves_with_valid_attributes)
47
+ end
48
+ end
49
+ end
@@ -0,0 +1,40 @@
1
+ require 'rails_helper'
2
+
3
+ RSpec.describe 'Translations', type: :model do
4
+ {
5
+ Cmor::UserArea::User => {},
6
+ }.each do |model, options|
7
+ I18n.available_locales.each do |locale|
8
+ I18n.locale = locale
9
+
10
+ describe "for locale #{locale}:" do
11
+ describe "#{model} translations" do
12
+ it 'include one' do
13
+ I18n.locale = locale
14
+ i18n_key = ['activerecord', 'models', model.name.underscore].join('.')
15
+ i18n_options = {}
16
+ expect(I18n.translate!(i18n_key, options)[:one]).to be_a(String)
17
+ end
18
+
19
+ it 'include other' do
20
+ I18n.locale = locale
21
+ i18n_key = ['activerecord', 'models', model.name.underscore].join('.')
22
+ i18n_options = {}
23
+ expect(I18n.translate!(i18n_key, options)[:other]).to be_a(String)
24
+ end
25
+
26
+ describe 'for attributes' do
27
+
28
+ model.column_names.each do |column_name|
29
+ it "include #{column_name}" do
30
+ I18n.locale = locale
31
+ i18n_key = ['activerecord', 'attributes', model.name.underscore, column_name].join('.')
32
+ expect(I18n.translate!(i18n_key)).to be_a(String)
33
+ end
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -0,0 +1,33 @@
1
+ require 'rails_helper'
2
+
3
+ describe 'ActiveRecord::Base models' do
4
+ ActiveRecord::Base.descendants.map(&:to_s).reject { |m| %w(Delayed::Backend::ActiveRecord::Job).include?(m) }.each do |model_name|
5
+ model = model_name.constantize
6
+ describe model do
7
+ it 'should be an ActiveRecord::Base' do
8
+ expect(ActiveRecord::Base.descendants).to include(model)
9
+ end
10
+
11
+ it 'should be instanciable' do
12
+ instance = model.new
13
+ expect(instance).to be_a(model)
14
+ end
15
+
16
+ it 'should be valid with correct attribute values' do
17
+ instance = create(model.to_s.tableize.singularize.underscore.tr('/', '_'))
18
+ expect(instance.valid?).to be_truthy
19
+ end
20
+
21
+ it 'should not be valid with empty attributes' do
22
+ instance = model.new
23
+ expect(instance.valid?).to be_falsey
24
+ end
25
+
26
+ it 'should save with valid attributes' do
27
+ instance = create(model.to_s.tableize.singularize.underscore.tr('/', '_'))
28
+ expect(instance.save).to be_truthy
29
+ expect(instance).to be_persisted
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,62 @@
1
+ # This file is copied to spec/ when you run 'rails generate rspec:install'
2
+ require 'spec_helper'
3
+ ENV['RAILS_ENV'] ||= 'test'
4
+ require File.expand_path('../dummy/config/environment', __FILE__)
5
+ # Prevent database truncation if the environment is production
6
+ abort("The Rails environment is running in production mode!") if Rails.env.production?
7
+ require 'rspec/rails'
8
+ # Add additional requires below this line. Rails is not loaded until this point!
9
+
10
+ # Requires supporting ruby files with custom matchers and macros, etc, in
11
+ # spec/support/ and its subdirectories. Files matching `spec/**/*_spec.rb` are
12
+ # run as spec files by default. This means that files in spec/support that end
13
+ # in _spec.rb will both be required and run as specs, causing the specs to be
14
+ # run twice. It is recommended that you do not name files matching this glob to
15
+ # end with _spec.rb. You can configure this pattern with the --pattern
16
+ # option on the command line or in ~/.rspec, .rspec or `.rspec-local`.
17
+ #
18
+ # The following line is provided for convenience purposes. It has the downside
19
+ # of increasing the boot-up time by auto-requiring all files in the support
20
+ # directory. Alternatively, in the individual `*_spec.rb` files, manually
21
+ # require only the support files necessary.
22
+ #
23
+ # Dir[Rails.root.join('spec', 'support', '**', '*.rb')].each { |f| require f }
24
+ Dir[Cmor::UserArea::Engine.root.join('spec', 'support', '**', '*.rb')].each { |f| require f }
25
+
26
+ # Checks for pending migrations and applies them before tests are run.
27
+ # If you are not using ActiveRecord, you can remove these lines.
28
+ # begin
29
+ # ActiveRecord::Migration.maintain_test_schema!
30
+ # rescue ActiveRecord::PendingMigrationError => e
31
+ # puts e.to_s.strip
32
+ # exit 1
33
+ # end
34
+ RSpec.configure do |config|
35
+ # Remove this line if you're not using ActiveRecord or ActiveRecord fixtures
36
+ config.fixture_path = "#{::Rails.root}/spec/fixtures"
37
+
38
+ # If you're not using ActiveRecord, or you'd prefer not to run each of your
39
+ # examples within a transaction, remove the following line or assign false
40
+ # instead of true.
41
+ config.use_transactional_fixtures = true
42
+
43
+ # RSpec Rails can automatically mix in different behaviours to your tests
44
+ # based on their file location, for example enabling you to call `get` and
45
+ # `post` in specs under `spec/controllers`.
46
+ #
47
+ # You can disable this behaviour by removing the line below, and instead
48
+ # explicitly tag your specs with their type, e.g.:
49
+ #
50
+ # RSpec.describe UsersController, :type => :controller do
51
+ # # ...
52
+ # end
53
+ #
54
+ # The different available types are documented in the features, such as in
55
+ # https://relishapp.com/rspec/rspec-rails/docs
56
+ config.infer_spec_type_from_file_location!
57
+
58
+ # Filter lines from Rails gems in backtraces.
59
+ config.filter_rails_from_backtrace!
60
+ # arbitrary gems may also be filtered via:
61
+ # config.filter_gems_from_backtrace("gem name")
62
+ end
@@ -0,0 +1,57 @@
1
+ # This file is copied to spec/ when you run 'rails generate rspec:install'
2
+ ENV['RAILS_ENV'] ||= 'test'
3
+ require File.expand_path('../dummy/config/environment', __FILE__)
4
+ # Prevent database truncation if the environment is production
5
+ abort('The Rails environment is running in production mode!') if Rails.env.production?
6
+ require 'spec_helper'
7
+ require 'rspec/rails'
8
+ # Add additional requires below this line. Rails is not loaded until this point!
9
+
10
+ # Requires supporting ruby files with custom matchers and macros, etc, in
11
+ # spec/support/ and its subdirectories. Files matching `spec/**/*_spec.rb` are
12
+ # run as spec files by default. This means that files in spec/support that end
13
+ # in _spec.rb will both be required and run as specs, causing the specs to be
14
+ # run twice. It is recommended that you do not name files matching this glob to
15
+ # end with _spec.rb. You can configure this pattern with the --pattern
16
+ # option on the command line or in ~/.rspec, .rspec or `.rspec-local`.
17
+ #
18
+ # The following line is provided for convenience purposes. It has the downside
19
+ # of increasing the boot-up time by auto-requiring all files in the support
20
+ # directory. Alternatively, in the individual `*_spec.rb` files, manually
21
+ # require only the support files necessary.
22
+ #
23
+ Dir[File.expand_path('../support/**/*.rb', __FILE__)].each { |f| require f }
24
+
25
+ # Checks for pending migration and applies them before tests are run.
26
+ # If you are not using ActiveRecord, you can remove this line.
27
+ # ActiveRecord::Migration.maintain_test_schema!
28
+
29
+ RSpec.configure do |config|
30
+ # Remove this line if you're not using ActiveRecord or ActiveRecord fixtures
31
+ # config.fixture_path = "#{::Rails.root}/spec/fixtures"
32
+
33
+ # If you're not using ActiveRecord, or you'd prefer not to run each of your
34
+ # examples within a transaction, remove the following line or assign false
35
+ # instead of true.
36
+ config.use_transactional_fixtures = true
37
+
38
+ # RSpec Rails can automatically mix in different behaviours to your tests
39
+ # based on their file location, for example enabling you to call `get` and
40
+ # `post` in specs under `spec/controllers`.
41
+ #
42
+ # You can disable this behaviour by removing the line below, and instead
43
+ # explicitly tag your specs with their type, e.g.:
44
+ #
45
+ # RSpec.describe UsersController, :type => :controller do
46
+ # # ...
47
+ # end
48
+ #
49
+ # The different available types are documented in the features, such as in
50
+ # https://relishapp.com/rspec/rspec-rails/docs
51
+ config.infer_spec_type_from_file_location!
52
+
53
+ # Filter lines from Rails gems in backtraces.
54
+ config.filter_rails_from_backtrace!
55
+ # arbitrary gems may also be filtered via:
56
+ # config.filter_gems_from_backtrace("gem name")
57
+ end