fat_free_crm 0.18.2 → 0.19.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of fat_free_crm might be problematic. Click here for more details.

Files changed (251) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop_todo.yml +61 -160
  3. data/.travis.yml +27 -11
  4. data/CHANGELOG.md +40 -24
  5. data/CONTRIBUTORS.md +1 -0
  6. data/Dockerfile +45 -14
  7. data/Gemfile +16 -10
  8. data/Gemfile.lock +230 -222
  9. data/Procfile +1 -1
  10. data/README.md +2 -2
  11. data/Rakefile +1 -1
  12. data/app/assets/stylesheets/common.scss +1 -1
  13. data/app/controllers/admin/application_controller.rb +1 -1
  14. data/app/controllers/admin/field_groups_controller.rb +1 -3
  15. data/app/controllers/admin/tags_controller.rb +1 -3
  16. data/app/controllers/admin/users_controller.rb +5 -8
  17. data/app/controllers/application_controller.rb +11 -45
  18. data/app/controllers/comments_controller.rb +2 -5
  19. data/{config/initializers/authlogic.rb → app/controllers/confirmations_controller.rb} +4 -2
  20. data/app/controllers/emails_controller.rb +0 -2
  21. data/app/controllers/entities/accounts_controller.rb +1 -3
  22. data/app/controllers/entities/campaigns_controller.rb +1 -3
  23. data/app/controllers/entities/contacts_controller.rb +4 -24
  24. data/app/controllers/entities/leads_controller.rb +7 -10
  25. data/app/controllers/entities/opportunities_controller.rb +4 -14
  26. data/app/controllers/entities_controller.rb +21 -7
  27. data/app/controllers/home_controller.rb +2 -4
  28. data/app/controllers/passwords_controller.rb +3 -59
  29. data/{spec/features/support/maintain_sessions.rb → app/controllers/registrations_controller.rb} +12 -5
  30. data/{lib/development_tasks/gem.rake → app/controllers/sessions_controller.rb} +6 -6
  31. data/app/controllers/tasks_controller.rb +8 -17
  32. data/app/controllers/users_controller.rb +8 -29
  33. data/app/helpers/admin/users_helper.rb +1 -1
  34. data/app/helpers/application_helper.rb +27 -32
  35. data/app/helpers/campaigns_helper.rb +1 -1
  36. data/app/helpers/contacts_helper.rb +1 -3
  37. data/app/helpers/opportunities_helper.rb +4 -12
  38. data/app/helpers/tasks_helper.rb +1 -1
  39. data/app/helpers/users_helper.rb +1 -3
  40. data/{config/initializers/paper_trail.rb → app/mailers/devise_mailer.rb} +5 -1
  41. data/app/mailers/user_mailer.rb +0 -9
  42. data/app/models/entities/account.rb +10 -10
  43. data/app/models/entities/campaign.rb +4 -6
  44. data/app/models/entities/contact.rb +24 -12
  45. data/app/models/entities/lead.rb +7 -7
  46. data/app/models/entities/opportunity.rb +7 -9
  47. data/app/models/fields/custom_field.rb +1 -0
  48. data/app/models/fields/custom_field_date_pair.rb +2 -0
  49. data/app/models/fields/field.rb +1 -3
  50. data/app/models/list.rb +1 -1
  51. data/app/models/observers/entity_observer.rb +3 -7
  52. data/app/models/observers/lead_observer.rb +2 -4
  53. data/app/models/observers/opportunity_observer.rb +2 -4
  54. data/app/models/observers/task_observer.rb +1 -1
  55. data/app/models/polymorphic/email.rb +2 -2
  56. data/app/models/polymorphic/task.rb +13 -9
  57. data/app/models/polymorphic/version.rb +3 -2
  58. data/app/models/setting.rb +2 -0
  59. data/app/models/users/permission.rb +3 -3
  60. data/app/models/users/preference.rb +2 -1
  61. data/app/models/users/user.rb +67 -42
  62. data/app/views/accounts/_top_section.html.haml +1 -1
  63. data/app/views/accounts/edit.js.haml +1 -1
  64. data/app/views/accounts/update.js.haml +2 -2
  65. data/app/views/admin/users/_user.html.haml +4 -4
  66. data/app/views/contacts/_index_brief.html.haml +1 -1
  67. data/app/views/contacts/_index_full.html.haml +1 -1
  68. data/app/views/contacts/_index_long.html.haml +1 -1
  69. data/app/views/devise/confirmations/new.html.haml +9 -0
  70. data/app/views/devise/mailer/confirmation_instructions.html.haml +4 -0
  71. data/app/views/devise/mailer/password_change.html.haml +3 -0
  72. data/app/views/devise/mailer/reset_password_instructions.html.haml +6 -0
  73. data/app/views/devise/passwords/edit.html.haml +18 -0
  74. data/app/views/devise/passwords/new.html.haml +10 -0
  75. data/app/views/devise/registrations/new.html.haml +21 -0
  76. data/app/views/devise/sessions/new.html.haml +32 -0
  77. data/app/views/layouts/_about.html.haml +5 -5
  78. data/app/views/layouts/_header.html.haml +3 -3
  79. data/app/views/layouts/admin/_header.html.haml +1 -1
  80. data/app/views/shared/_address.html.haml +5 -5
  81. data/app/views/shared/_paginate_with_per_page.html.haml +1 -0
  82. data/app/views/users/_avatar.html.haml +1 -1
  83. data/bin/bundle +1 -1
  84. data/bin/rails +1 -1
  85. data/bin/setup +38 -0
  86. data/bin/update +33 -0
  87. data/bin/yarn +13 -0
  88. data/config/application.rb +8 -6
  89. data/config/boot.rb +1 -1
  90. data/config/brakeman.ignore +2 -2
  91. data/config/database.postgres.docker.yml +5 -5
  92. data/config/environment.rb +1 -1
  93. data/config/environments/development.rb +1 -0
  94. data/config/environments/test.rb +7 -0
  95. data/config/initializers/action_mailer.rb +1 -3
  96. data/config/initializers/application_controller_renderer.rb +9 -0
  97. data/config/initializers/assets.rb +6 -11
  98. data/config/initializers/backtrace_silencers.rb +0 -6
  99. data/config/initializers/content_security_policy.rb +26 -0
  100. data/config/initializers/cookies_serializer.rb +3 -6
  101. data/config/initializers/devise.rb +289 -0
  102. data/config/initializers/filter_parameter_logging.rb +0 -5
  103. data/config/initializers/gravatar.rb +0 -1
  104. data/config/initializers/inflections.rb +0 -6
  105. data/config/initializers/mime_types.rb +1 -9
  106. data/config/initializers/new_framework_defaults_5_2.rb +40 -0
  107. data/config/initializers/relative_url_root.rb +1 -3
  108. data/config/initializers/session_store.rb +1 -3
  109. data/config/initializers/wrap_parameters.rb +4 -9
  110. data/config/locales/fat_free_crm.en-GB.yml +5 -5
  111. data/config/locales/fat_free_crm.en-US.yml +5 -5
  112. data/config/locales/fat_free_crm.fr.yml +1 -1
  113. data/config/locales/fat_free_crm.ru.yml +1 -0
  114. data/config/routes.rb +20 -9
  115. data/db/demo/users.yml +62 -81
  116. data/db/migrate/20100928030620_remove_uuid.rb +1 -2
  117. data/db/migrate/20120316045804_activities_to_versions.rb +1 -0
  118. data/db/migrate/20120510025219_add_not_null_constraints_for_timestamp_columns.rb +1 -0
  119. data/db/migrate/20180107082701_authlogic_to_devise.rb +58 -0
  120. data/db/schema.rb +48 -43
  121. data/docker-compose.yml +10 -0
  122. data/fat_free_crm.gemspec +11 -13
  123. data/lib/development_tasks/license.rake +2 -2
  124. data/lib/fat_free_crm/callback.rb +2 -2
  125. data/lib/fat_free_crm/comment_extensions.rb +2 -4
  126. data/lib/fat_free_crm/core_ext/string.rb +1 -1
  127. data/lib/fat_free_crm/engine.rb +1 -1
  128. data/lib/fat_free_crm/errors.rb +1 -1
  129. data/lib/fat_free_crm/export_csv.rb +1 -0
  130. data/lib/fat_free_crm/exportable.rb +1 -1
  131. data/lib/fat_free_crm/fields.rb +1 -1
  132. data/lib/fat_free_crm/gem_dependencies.rb +1 -1
  133. data/lib/fat_free_crm/gem_ext/simple_form/action_view_extensions/form_helper.rb +1 -3
  134. data/lib/fat_free_crm/i18n.rb +2 -2
  135. data/lib/fat_free_crm/mail_processor/base.rb +4 -10
  136. data/lib/fat_free_crm/mail_processor/dropbox.rb +5 -15
  137. data/lib/fat_free_crm/permissions.rb +7 -4
  138. data/lib/fat_free_crm/sortable.rb +1 -1
  139. data/lib/fat_free_crm/tabs.rb +2 -2
  140. data/lib/fat_free_crm/version.rb +2 -2
  141. data/lib/gravatar_image_tag.rb +7 -8
  142. data/lib/missing_translation_detector.rb +1 -0
  143. data/lib/tasks/ffcrm/missing_translations.rake +1 -0
  144. data/lib/tasks/ffcrm/setup.rake +10 -1
  145. data/lib/tasks/ffcrm/update_data.rake +2 -2
  146. data/script/rails +2 -2
  147. data/spec/controllers/admin/users_controller_spec.rb +0 -56
  148. data/spec/controllers/comments_controller_spec.rb +6 -6
  149. data/spec/controllers/entities/campaigns_controller_spec.rb +1 -1
  150. data/spec/controllers/entities/contacts_controller_spec.rb +2 -1
  151. data/spec/controllers/entities/leads_controller_spec.rb +2 -2
  152. data/spec/controllers/entities/opportunities_controller_spec.rb +1 -1
  153. data/spec/controllers/entities_controller_spec.rb +5 -0
  154. data/spec/controllers/home_controller_spec.rb +5 -5
  155. data/spec/controllers/tasks_controller_spec.rb +6 -4
  156. data/spec/controllers/users_controller_spec.rb +28 -98
  157. data/spec/factories/account_factories.rb +5 -5
  158. data/spec/factories/campaign_factories.rb +3 -3
  159. data/spec/factories/contact_factories.rb +8 -8
  160. data/spec/factories/field_factories.rb +4 -3
  161. data/spec/factories/lead_factories.rb +5 -5
  162. data/spec/factories/list_factories.rb +2 -2
  163. data/spec/factories/opportunity_factories.rb +3 -3
  164. data/spec/factories/setting_factories.rb +2 -2
  165. data/spec/factories/shared_factories.rb +11 -9
  166. data/spec/factories/task_factories.rb +7 -7
  167. data/spec/factories/user_factories.rb +16 -19
  168. data/spec/features/admin/groups_spec.rb +1 -1
  169. data/spec/features/admin/users_spec.rb +3 -1
  170. data/spec/features/campaigns_spec.rb +1 -1
  171. data/spec/features/contacts_spec.rb +1 -1
  172. data/spec/features/dashboard_spec.rb +1 -1
  173. data/spec/features/devise/sign_in_spec.rb +58 -0
  174. data/spec/features/devise/sign_up_spec.rb +36 -0
  175. data/spec/features/leads_spec.rb +1 -1
  176. data/spec/features/opportunities_overview_spec.rb +1 -1
  177. data/spec/features/opportunities_spec.rb +3 -3
  178. data/spec/features/support/browser.rb +2 -1
  179. data/spec/features/tasks_spec.rb +1 -1
  180. data/spec/helpers/admin/field_groups_helper_spec.rb +1 -1
  181. data/spec/helpers/users_helper_spec.rb +4 -4
  182. data/spec/lib/comment_extensions_spec.rb +10 -4
  183. data/spec/lib/errors_spec.rb +2 -2
  184. data/spec/lib/mail_processor/dropbox_spec.rb +1 -1
  185. data/spec/lib/mail_processor/sample_emails/dropbox.rb +8 -8
  186. data/spec/lib/permissions_spec.rb +8 -3
  187. data/spec/mailers/devise_mailer_spec.rb +35 -0
  188. data/spec/mailers/user_mailer_spec.rb +0 -26
  189. data/spec/models/entities/account_spec.rb +27 -0
  190. data/spec/models/entities/contact_spec.rb +96 -1
  191. data/spec/models/fields/custom_field_date_pair_spec.rb +4 -2
  192. data/spec/models/fields/custom_field_spec.rb +4 -2
  193. data/spec/models/observers/entity_observer_spec.rb +1 -1
  194. data/spec/models/polymorphic/version_spec.rb +7 -7
  195. data/spec/models/users/user_spec.rb +22 -26
  196. data/spec/routing/users_routing_spec.rb +30 -8
  197. data/spec/shared/controllers.rb +3 -9
  198. data/spec/spec_helper.rb +10 -2
  199. data/spec/support/assert_select.rb +1 -0
  200. data/spec/support/devise_helpers.rb +28 -0
  201. data/spec/{features/support/helpers.rb → support/feature_helpers.rb} +10 -10
  202. data/spec/support/macros.rb +4 -1
  203. data/spec/views/contacts/update.js.haml_spec.rb +1 -1
  204. data/spec/views/opportunities/update.js.haml_spec.rb +1 -1
  205. data/vendor/gems/ransack_ui-1.3.4/.gitignore +17 -0
  206. data/vendor/gems/ransack_ui-1.3.4/Gemfile +7 -0
  207. data/vendor/gems/ransack_ui-1.3.4/LICENSE.txt +22 -0
  208. data/vendor/gems/ransack_ui-1.3.4/README.md +57 -0
  209. data/vendor/gems/ransack_ui-1.3.4/Rakefile +1 -0
  210. data/vendor/gems/ransack_ui-1.3.4/app/assets/images/ransack_ui/calendar.png +0 -0
  211. data/vendor/gems/ransack_ui-1.3.4/app/assets/images/ransack_ui/delete.png +0 -0
  212. data/vendor/gems/ransack_ui-1.3.4/app/assets/javascripts/ransack/predicates.js.coffee +41 -0
  213. data/vendor/gems/ransack_ui-1.3.4/app/assets/javascripts/ransack_ui_bootstrap/button_group_select.js.coffee +26 -0
  214. data/vendor/gems/ransack_ui-1.3.4/app/assets/javascripts/ransack_ui_bootstrap/index.js.coffee +2 -0
  215. data/vendor/gems/ransack_ui-1.3.4/app/assets/javascripts/ransack_ui_jquery/index.js +2 -0
  216. data/vendor/gems/ransack_ui-1.3.4/app/assets/javascripts/ransack_ui_jquery/search_form.js.coffee.erb +499 -0
  217. data/vendor/gems/ransack_ui-1.3.4/app/assets/stylesheets/ransack_ui_bootstrap/index.css +3 -0
  218. data/vendor/gems/ransack_ui-1.3.4/app/assets/stylesheets/ransack_ui_bootstrap/search.css.scss +41 -0
  219. data/vendor/gems/ransack_ui-1.3.4/app/views/ransack_ui/_condition_fields.html.erb +15 -0
  220. data/vendor/gems/ransack_ui-1.3.4/app/views/ransack_ui/_grouping_fields.html.erb +16 -0
  221. data/vendor/gems/ransack_ui-1.3.4/app/views/ransack_ui/_search.html.erb +29 -0
  222. data/vendor/gems/ransack_ui-1.3.4/app/views/ransack_ui/_sort_fields.html.erb +4 -0
  223. data/vendor/gems/ransack_ui-1.3.4/config/locales/en.yml +24 -0
  224. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui.rb +9 -0
  225. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/adapters/active_record.rb +6 -0
  226. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/adapters/active_record/base.rb +46 -0
  227. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/controller_helpers.rb +18 -0
  228. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/rails/engine.rb +21 -0
  229. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/ransack_overrides/adapters/active_record/base.rb +47 -0
  230. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/ransack_overrides/configuration.rb +15 -0
  231. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/ransack_overrides/context.rb +9 -0
  232. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/ransack_overrides/helpers/form_builder.rb +262 -0
  233. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/ransack_overrides/nodes/attribute.rb +13 -0
  234. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/ransack_overrides/nodes/condition.rb +13 -0
  235. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/ransack_overrides/nodes/grouping.rb +20 -0
  236. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/version.rb +3 -0
  237. data/vendor/gems/ransack_ui-1.3.4/lib/ransack_ui/view_helpers.rb +30 -0
  238. data/vendor/gems/ransack_ui-1.3.4/ransack_ui.gemspec +23 -0
  239. metadata +79 -67
  240. data/app/controllers/authentications_controller.rb +0 -53
  241. data/app/models/users/authentication.rb +0 -56
  242. data/app/views/authentications/new.html.haml +0 -19
  243. data/app/views/passwords/edit.html.haml +0 -15
  244. data/app/views/passwords/new.html.haml +0 -10
  245. data/app/views/user_mailer/password_reset_instructions.html.haml +0 -6
  246. data/app/views/users/new.html.haml +0 -19
  247. data/spec/controllers/authentications_controller_spec.rb +0 -150
  248. data/spec/controllers/passwords_controller_spec.rb +0 -32
  249. data/spec/models/users/authentication_spec.rb +0 -19
  250. data/spec/support/auth_macros.rb +0 -49
  251. data/spec/views/authentications/new.haml_spec.rb +0 -31
@@ -25,12 +25,12 @@ describe CommentsController do
25
25
  end
26
26
 
27
27
  it "should redirect to the asset landing page if the asset is found" do
28
- get :index, params: { :"#{asset}_id" => @asset.id }
28
+ get :index, params: { "#{asset}_id": @asset.id }
29
29
  expect(response).to redirect_to(controller: asset.to_s.pluralize, action: :show, id: @asset.id)
30
30
  end
31
31
 
32
32
  it "should redirect to root url with warning if the asset is not found" do
33
- get :index, params: { :"#{asset}_id" => @asset.id + 42 }
33
+ get :index, params: { "#{asset}_id": @asset.id + 42 }
34
34
  expect(flash[:warning]).not_to eq(nil)
35
35
  expect(response).to redirect_to(root_path)
36
36
  end
@@ -44,12 +44,12 @@ describe CommentsController do
44
44
  end
45
45
 
46
46
  it "should render all comments as JSON if the asset is found found" do
47
- get :index, params: { :"#{asset}_id" => @asset.id }
47
+ get :index, params: { "#{asset}_id": @asset.id }
48
48
  expect(response.body).to eq(assigns[:comments].to_json)
49
49
  end
50
50
 
51
51
  it "JSON: should return 404 (Not Found) JSON error if the asset is not found" do
52
- get :index, params: { :"#{asset}_id" => @asset.id + 42 }
52
+ get :index, params: { "#{asset}_id": @asset.id + 42 }
53
53
  expect(flash[:warning]).not_to eq(nil)
54
54
  expect(response.code).to eq("404")
55
55
  end
@@ -63,12 +63,12 @@ describe CommentsController do
63
63
  end
64
64
 
65
65
  it "should render all comments as XML if the asset is found found" do
66
- get :index, params: { :"#{asset}_id" => @asset.id }
66
+ get :index, params: { "#{asset}_id": @asset.id }
67
67
  expect(response.body).to eq(assigns[:comments].to_xml)
68
68
  end
69
69
 
70
70
  it "XML: should return 404 (Not Found) XML error if the asset is not found" do
71
- get :index, params: { :"#{asset}_id" => @asset.id + 42 }
71
+ get :index, params: { "#{asset}_id": @asset.id + 42 }
72
72
  expect(flash[:warning]).not_to eq(nil)
73
73
  expect(response.code).to eq("404")
74
74
  end
@@ -370,7 +370,7 @@ describe CampaignsController do
370
370
 
371
371
  it "should update campaign permissions when sharing with specific users" do
372
372
  @campaign = create(:campaign, id: 42, access: "Public")
373
- he = create(:user, id: 7)
373
+ he = create(:user, id: 7)
374
374
  she = create(:user, id: 8)
375
375
 
376
376
  put :update, params: { id: 42, campaign: { name: "Hello", access: "Shared", user_ids: %w[7 8] } }, xhr: true
@@ -334,9 +334,10 @@ describe ContactsController do
334
334
  @contact = build(:contact, first_name: "Billy", last_name: "Bones")
335
335
  allow(Contact).to receive(:new).and_return(@contact)
336
336
 
337
- post :create, params: { contact: { first_name: "Billy", last_name: "Bones" }, account: { name: "Hello world" } }, xhr: true
337
+ post :create, params: { contact: { first_name: "Billy", last_name: "Bones" }, account: { id: "", name: "Hello world" } }, xhr: true
338
338
  expect(assigns(:contact)).to eq(@contact)
339
339
  expect(assigns(:contact).reload.account.name).to eq("Hello world")
340
+ expect(assigns(:contact).account.user).to eq(assigns(:contact).user)
340
341
  expect(response).to render_template("contacts/create")
341
342
  end
342
343
 
@@ -465,7 +465,7 @@ describe LeadsController do
465
465
 
466
466
  it "should update shared permissions for the lead" do
467
467
  @lead = create(:lead, user: current_user)
468
- he = create(:user, id: 7)
468
+ he = create(:user, id: 7)
469
469
  she = create(:user, id: 8)
470
470
 
471
471
  put :update, params: { id: @lead.id, lead: { access: "Shared", user_ids: %w[7 8] } }, xhr: true
@@ -995,7 +995,7 @@ describe LeadsController do
995
995
  @leads = [create(:lead, user: current_user, status: "new")]
996
996
  post :filter, params: { status: "new" }, xhr: true
997
997
  expect(assigns[:leads]).to eq(@leads)
998
- expect(response).to be_a_success
998
+ expect(response).to be_successful
999
999
  expect(response).to render_template("leads/index")
1000
1000
  end
1001
1001
 
@@ -890,7 +890,7 @@ describe OpportunitiesController do
890
890
  get :filter, params: { stage: "prospecting" }, xhr: true
891
891
  expect(assigns(:opportunities)).to eq(@opportunities)
892
892
  expect(assigns[:stage]).to eq(@stage)
893
- expect(response).to be_a_success
893
+ expect(response).to be_successful
894
894
  expect(response).to render_template("opportunities/index")
895
895
  end
896
896
 
@@ -19,6 +19,11 @@ describe EntitiesController do
19
19
  expect(controller.send(:parse_query_and_tags, str)).to eq(['', 'test'])
20
20
  end
21
21
 
22
+ it 'should parse #multiword tags' do
23
+ str = "#multiword tag#"
24
+ expect(controller.send(:parse_query_and_tags, str)).to eq(['', 'multiword tag'])
25
+ end
26
+
22
27
  it "should parse no tags" do
23
28
  str = "test query"
24
29
  expect(controller.send(:parse_query_and_tags, str)).to eq(['test query', ''])
@@ -23,7 +23,7 @@ describe HomeController do
23
23
  end
24
24
 
25
25
  it "should not include views in the list of activities" do
26
- create(:version, item: create(:account, user: @current_user), event: "view")
26
+ create(:version, item: create(:account, user: current_user), event: "view")
27
27
  expect(controller).to receive(:get_activities).once.and_return([])
28
28
 
29
29
  get :index
@@ -158,14 +158,14 @@ describe HomeController do
158
158
 
159
159
  it "should find a user by email" do
160
160
  allow(@cur_user).to receive(:pref).and_return(activity_user: 'billy@example.com')
161
- controller.instance_variable_set(:@current_user, @cur_user)
161
+ allow(controller).to receive(:current_user).and_return(@cur_user)
162
162
  expect(User).to receive(:where).with(email: 'billy@example.com').and_return([@user])
163
163
  expect(controller.send(:activity_user)).to eq(1)
164
164
  end
165
165
 
166
166
  it "should find a user by first name or last name" do
167
167
  allow(@cur_user).to receive(:pref).and_return(activity_user: 'Billy')
168
- controller.instance_variable_set(:@current_user, @cur_user)
168
+ allow(controller).to receive(:current_user).and_return(@cur_user)
169
169
  expect(User).to receive(:where).with(first_name: 'Billy').and_return([@user])
170
170
  expect(User).to receive(:where).with(last_name: 'Billy').and_return([@user])
171
171
  expect(controller.send(:activity_user)).to eq(1)
@@ -173,7 +173,7 @@ describe HomeController do
173
173
 
174
174
  it "should find a user by first name and last name" do
175
175
  allow(@cur_user).to receive(:pref).and_return(activity_user: 'Billy Elliot')
176
- controller.instance_variable_set(:@current_user, @cur_user)
176
+ allow(controller).to receive(:current_user).and_return(@cur_user)
177
177
  expect(User).to receive(:where).with(first_name: 'Billy', last_name: "Elliot").and_return([@user])
178
178
  expect(User).to receive(:where).with(first_name: 'Elliot', last_name: "Billy").and_return([@user])
179
179
  expect(controller.send(:activity_user)).to eq(1)
@@ -181,7 +181,7 @@ describe HomeController do
181
181
 
182
182
  it "should return nil when 'all_users' is specified" do
183
183
  allow(@cur_user).to receive(:pref).and_return(activity_user: 'all_users')
184
- controller.instance_variable_set(:@current_user, @cur_user)
184
+ allow(controller).to receive(:current_user).and_return(@cur_user)
185
185
  expect(User).not_to receive(:where)
186
186
  expect(controller.send(:activity_user)).to eq(nil)
187
187
  end
@@ -24,7 +24,7 @@ describe TasksController do
24
24
  end
25
25
  hash[due] << case view
26
26
  when "pending"
27
- create(:task, user: user, bucket: due.to_s)
27
+ create(:task, user: user, bucket: due.to_s, name: 'Example task')
28
28
  when "assigned"
29
29
  create(:task, user: user, bucket: due.to_s, assigned_to: 1)
30
30
  when "completed"
@@ -83,12 +83,14 @@ describe TasksController do
83
83
 
84
84
  expect(assigns[:tasks].keys.map(&:to_sym) - @tasks.keys).to eq([])
85
85
  expect(assigns[:tasks].values.flatten - @tasks.values.flatten).to eq([])
86
- hash = ActiveSupport::JSON.decode(response.body)
87
86
 
87
+ # TODO: This used to return "task" => {...} mappings, now just returns mappings
88
+ hash = ActiveSupport::JSON.decode(response.body)
88
89
  hash.each_key do |key|
89
- hash[key].each do |attr|
90
- task = Task.new(attr["task"])
90
+ hash[key].each do |data|
91
+ task = Task.new(data)
91
92
  expect(task).to be_instance_of(Task)
93
+ puts task.errors.inspect unless task.valid?
92
94
  expect(task.valid?).to eq(true)
93
95
  end
94
96
  end
@@ -50,7 +50,6 @@ describe UsersController do
50
50
  it "should render the requested user as JSON" do
51
51
  expect(User).to receive(:find).and_return(current_user)
52
52
  expect_any_instance_of(User).to receive(:to_json).and_return("generated JSON")
53
-
54
53
  get :show, params: { id: current_user.id }
55
54
  expect(response.body).to eq("generated JSON")
56
55
  end
@@ -85,32 +84,6 @@ describe UsersController do
85
84
  end
86
85
  end
87
86
 
88
- # GET /users/new
89
- # GET /users/new.xml HTML
90
- #----------------------------------------------------------------------------
91
- describe "responding to GET new" do
92
- describe "if user is allowed to sign up" do
93
- it "should expose a new user as @user and render [new] template" do
94
- expect(User).to receive(:can_signup?).and_return(true)
95
- @user = build(:user)
96
- allow(User).to receive(:new).and_return(@user)
97
-
98
- get :new
99
- expect(assigns[:user]).to eq(@user)
100
- expect(response).to render_template("users/new")
101
- end
102
- end
103
-
104
- describe "if user is not allowed to sign up" do
105
- it "should redirect to login_path" do
106
- expect(User).to receive(:can_signup?).and_return(false)
107
-
108
- get :new
109
- expect(response).to redirect_to(login_path)
110
- end
111
- end
112
- end
113
-
114
87
  # GET /users/1/edit AJAX
115
88
  #----------------------------------------------------------------------------
116
89
  describe "responding to GET edit" do
@@ -138,50 +111,6 @@ describe UsersController do
138
111
  end
139
112
  end
140
113
 
141
- # POST /users
142
- # POST /users.xml HTML
143
- #----------------------------------------------------------------------------
144
- describe "responding to POST create" do
145
- describe "with valid params" do
146
- before(:each) do
147
- @username = "none"
148
- @email = @username + "@example.com"
149
- @password = "secret"
150
- @user = build(:user, username: @username, email: @email)
151
- allow(User).to receive(:new).and_return(@user)
152
- end
153
-
154
- it "exposes a newly created user as @user and redirect to profile page" do
155
- login_admin
156
- post :create, params: { user: { username: @username, email: @email, password: @password, password_confirmation: @password } }
157
- expect(assigns[:user]).to eq(@user)
158
- expect(flash[:notice]).to match(/welcome/)
159
- expect(response).to redirect_to(profile_path)
160
- end
161
-
162
- it "should redirect to login page if user signup needs approval" do
163
- allow(Setting).to receive(:user_signup).and_return(:needs_approval)
164
-
165
- post :create, params: { user: { username: @username, email: @email, password: @password, password_confirmation: @password } }
166
- expect(assigns[:user]).to eq(@user)
167
- expect(flash[:notice]).to match(/approval/)
168
- expect(response).to redirect_to(login_path)
169
- end
170
- end
171
-
172
- describe "with invalid params" do
173
- it "assigns a newly created but unsaved user as @user and renders [new] template" do
174
- login_admin
175
- @user = build(:user, username: "", email: "")
176
- allow(User).to receive(:new).and_return(@user)
177
-
178
- post :create, params: { user: {} }
179
- expect(assigns[:user]).to eq(@user)
180
- expect(response).to render_template("users/new")
181
- end
182
- end
183
- end
184
-
185
114
  # PUT /users/1
186
115
  # PUT /users/1.xml AJAX
187
116
  #----------------------------------------------------------------------------
@@ -312,52 +241,53 @@ describe UsersController do
312
241
  #----------------------------------------------------------------------------
313
242
  describe "responding to PUT change_password" do
314
243
  before(:each) do
315
- login
316
- allow(User).to receive(:find).and_return(current_user)
317
- allow(@current_user_session).to receive(:unauthorized_record=).and_return(current_user)
318
- allow(@current_user_session).to receive(:save).and_return(current_user)
319
- @user = current_user
320
- @new_password = "secret?!"
244
+ @old_password = 'foobar123'
245
+ @user = FactoryBot.create(:user, password: @old_password, password_confirmation: @old_password)
246
+ perform_login(@user)
247
+ @old_encrypted_password = @user.encrypted_password
248
+ @new_password = 'secret?!'
321
249
  end
322
250
 
323
251
  it "should set new user password" do
324
- put :change_password, params: { id: @user.id, current_password: @user.password, user: { password: @new_password, password_confirmation: @new_password } }, xhr: true
325
- expect(assigns[:user]).to eq(current_user)
326
- expect(current_user.password).to eq(@new_password)
327
- expect(current_user.errors).to be_empty
328
- expect(flash[:notice]).not_to eq(nil)
252
+ put :change_password, params: { id: @user.id, current_password: @old_password, user: { password: @new_password, password_confirmation: @new_password } }, xhr: true
253
+ expect(assigns[:user]).to eq(@user)
254
+ expect(assigns[:user].password).to eq('secret?!')
255
+ expect(assigns[:user].errors).to be_empty
256
+ expect(assigns[:user].reload.encrypted_password).to_not eq(@old_encrypted_password) # password change
329
257
  expect(response).to render_template("users/change_password")
330
258
  end
331
259
 
332
- it "should allow to change password if current password is blank" do
333
- @user.password_hash = nil
260
+ it "should not allow to change password if current password is blank" do
261
+ current_user.encrypted_password = nil
334
262
  put :change_password, params: { id: @user.id, current_password: "", user: { password: @new_password, password_confirmation: @new_password } }, xhr: true
335
- expect(current_user.password).to eq(@new_password)
336
- expect(current_user.errors).to be_empty
337
- expect(flash[:notice]).not_to eq(nil)
263
+ expect(assigns[:user].password).to eq(nil)
264
+ expect(assigns[:user].errors.size).to eq(1) # .error_on(:current_password)
265
+ expect(assigns[:user].reload.encrypted_password).to eq(@old_encrypted_password) # password stays the same
338
266
  expect(response).to render_template("users/change_password")
339
267
  end
340
268
 
341
269
  it "should not change user password if password field is blank" do
342
- put :change_password, params: { id: @user.id, current_password: @user.password, user: { password: "", password_confirmation: "" } }, xhr: true
270
+ put :change_password, params: { id: @user.id, current_password: @old_password, user: { password: "", password_confirmation: "" } }, xhr: true
343
271
  expect(assigns[:user]).to eq(current_user)
344
- expect(current_user.password).to eq(@user.password) # password stays the same
345
- expect(current_user.errors).to be_empty # no errors
346
- expect(flash[:notice]).not_to eq(nil)
272
+ expect(assigns[:user].password).to eq(nil)
273
+ expect(assigns[:user].errors).to be_empty # no errors
274
+ expect(assigns[:user].reload.encrypted_password).to eq(@old_encrypted_password) # password stays the same
347
275
  expect(response).to render_template("users/change_password")
348
276
  end
349
277
 
350
278
  it "should require valid current password" do
351
279
  put :change_password, params: { id: @user.id, current_password: "what?!", user: { password: @new_password, password_confirmation: @new_password } }, xhr: true
352
- expect(current_user.password).to eq(@user.password) # password stays the same
353
- expect(current_user.errors.size).to eq(1) # .error_on(:current_password)
280
+ expect(assigns[:user].password).to eq(nil)
281
+ expect(assigns[:user].errors.size).to eq(1) # .error_on(:current_password)
282
+ expect(assigns[:user].reload.encrypted_password).to eq(@old_encrypted_password) # password stays the same
354
283
  expect(response).to render_template("users/change_password")
355
284
  end
356
285
 
357
286
  it "should require new password and password confirmation to match" do
358
- put :change_password, params: { id: @user.id, current_password: @user.password, user: { password: @new_password, password_confirmation: "none" } }, xhr: true
359
- expect(current_user.password).to eq(@user.password) # password stays the same
360
- expect(current_user.errors.size).to eq(1) # .error_on(:current_password)
287
+ put :change_password, params: { id: @user.id, current_password: @old_password, user: { password: @new_password, password_confirmation: "none" } }, xhr: true
288
+ expect(assigns[:user].password).to eq('secret?!')
289
+ expect(assigns[:user].errors.size).to eq(1) # .error_on(:current_password)
290
+ expect(assigns[:user].reload.encrypted_password).to eq(@old_encrypted_password) # password stays the same
361
291
  expect(response).to render_template("users/change_password")
362
292
  end
363
293
  end
@@ -368,14 +298,14 @@ describe UsersController do
368
298
  describe "responding to GET opportunities_overview" do
369
299
  before(:each) do
370
300
  login
371
- @user = @current_user
301
+ @user = current_user
372
302
  @user.update_attributes(first_name: "Apple", last_name: "Boy")
373
303
  end
374
304
 
375
305
  it "should assign @users_with_opportunities" do
376
306
  create(:opportunity, stage: "prospecting", assignee: @user)
377
307
  get :opportunities_overview, xhr: true
378
- expect(assigns[:users_with_opportunities]).to eq([@current_user])
308
+ expect(assigns[:users_with_opportunities]).to eq([@user])
379
309
  end
380
310
 
381
311
  it "@users_with_opportunities should be ordered by name" do
@@ -8,16 +8,16 @@
8
8
  FactoryBot.define do
9
9
  factory :account do
10
10
  user
11
- assigned_to nil
11
+ assigned_to { nil }
12
12
  name { FFaker::Company.name + rand(100).to_s }
13
- access "Public"
13
+ access { "Public" }
14
14
  website { FactoryBot.generate(:website) }
15
15
  email { FFaker::Internet.email }
16
16
  toll_free_phone { FFaker::PhoneNumber.phone_number }
17
17
  phone { FFaker::PhoneNumber.phone_number }
18
18
  fax { FFaker::PhoneNumber.phone_number }
19
19
  background_info { FFaker::Lorem.paragraph[0, 255] }
20
- deleted_at nil
20
+ deleted_at { nil }
21
21
  updated_at { FactoryBot.generate(:time) }
22
22
  created_at { FactoryBot.generate(:time) }
23
23
  end
@@ -25,7 +25,7 @@ FactoryBot.define do
25
25
  factory :account_contact do
26
26
  account
27
27
  contact
28
- deleted_at nil
28
+ deleted_at { nil }
29
29
  updated_at { FactoryBot.generate(:time) }
30
30
  created_at { FactoryBot.generate(:time) }
31
31
  end
@@ -33,7 +33,7 @@ FactoryBot.define do
33
33
  factory :account_opportunity do
34
34
  account
35
35
  opportunity
36
- deleted_at nil
36
+ deleted_at { nil }
37
37
  updated_at { FactoryBot.generate(:time) }
38
38
  created_at { FactoryBot.generate(:time) }
39
39
  end
@@ -9,8 +9,8 @@ FactoryBot.define do
9
9
  factory :campaign do
10
10
  user
11
11
  name { FFaker::Lorem.sentence[0, 64] }
12
- assigned_to nil
13
- access "Public"
12
+ assigned_to { nil }
13
+ access { "Public" }
14
14
  status { %w[planned started completed planned started completed on_hold called_off].sample }
15
15
  budget { rand(500) }
16
16
  target_leads { rand(200) }
@@ -23,7 +23,7 @@ FactoryBot.define do
23
23
  starts_on { FactoryBot.generate(:date) }
24
24
  objectives { FFaker::Lorem.paragraph[0, 255] }
25
25
  background_info { FFaker::Lorem.paragraph[0, 255] }
26
- deleted_at nil
26
+ deleted_at { nil }
27
27
  updated_at { FactoryBot.generate(:time) }
28
28
  created_at { FactoryBot.generate(:time) }
29
29
  end
@@ -9,11 +9,11 @@ FactoryBot.define do
9
9
  factory :contact do
10
10
  user
11
11
  lead
12
- assigned_to nil
13
- reports_to nil
12
+ assigned_to { nil }
13
+ reports_to { nil }
14
14
  first_name { FFaker::Name.first_name }
15
15
  last_name { FFaker::Name.last_name }
16
- access "Public"
16
+ access { "Public" }
17
17
  title { FactoryBot.generate(:title) }
18
18
  department { FFaker::Name.name + " Dept." }
19
19
  source { %w[campaign cold_call conference online referral self web word_of_mouth other].sample }
@@ -26,10 +26,10 @@ FactoryBot.define do
26
26
  facebook { FactoryBot.generate(:website) }
27
27
  linkedin { FactoryBot.generate(:website) }
28
28
  twitter { FactoryBot.generate(:website) }
29
- do_not_call false
30
- born_on "1992-10-10"
29
+ do_not_call { false }
30
+ born_on { "1992-10-10" }
31
31
  background_info { FFaker::Lorem.paragraph[0, 255] }
32
- deleted_at nil
32
+ deleted_at { nil }
33
33
  updated_at { FactoryBot.generate(:time) }
34
34
  created_at { FactoryBot.generate(:time) }
35
35
  end
@@ -37,8 +37,8 @@ FactoryBot.define do
37
37
  factory :contact_opportunity do
38
38
  contact
39
39
  opportunity
40
- role "foo"
41
- deleted_at nil
40
+ role { "foo" }
41
+ deleted_at { nil }
42
42
  updated_at { FactoryBot.generate(:time) }
43
43
  created_at { FactoryBot.generate(:time) }
44
44
  end