fat_free_crm 0.20.0 → 0.21.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 (286) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +170 -0
  3. data/README.md +3 -6
  4. data/app/assets/config/manifest.js +3 -0
  5. data/app/helpers/accounts_helper.rb +2 -0
  6. data/app/helpers/application_helper.rb +22 -3
  7. data/app/helpers/tasks_helper.rb +1 -2
  8. data/app/models/entities/account.rb +1 -1
  9. data/app/models/entities/campaign.rb +1 -1
  10. data/app/models/entities/contact.rb +1 -1
  11. data/app/models/entities/lead.rb +1 -1
  12. data/app/models/entities/opportunity.rb +1 -1
  13. data/app/models/polymorphic/avatar.rb +1 -30
  14. data/app/models/polymorphic/task.rb +2 -0
  15. data/app/views/home/index.xls.builder +1 -0
  16. data/app/views/shared/_address.html.haml +1 -1
  17. data/config/application.rb +13 -0
  18. data/config/environments/development.rb +3 -0
  19. data/config/puma.rb +2 -2
  20. data/config/storage.yml +34 -0
  21. data/db/migrate/20100928030617_drop_openid_tables.rb +2 -1
  22. data/db/migrate/20230526211831_create_active_storage_tables.active_storage.rb +51 -0
  23. data/db/migrate/20230526212613_convert_to_active_storage.rb +91 -0
  24. data/db/schema.rb +65 -35
  25. data/db/seeds/fields.rb +7 -21
  26. data/lib/development_tasks/license.rake +10 -10
  27. data/lib/fat_free_crm/errors.rb +2 -10
  28. data/lib/fat_free_crm/exceptions.rb +1 -0
  29. data/lib/fat_free_crm/fields.rb +4 -5
  30. data/lib/fat_free_crm/gem_dependencies.rb +0 -1
  31. data/lib/fat_free_crm/i18n.rb +1 -1
  32. data/lib/fat_free_crm/version.rb +2 -2
  33. metadata +16 -279
  34. data/.docker/nginx/sites-enabled/ffcrm.conf +0 -8
  35. data/.github/workflows/brakeman-analysis.yml +0 -46
  36. data/.github/workflows/rubocop-analysis.yml +0 -40
  37. data/.github/workflows/ruby.yml +0 -52
  38. data/.gitignore +0 -39
  39. data/.rubocop.yml +0 -73
  40. data/.rubocop_todo.yml +0 -286
  41. data/.teatro.yml +0 -3
  42. data/.travis.yml +0 -60
  43. data/CONTRIBUTORS.md +0 -135
  44. data/Capfile +0 -27
  45. data/Dockerfile +0 -51
  46. data/Gemfile +0 -106
  47. data/Gemfile.lock +0 -529
  48. data/Guardfile +0 -26
  49. data/Procfile +0 -1
  50. data/SECURITY.md +0 -11
  51. data/Vagrantfile +0 -92
  52. data/custom_plan.rb +0 -11
  53. data/docker-compose.yml +0 -27
  54. data/fat_free_crm.gemspec +0 -62
  55. data/lib/tasks/.gitkeep +0 -0
  56. data/lib/tasks/.gitkeep~master +0 -0
  57. data/script/rails +0 -8
  58. data/spec/controllers/admin/groups_controller_spec.rb +0 -11
  59. data/spec/controllers/admin/users_controller_spec.rb +0 -251
  60. data/spec/controllers/applications_controller_spec.rb +0 -43
  61. data/spec/controllers/comments_controller_spec.rb +0 -195
  62. data/spec/controllers/emails_controller_spec.rb +0 -37
  63. data/spec/controllers/entities/accounts_controller_spec.rb +0 -607
  64. data/spec/controllers/entities/campaigns_controller_spec.rb +0 -645
  65. data/spec/controllers/entities/contacts_controller_spec.rb +0 -705
  66. data/spec/controllers/entities/leads_controller_spec.rb +0 -1009
  67. data/spec/controllers/entities/opportunities_controller_spec.rb +0 -904
  68. data/spec/controllers/entities_controller_spec.rb +0 -47
  69. data/spec/controllers/home_controller_spec.rb +0 -235
  70. data/spec/controllers/lists_controller_spec.rb +0 -11
  71. data/spec/controllers/tasks_controller_spec.rb +0 -517
  72. data/spec/controllers/users_controller_spec.rb +0 -375
  73. data/spec/factories/account_factories.rb +0 -40
  74. data/spec/factories/campaign_factories.rb +0 -30
  75. data/spec/factories/contact_factories.rb +0 -45
  76. data/spec/factories/field_factories.rb +0 -40
  77. data/spec/factories/lead_factories.rb +0 -36
  78. data/spec/factories/list_factories.rb +0 -13
  79. data/spec/factories/opportunity_factories.rb +0 -39
  80. data/spec/factories/sequences.rb +0 -32
  81. data/spec/factories/setting_factories.rb +0 -15
  82. data/spec/factories/shared_factories.rb +0 -70
  83. data/spec/factories/subscription_factories.rb +0 -13
  84. data/spec/factories/tag_factories.rb +0 -12
  85. data/spec/factories/task_factories.rb +0 -29
  86. data/spec/factories/user_factories.rb +0 -66
  87. data/spec/features/acceptance_helper.rb +0 -11
  88. data/spec/features/accounts_spec.rb +0 -126
  89. data/spec/features/admin/groups_spec.rb +0 -31
  90. data/spec/features/admin/users_spec.rb +0 -40
  91. data/spec/features/campaigns_spec.rb +0 -104
  92. data/spec/features/contacts_spec.rb +0 -134
  93. data/spec/features/dashboard_spec.rb +0 -67
  94. data/spec/features/devise/sign_in_spec.rb +0 -58
  95. data/spec/features/devise/sign_up_spec.rb +0 -36
  96. data/spec/features/leads_spec.rb +0 -138
  97. data/spec/features/opportunities_overview_spec.rb +0 -88
  98. data/spec/features/opportunities_spec.rb +0 -132
  99. data/spec/features/support/autocomlete_helper.rb +0 -17
  100. data/spec/features/support/browser.rb +0 -28
  101. data/spec/features/support/headless.rb +0 -19
  102. data/spec/features/support/paths.rb +0 -48
  103. data/spec/features/support/selector_helpers.rb +0 -36
  104. data/spec/features/tasks_spec.rb +0 -94
  105. data/spec/fixtures/rails.png +0 -0
  106. data/spec/helpers/accounts_helper_spec.rb +0 -73
  107. data/spec/helpers/admin/field_groups_helper_spec.rb +0 -20
  108. data/spec/helpers/admin/plugins_helper_spec.rb +0 -11
  109. data/spec/helpers/admin/settings_helper_spec.rb +0 -11
  110. data/spec/helpers/admin/users_helper_spec.rb +0 -11
  111. data/spec/helpers/application_helper_spec.rb +0 -86
  112. data/spec/helpers/authentications_helper_spec.rb +0 -16
  113. data/spec/helpers/campaigns_helper_spec.rb +0 -16
  114. data/spec/helpers/comments_helper_spec.rb +0 -16
  115. data/spec/helpers/contacts_helper_spec.rb +0 -16
  116. data/spec/helpers/emails_helper_spec.rb +0 -11
  117. data/spec/helpers/fields_helper_spec.rb +0 -12
  118. data/spec/helpers/groups_helper_spec.rb +0 -21
  119. data/spec/helpers/home_helper_spec.rb +0 -16
  120. data/spec/helpers/leads_helper_spec.rb +0 -16
  121. data/spec/helpers/lists_helper_spec.rb +0 -21
  122. data/spec/helpers/opportunities_helper_spec.rb +0 -16
  123. data/spec/helpers/passwords_helper_spec.rb +0 -16
  124. data/spec/helpers/tasks_helper_spec.rb +0 -20
  125. data/spec/helpers/users_helper_spec.rb +0 -39
  126. data/spec/lib/comment_extensions_spec.rb +0 -42
  127. data/spec/lib/core_ext/string_spec.rb +0 -23
  128. data/spec/lib/errors_spec.rb +0 -32
  129. data/spec/lib/fields_spec.rb +0 -101
  130. data/spec/lib/mail_processor/base_spec.rb +0 -169
  131. data/spec/lib/mail_processor/comment_replies_spec.rb +0 -70
  132. data/spec/lib/mail_processor/dropbox_spec.rb +0 -306
  133. data/spec/lib/mail_processor/sample_emails/dropbox.rb +0 -173
  134. data/spec/lib/permissions_spec.rb +0 -155
  135. data/spec/lib/secret_token_generator_spec.rb +0 -69
  136. data/spec/lib/view_factory_spec.rb +0 -69
  137. data/spec/mailers/devise_mailer_spec.rb +0 -35
  138. data/spec/mailers/subscription_mailer_spec.rb +0 -48
  139. data/spec/mailers/user_mailer_spec.rb +0 -115
  140. data/spec/models/entities/account_contact_spec.rb +0 -34
  141. data/spec/models/entities/account_opportunity_spec.rb +0 -34
  142. data/spec/models/entities/account_spec.rb +0 -206
  143. data/spec/models/entities/campaign_spec.rb +0 -131
  144. data/spec/models/entities/contact_opportunity_spec.rb +0 -34
  145. data/spec/models/entities/contact_spec.rb +0 -314
  146. data/spec/models/entities/lead_spec.rb +0 -102
  147. data/spec/models/entities/opportunity_spec.rb +0 -299
  148. data/spec/models/fields/custom_field_date_pair_spec.rb +0 -92
  149. data/spec/models/fields/custom_field_pair_spec.rb +0 -76
  150. data/spec/models/fields/custom_field_spec.rb +0 -129
  151. data/spec/models/fields/field_group_spec.rb +0 -29
  152. data/spec/models/fields/field_spec.rb +0 -69
  153. data/spec/models/list_spec.rb +0 -19
  154. data/spec/models/observers/entity_observer_spec.rb +0 -74
  155. data/spec/models/polymorphic/address_spec.rb +0 -34
  156. data/spec/models/polymorphic/avatar_spec.rb +0 -46
  157. data/spec/models/polymorphic/comment_spec.rb +0 -45
  158. data/spec/models/polymorphic/email_spec.rb +0 -53
  159. data/spec/models/polymorphic/task_spec.rb +0 -395
  160. data/spec/models/polymorphic/version_spec.rb +0 -241
  161. data/spec/models/setting_spec.rb +0 -77
  162. data/spec/models/users/abilities/user_ability_spec.rb +0 -70
  163. data/spec/models/users/group_spec.rb +0 -11
  164. data/spec/models/users/permission_spec.rb +0 -58
  165. data/spec/models/users/preference_spec.rb +0 -71
  166. data/spec/models/users/user_spec.rb +0 -238
  167. data/spec/routing/accounts_routing_spec.rb +0 -60
  168. data/spec/routing/admin/users_routing_spec.rb +0 -40
  169. data/spec/routing/campaigns_routing_spec.rb +0 -64
  170. data/spec/routing/comments_routing_spec.rb +0 -32
  171. data/spec/routing/contacts_routing_spec.rb +0 -60
  172. data/spec/routing/emails_routing_spec.rb +0 -40
  173. data/spec/routing/leads_routing_spec.rb +0 -88
  174. data/spec/routing/opportunities_routing_spec.rb +0 -64
  175. data/spec/routing/tasks_routing_spec.rb +0 -68
  176. data/spec/routing/users_routing_spec.rb +0 -106
  177. data/spec/shared/controllers.rb +0 -99
  178. data/spec/shared/models.rb +0 -141
  179. data/spec/spec_helper.rb +0 -117
  180. data/spec/support/assert_select.rb +0 -167
  181. data/spec/support/devise_helpers.rb +0 -28
  182. data/spec/support/feature_helpers.rb +0 -32
  183. data/spec/support/macros.rb +0 -49
  184. data/spec/support/mail_processor_mocks.rb +0 -37
  185. data/spec/support/uploaded_file.rb +0 -10
  186. data/spec/views/accounts/_edit.haml_spec.rb +0 -43
  187. data/spec/views/accounts/_new.haml_spec.rb +0 -42
  188. data/spec/views/accounts/create.js.haml_spec.rb +0 -52
  189. data/spec/views/accounts/destroy.js.haml_spec.rb +0 -34
  190. data/spec/views/accounts/edit.js.haml_spec.rb +0 -66
  191. data/spec/views/accounts/index.haml_spec.rb +0 -43
  192. data/spec/views/accounts/index.js.haml_spec.rb +0 -34
  193. data/spec/views/accounts/new.js.haml_spec.rb +0 -44
  194. data/spec/views/accounts/show.haml_spec.rb +0 -38
  195. data/spec/views/accounts/update.js.haml_spec.rb +0 -93
  196. data/spec/views/admin/field_groups/create.js.haml_spec.rb +0 -30
  197. data/spec/views/admin/field_groups/destroy.js.haml_spec.rb +0 -31
  198. data/spec/views/admin/field_groups/edit.js.haml_spec.rb +0 -24
  199. data/spec/views/admin/field_groups/new.js.haml_spec.rb +0 -25
  200. data/spec/views/admin/field_groups/update.js.haml_spec.rb +0 -29
  201. data/spec/views/admin/users/_create.haml_spec.rb +0 -23
  202. data/spec/views/admin/users/create.js.haml_spec.rb +0 -41
  203. data/spec/views/admin/users/destroy.js.haml_spec.rb +0 -47
  204. data/spec/views/admin/users/edit.js.haml_spec.rb +0 -44
  205. data/spec/views/admin/users/index.haml_spec.rb +0 -22
  206. data/spec/views/admin/users/index.js.haml_spec.rb +0 -26
  207. data/spec/views/admin/users/new.js.haml_spec.rb +0 -34
  208. data/spec/views/admin/users/reactivate.js.haml_spec.rb +0 -22
  209. data/spec/views/admin/users/show.haml_spec.rb +0 -18
  210. data/spec/views/admin/users/suspend.js.haml_spec.rb +0 -22
  211. data/spec/views/admin/users/update.js.haml_spec.rb +0 -37
  212. data/spec/views/application/auto_complete.haml_spec.rb +0 -48
  213. data/spec/views/campaigns/_edit.haml_spec.rb +0 -44
  214. data/spec/views/campaigns/_new.haml_spec.rb +0 -41
  215. data/spec/views/campaigns/create.js.haml_spec.rb +0 -49
  216. data/spec/views/campaigns/destroy.js.haml_spec.rb +0 -31
  217. data/spec/views/campaigns/edit.js.haml_spec.rb +0 -66
  218. data/spec/views/campaigns/index.haml_spec.rb +0 -37
  219. data/spec/views/campaigns/index.js.haml_spec.rb +0 -34
  220. data/spec/views/campaigns/new.js.haml_spec.rb +0 -50
  221. data/spec/views/campaigns/show.haml_spec.rb +0 -38
  222. data/spec/views/campaigns/update.js.haml_spec.rb +0 -78
  223. data/spec/views/comments/edit.js.haml_spec.rb +0 -30
  224. data/spec/views/contacts/_edit.haml_spec.rb +0 -73
  225. data/spec/views/contacts/_new.haml_spec.rb +0 -52
  226. data/spec/views/contacts/create.js.haml_spec.rb +0 -65
  227. data/spec/views/contacts/destroy.js.haml_spec.rb +0 -45
  228. data/spec/views/contacts/edit.js.haml_spec.rb +0 -74
  229. data/spec/views/contacts/index.haml_spec.rb +0 -37
  230. data/spec/views/contacts/index.js.html_spec.rb +0 -34
  231. data/spec/views/contacts/new.js.haml_spec.rb +0 -47
  232. data/spec/views/contacts/show.haml_spec.rb +0 -35
  233. data/spec/views/contacts/update.js.haml_spec.rb +0 -128
  234. data/spec/views/home/index.haml_spec.rb +0 -36
  235. data/spec/views/home/index.js.haml_spec.rb +0 -33
  236. data/spec/views/home/options.js.haml_spec.rb +0 -53
  237. data/spec/views/leads/_convert.haml_spec.rb +0 -30
  238. data/spec/views/leads/_edit.haml_spec.rb +0 -47
  239. data/spec/views/leads/_new.haml_spec.rb +0 -45
  240. data/spec/views/leads/_sidebar_show.haml_spec.rb +0 -31
  241. data/spec/views/leads/convert.js.haml_spec.rb +0 -79
  242. data/spec/views/leads/create.js.haml_spec.rb +0 -67
  243. data/spec/views/leads/destroy.js.haml_spec.rb +0 -47
  244. data/spec/views/leads/edit.js.haml_spec.rb +0 -76
  245. data/spec/views/leads/index.haml_spec.rb +0 -37
  246. data/spec/views/leads/index.js.haml_spec.rb +0 -34
  247. data/spec/views/leads/new.js.haml_spec.rb +0 -47
  248. data/spec/views/leads/promote.js.haml_spec.rb +0 -135
  249. data/spec/views/leads/reject.js.haml_spec.rb +0 -45
  250. data/spec/views/leads/show.haml_spec.rb +0 -32
  251. data/spec/views/leads/update.js.haml_spec.rb +0 -118
  252. data/spec/views/opportunities/_edit.haml_spec.rb +0 -70
  253. data/spec/views/opportunities/_new.haml_spec.rb +0 -51
  254. data/spec/views/opportunities/create.js.haml_spec.rb +0 -86
  255. data/spec/views/opportunities/destroy.js.haml_spec.rb +0 -64
  256. data/spec/views/opportunities/edit.js.haml_spec.rb +0 -75
  257. data/spec/views/opportunities/index.haml_spec.rb +0 -38
  258. data/spec/views/opportunities/index.js.haml_spec.rb +0 -35
  259. data/spec/views/opportunities/new.js.haml_spec.rb +0 -54
  260. data/spec/views/opportunities/show.haml_spec.rb +0 -35
  261. data/spec/views/opportunities/update.js.haml_spec.rb +0 -143
  262. data/spec/views/tasks/_edit.haml_spec.rb +0 -50
  263. data/spec/views/tasks/complete.js.haml_spec.rb +0 -67
  264. data/spec/views/tasks/create.js.haml_spec.rb +0 -119
  265. data/spec/views/tasks/destroy.js.haml_spec.rb +0 -57
  266. data/spec/views/tasks/edit.js.haml_spec.rb +0 -76
  267. data/spec/views/tasks/index.haml_spec.rb +0 -46
  268. data/spec/views/tasks/new.js.haml_spec.rb +0 -49
  269. data/spec/views/tasks/uncomplete.js.haml_spec.rb +0 -45
  270. data/spec/views/tasks/update.js.haml_spec.rb +0 -140
  271. data/spec/views/users/avatar.js.haml_spec.rb +0 -35
  272. data/spec/views/users/change_password.js.haml_spec.rb +0 -51
  273. data/spec/views/users/edit.js.haml_spec.rb +0 -35
  274. data/spec/views/users/password.js.haml_spec.rb +0 -36
  275. data/spec/views/users/update.js.haml_spec.rb +0 -46
  276. data/spec/views/users/upload_avatar.js.haml_spec.rb +0 -45
  277. data/vendor/gems/globby-0.1.2/LICENSE.txt +0 -20
  278. data/vendor/gems/globby-0.1.2/README.md +0 -65
  279. data/vendor/gems/globby-0.1.2/Rakefile +0 -9
  280. data/vendor/gems/globby-0.1.2/lib/globby/glob.rb +0 -90
  281. data/vendor/gems/globby-0.1.2/lib/globby/globject.rb +0 -18
  282. data/vendor/gems/globby-0.1.2/lib/globby/result.rb +0 -20
  283. data/vendor/gems/globby-0.1.2/lib/globby.rb +0 -47
  284. data/vendor/gems/globby-0.1.2/spec/gitignore_spec.rb +0 -109
  285. data/vendor/gems/globby-0.1.2/spec/globby_spec.rb +0 -93
  286. data/zeus.json +0 -22
@@ -1,645 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- # Copyright (c) 2008-2013 Michael Dvorkin and contributors.
4
- #
5
- # Fat Free CRM is freely distributable under the terms of MIT license.
6
- # See MIT-LICENSE file or http://www.opensource.org/licenses/mit-license.php
7
- #------------------------------------------------------------------------------
8
- require File.expand_path(File.dirname(__FILE__) + '/../../spec_helper')
9
-
10
- describe CampaignsController do
11
- def get_data_for_sidebar
12
- @status = Setting.campaign_status.dup
13
- end
14
-
15
- before(:each) do
16
- login
17
- set_current_tab(:campaigns)
18
- end
19
-
20
- # GET /campaigns
21
- # GET /campaigns.xml
22
- #----------------------------------------------------------------------------
23
- describe "responding to GET index" do
24
- before(:each) do
25
- get_data_for_sidebar
26
- end
27
-
28
- it "should expose all campaigns as @campaigns and render [index] template" do
29
- @campaigns = [create(:campaign, user: current_user)]
30
-
31
- get :index
32
- expect(assigns[:campaigns]).to eq(@campaigns)
33
- expect(response).to render_template("campaigns/index")
34
- end
35
-
36
- it "should collect the data for the opportunities sidebar" do
37
- @campaigns = [create(:campaign, user: current_user)]
38
-
39
- get :index
40
- expect(assigns[:campaign_status_total].keys.map(&:to_sym) - (@status << :all << :other)).to eq([])
41
- end
42
-
43
- it "should filter out campaigns by status" do
44
- controller.session[:campaigns_filter] = "planned,started"
45
- @campaigns = [
46
- create(:campaign, user: current_user, status: "started"),
47
- create(:campaign, user: current_user, status: "planned")
48
- ]
49
-
50
- # This one should be filtered out.
51
- create(:campaign, user: current_user, status: "completed")
52
-
53
- get :index
54
- # Note: can't compare campaigns directly because of BigDecimal objects.
55
- expect(assigns[:campaigns].size).to eq(2)
56
- expect(assigns[:campaigns].map(&:status).sort).to eq(%w[planned started])
57
- end
58
-
59
- it "should perform lookup using query string" do
60
- @first = create(:campaign, user: current_user, name: "Hello, world!")
61
- @second = create(:campaign, user: current_user, name: "Hello again")
62
-
63
- get :index, params: { query: "again" }
64
- expect(assigns[:campaigns]).to eq([@second])
65
- expect(assigns[:current_query]).to eq("again")
66
- expect(session[:campaigns_current_query]).to eq("again")
67
- end
68
-
69
- describe "AJAX pagination" do
70
- it "should pick up page number from params" do
71
- @campaigns = [create(:campaign, user: current_user)]
72
- get :index, params: { page: 42 }, xhr: true
73
-
74
- expect(assigns[:current_page].to_i).to eq(42)
75
- expect(assigns[:campaigns]).to eq([]) # page #42 should be empty if there's only one campaign ;-)
76
- expect(session[:campaigns_current_page].to_i).to eq(42)
77
- expect(response).to render_template("campaigns/index")
78
- end
79
-
80
- it "should pick up saved page number from session" do
81
- session[:campaigns_current_page] = 42
82
- @campaigns = [create(:campaign, user: current_user)]
83
- get :index, xhr: true
84
-
85
- expect(assigns[:current_page]).to eq(42)
86
- expect(assigns[:campaigns]).to eq([])
87
- expect(response).to render_template("campaigns/index")
88
- end
89
-
90
- it "should reset current_page when query is altered" do
91
- session[:campaigns_current_page] = 42
92
- session[:campaigns_current_query] = "bill"
93
- @campaigns = [create(:campaign, user: current_user)]
94
- get :index, xhr: true
95
-
96
- expect(assigns[:current_page]).to eq(1)
97
- expect(assigns[:campaigns]).to eq(@campaigns)
98
- expect(response).to render_template("campaigns/index")
99
- end
100
- end
101
-
102
- describe "with mime type of JSON" do
103
- it "should render all campaigns as JSON" do
104
- expect(@controller).to receive(:get_campaigns).and_return(@campaigns = [])
105
- expect(@campaigns).to receive(:to_json).and_return("generated JSON")
106
-
107
- request.env["HTTP_ACCEPT"] = "application/json"
108
- get :index
109
- expect(response.body).to eq("generated JSON")
110
- end
111
- end
112
-
113
- describe "with mime type of XML" do
114
- it "should render all campaigns as xml" do
115
- expect(@controller).to receive(:get_campaigns).and_return(@campaigns = [])
116
- expect(@campaigns).to receive(:to_xml).and_return("generated XML")
117
-
118
- request.env["HTTP_ACCEPT"] = "application/xml"
119
- get :index
120
- expect(response.body).to eq("generated XML")
121
- end
122
- end
123
- end
124
-
125
- # GET /campaigns/1
126
- # GET /campaigns/1.xml HTML
127
- #----------------------------------------------------------------------------
128
- describe "responding to GET show" do
129
- describe "with mime type of HTML" do
130
- before(:each) do
131
- @campaign = create(:campaign, id: 42, user: current_user)
132
- @stage = Setting.unroll(:opportunity_stage)
133
- @comment = Comment.new
134
- end
135
-
136
- it "should expose the requested campaign as @campaign and render [show] template" do
137
- get :show, params: { id: 42 }
138
- expect(assigns[:campaign]).to eq(@campaign)
139
- expect(assigns[:stage]).to eq(@stage)
140
- expect(assigns[:comment].attributes).to eq(@comment.attributes)
141
- expect(response).to render_template("campaigns/show")
142
- end
143
-
144
- it "should update an activity when viewing the campaign" do
145
- get :show, params: { id: @campaign.id }
146
- expect(@campaign.versions.last.event).to eq('view')
147
- end
148
- end
149
-
150
- describe "with mime type of JSON" do
151
- it "should render the requested campaign as JSON" do
152
- @campaign = create(:campaign, id: 42, user: current_user)
153
- expect(Campaign).to receive(:find).and_return(@campaign)
154
- expect(@campaign).to receive(:to_json).and_return("generated JSON")
155
-
156
- request.env["HTTP_ACCEPT"] = "application/json"
157
- get :show, params: { id: 42 }
158
- expect(response.body).to eq("generated JSON")
159
- end
160
- end
161
-
162
- describe "with mime type of XML" do
163
- it "should render the requested campaign as XML" do
164
- @campaign = create(:campaign, id: 42, user: current_user)
165
- expect(Campaign).to receive(:find).and_return(@campaign)
166
- expect(@campaign).to receive(:to_xml).and_return("generated XML")
167
-
168
- request.env["HTTP_ACCEPT"] = "application/xml"
169
- get :show, params: { id: 42 }
170
- expect(response.body).to eq("generated XML")
171
- end
172
- end
173
-
174
- describe "campaign got deleted or otherwise unavailable" do
175
- it "should redirect to campaign index if the campaign got deleted" do
176
- @campaign = create(:campaign, user: current_user)
177
- @campaign.destroy
178
-
179
- get :show, params: { id: @campaign.id }
180
- expect(flash[:warning]).not_to eq(nil)
181
- expect(response).to redirect_to(campaigns_path)
182
- end
183
-
184
- it "should redirect to campaign index if the campaign is protected" do
185
- @campaign = create(:campaign, user: create(:user), access: "Private")
186
-
187
- get :show, params: { id: @campaign.id }
188
- expect(flash[:warning]).not_to eq(nil)
189
- expect(response).to redirect_to(campaigns_path)
190
- end
191
-
192
- it "should return 404 (Not Found) JSON error" do
193
- @campaign = create(:campaign, user: current_user)
194
- @campaign.destroy
195
- request.env["HTTP_ACCEPT"] = "application/json"
196
-
197
- get :show, params: { id: @campaign.id }
198
- expect(response.code).to eq("404") # :not_found
199
- end
200
-
201
- it "should return 404 (Not Found) XML error" do
202
- @campaign = create(:campaign, user: current_user)
203
- @campaign.destroy
204
- request.env["HTTP_ACCEPT"] = "application/xml"
205
-
206
- get :show, params: { id: @campaign.id }
207
- expect(response.code).to eq("404") # :not_found
208
- end
209
- end
210
- end
211
-
212
- # GET /campaigns/new
213
- # GET /campaigns/new.xml AJAX
214
- #----------------------------------------------------------------------------
215
- describe "responding to GET new" do
216
- it "should expose a new campaign as @campaign" do
217
- @campaign = Campaign.new(user: current_user,
218
- access: Setting.default_access)
219
- get :new, xhr: true
220
- expect(assigns[:campaign].attributes).to eq(@campaign.attributes)
221
- expect(response).to render_template("campaigns/new")
222
- end
223
-
224
- it "should create related object when necessary" do
225
- @lead = create(:lead, id: 42)
226
-
227
- get :new, params: { related: "lead_42" }, xhr: true
228
- expect(assigns[:lead]).to eq(@lead)
229
- end
230
- end
231
-
232
- # GET /campaigns/1/edit AJAX
233
- #----------------------------------------------------------------------------
234
- describe "responding to GET edit" do
235
- it "should expose the requested campaign as @campaign and render [edit] template" do
236
- @campaign = create(:campaign, id: 42, user: current_user)
237
-
238
- get :edit, params: { id: 42 }, xhr: true
239
- expect(assigns[:campaign]).to eq(@campaign)
240
- expect(response).to render_template("campaigns/edit")
241
- end
242
-
243
- it "should find previous campaign as necessary" do
244
- @campaign = create(:campaign, id: 42)
245
- @previous = create(:campaign, id: 99)
246
-
247
- get :edit, params: { id: 42, previous: 99 }, xhr: true
248
- expect(assigns[:campaign]).to eq(@campaign)
249
- expect(assigns[:previous]).to eq(@previous)
250
- end
251
-
252
- describe "(campaign got deleted or is otherwise unavailable)" do
253
- it "should reload current page with the flash message if the campaign got deleted" do
254
- @campaign = create(:campaign, user: current_user)
255
- @campaign.destroy
256
-
257
- get :edit, params: { id: @campaign.id }, xhr: true
258
- expect(flash[:warning]).not_to eq(nil)
259
- expect(response.body).to eq("window.location.reload();")
260
- end
261
-
262
- it "should reload current page with the flash message if the campaign is protected" do
263
- @private = create(:campaign, user: create(:user), access: "Private")
264
-
265
- get :edit, params: { id: @private.id }, xhr: true
266
- expect(flash[:warning]).not_to eq(nil)
267
- expect(response.body).to eq("window.location.reload();")
268
- end
269
- end
270
-
271
- describe "(previous campaign got deleted or is otherwise unavailable)" do
272
- before(:each) do
273
- @campaign = create(:campaign, user: current_user)
274
- @previous = create(:campaign, user: create(:user))
275
- end
276
-
277
- it "should notify the view if previous campaign got deleted" do
278
- @previous.destroy
279
-
280
- get :edit, params: { id: @campaign.id, previous: @previous.id }, xhr: true
281
- expect(flash[:warning]).to eq(nil) # no warning, just silently remove the div
282
- expect(assigns[:previous]).to eq(@previous.id)
283
- expect(response).to render_template("campaigns/edit")
284
- end
285
-
286
- it "should notify the view if previous campaign got protected" do
287
- @previous.update_attribute(:access, "Private")
288
-
289
- get :edit, params: { id: @campaign.id, previous: @previous.id }, xhr: true
290
- expect(flash[:warning]).to eq(nil)
291
- expect(assigns[:previous]).to eq(@previous.id)
292
- expect(response).to render_template("campaigns/edit")
293
- end
294
- end
295
- end
296
-
297
- # POST /campaigns
298
- # POST /campaigns.xml AJAX
299
- #----------------------------------------------------------------------------
300
- describe "responding to POST create" do
301
- describe "with valid params" do
302
- it "should expose a newly created campaign as @campaign and render [create] template" do
303
- @campaign = build(:campaign, name: "Hello", user: current_user)
304
- allow(Campaign).to receive(:new).and_return(@campaign)
305
-
306
- post :create, params: { campaign: { name: "Hello" } }, xhr: true
307
- expect(assigns(:campaign)).to eq(@campaign)
308
- expect(response).to render_template("campaigns/create")
309
- end
310
-
311
- it "should get data to update campaign sidebar" do
312
- @campaign = build(:campaign, name: "Hello", user: current_user)
313
- allow(Campaign).to receive(:new).and_return(@campaign)
314
-
315
- post :create, params: { campaign: { name: "Hello" } }, xhr: true
316
- expect(assigns[:campaign_status_total]).to be_instance_of(HashWithIndifferentAccess)
317
- end
318
-
319
- it "should reload campaigns to update pagination" do
320
- @campaign = build(:campaign, user: current_user)
321
- allow(Campaign).to receive(:new).and_return(@campaign)
322
-
323
- post :create, params: { campaign: { name: "Hello" } }, xhr: true
324
- expect(assigns[:campaigns]).to eq([@campaign])
325
- end
326
-
327
- it "should add a new comment to the newly created campaign when specified" do
328
- @campaign = build(:campaign, name: "Hello world", user: current_user)
329
- allow(Campaign).to receive(:new).and_return(@campaign)
330
-
331
- post :create, params: { campaign: { name: "Hello world" }, comment_body: "Awesome comment is awesome" }, xhr: true
332
- expect(@campaign.reload.comments.map(&:comment)).to include("Awesome comment is awesome")
333
- end
334
- end
335
-
336
- describe "with invalid params" do
337
- it "should expose a newly created but unsaved campaign as @campaign and still render [create] template" do
338
- @campaign = build(:campaign, id: nil, name: nil, user: current_user)
339
- allow(Campaign).to receive(:new).and_return(@campaign)
340
-
341
- post :create, params: { campaign: {} }, xhr: true
342
- expect(assigns(:campaign)).to eq(@campaign)
343
- expect(response).to render_template("campaigns/create")
344
- end
345
- end
346
- end
347
-
348
- # PUT /campaigns/1
349
- # PUT /campaigns/1.xml AJAX
350
- #----------------------------------------------------------------------------
351
- describe "responding to PUT update" do
352
- describe "with valid params" do
353
- it "should update the requested campaign and render [update] template" do
354
- @campaign = create(:campaign, id: 42, name: "Bye")
355
-
356
- put :update, params: { id: 42, campaign: { name: "Hello" } }, xhr: true
357
- expect(@campaign.reload.name).to eq("Hello")
358
- expect(assigns(:campaign)).to eq(@campaign)
359
- expect(response).to render_template("campaigns/update")
360
- end
361
-
362
- it "should get data for campaigns sidebar when called from Campaigns index" do
363
- @campaign = create(:campaign, id: 42)
364
- request.env["HTTP_REFERER"] = "http://localhost/campaigns"
365
-
366
- put :update, params: { id: 42, campaign: { name: "Hello" } }, xhr: true
367
- expect(assigns(:campaign)).to eq(@campaign)
368
- expect(assigns[:campaign_status_total]).to be_instance_of(HashWithIndifferentAccess)
369
- end
370
-
371
- it "should update campaign permissions when sharing with specific users" do
372
- @campaign = create(:campaign, id: 42, access: "Public")
373
- he = create(:user, id: 7)
374
- she = create(:user, id: 8)
375
-
376
- put :update, params: { id: 42, campaign: { name: "Hello", access: "Shared", user_ids: %w[7 8] } }, xhr: true
377
- expect(assigns[:campaign].access).to eq("Shared")
378
- expect(assigns[:campaign].user_ids.sort).to eq([he.id, she.id])
379
- end
380
-
381
- describe "campaign got deleted or otherwise unavailable" do
382
- it "should reload current page with the flash message if the campaign got deleted" do
383
- @campaign = create(:campaign, user: current_user)
384
- @campaign.destroy
385
-
386
- put :update, params: { id: @campaign.id }, xhr: true
387
- expect(flash[:warning]).not_to eq(nil)
388
- expect(response.body).to eq("window.location.reload();")
389
- end
390
-
391
- it "should reload current page with the flash message if the campaign is protected" do
392
- @private = create(:campaign, user: create(:user), access: "Private")
393
-
394
- put :update, params: { id: @private.id }, xhr: true
395
- expect(flash[:warning]).not_to eq(nil)
396
- expect(response.body).to eq("window.location.reload();")
397
- end
398
- end
399
- end
400
-
401
- describe "with invalid params" do
402
- it "should not update the requested campaign, but still expose it as @campaign and still render [update] template" do
403
- @campaign = create(:campaign, id: 42, name: "Hello", user: current_user)
404
-
405
- put :update, params: { id: 42, campaign: { name: nil } }, xhr: true
406
- expect(@campaign.reload.name).to eq("Hello")
407
- expect(assigns(:campaign)).to eq(@campaign)
408
- expect(response).to render_template("campaigns/update")
409
- end
410
- end
411
- end
412
-
413
- # DELETE /campaigns/1
414
- # DELETE /campaigns/1.xml AJAX
415
- #----------------------------------------------------------------------------
416
- describe "responding to DELETE destroy" do
417
- before(:each) do
418
- @campaign = create(:campaign, user: current_user)
419
- end
420
-
421
- describe "AJAX request" do
422
- it "should destroy the requested campaign and render [destroy] template" do
423
- @another_campaign = create(:campaign, user: current_user)
424
- delete :destroy, params: { id: @campaign.id }, xhr: true
425
-
426
- expect(assigns[:campaigns]).to eq([@another_campaign])
427
- expect { Campaign.find(@campaign.id) }.to raise_error(ActiveRecord::RecordNotFound)
428
- expect(response).to render_template("campaigns/destroy")
429
- end
430
-
431
- it "should get data for campaigns sidebar" do
432
- delete :destroy, params: { id: @campaign.id }, xhr: true
433
-
434
- expect(assigns[:campaign_status_total]).to be_instance_of(HashWithIndifferentAccess)
435
- end
436
-
437
- it "should try previous page and render index action if current page has no campaigns" do
438
- session[:campaigns_current_page] = 42
439
-
440
- delete :destroy, params: { id: @campaign.id }, xhr: true
441
- expect(session[:campaigns_current_page]).to eq(41)
442
- expect(response).to render_template("campaigns/index")
443
- end
444
-
445
- it "should render index action when deleting last campaign" do
446
- session[:campaigns_current_page] = 1
447
-
448
- delete :destroy, params: { id: @campaign.id }, xhr: true
449
- expect(session[:campaigns_current_page]).to eq(1)
450
- expect(response).to render_template("campaigns/index")
451
- end
452
-
453
- describe "campaign got deleted or otherwise unavailable" do
454
- it "should reload current page with the flash message if the campaign got deleted" do
455
- @campaign = create(:campaign, user: current_user)
456
- @campaign.destroy
457
-
458
- delete :destroy, params: { id: @campaign.id }, xhr: true
459
- expect(flash[:warning]).not_to eq(nil)
460
- expect(response.body).to eq("window.location.reload();")
461
- end
462
-
463
- it "should reload current page with the flash message if the campaign is protected" do
464
- @private = create(:campaign, user: create(:user), access: "Private")
465
-
466
- delete :destroy, params: { id: @private.id }, xhr: true
467
- expect(flash[:warning]).not_to eq(nil)
468
- expect(response.body).to eq("window.location.reload();")
469
- end
470
- end
471
- end
472
-
473
- describe "HTML request" do
474
- it "should redirect to Campaigns index when a campaign gets deleted from its landing page" do
475
- delete :destroy, params: { id: @campaign.id }
476
-
477
- expect(flash[:notice]).not_to eq(nil)
478
- expect(response).to redirect_to(campaigns_path)
479
- end
480
-
481
- it "should redirect to campaign index with the flash message is the campaign got deleted" do
482
- @campaign = create(:campaign, user: current_user)
483
- @campaign.destroy
484
-
485
- delete :destroy, params: { id: @campaign.id }
486
- expect(flash[:warning]).not_to eq(nil)
487
- expect(response).to redirect_to(campaigns_path)
488
- end
489
-
490
- it "should redirect to campaign index with the flash message if the campaign is protected" do
491
- @private = create(:campaign, user: create(:user), access: "Private")
492
-
493
- delete :destroy, params: { id: @private.id }
494
- expect(flash[:warning]).not_to eq(nil)
495
- expect(response).to redirect_to(campaigns_path)
496
- end
497
- end
498
- end
499
-
500
- # PUT /campaigns/1/attach
501
- # PUT /campaigns/1/attach.xml AJAX
502
- #----------------------------------------------------------------------------
503
- describe "responding to PUT attach" do
504
- describe "tasks" do
505
- before do
506
- @model = create(:campaign)
507
- @attachment = create(:task, asset: nil)
508
- end
509
- it_should_behave_like("attach")
510
- end
511
-
512
- describe "leads" do
513
- before do
514
- @model = create(:campaign)
515
- @attachment = create(:lead, campaign: nil)
516
- end
517
- it_should_behave_like("attach")
518
- end
519
-
520
- describe "opportunities" do
521
- before do
522
- @model = create(:campaign)
523
- @attachment = create(:opportunity, campaign: nil)
524
- end
525
- it_should_behave_like("attach")
526
- end
527
- end
528
-
529
- # PUT /campaigns/1/attach
530
- # PUT /campaigns/1/attach.xml AJAX
531
- #----------------------------------------------------------------------------
532
- describe "responding to PUT attach" do
533
- describe "tasks" do
534
- before do
535
- @model = create(:campaign)
536
- @attachment = create(:task, asset: nil)
537
- end
538
- it_should_behave_like("attach")
539
- end
540
-
541
- describe "leads" do
542
- before do
543
- @model = create(:campaign)
544
- @attachment = create(:lead, campaign: nil)
545
- end
546
- it_should_behave_like("attach")
547
- end
548
-
549
- describe "opportunities" do
550
- before do
551
- @model = create(:campaign)
552
- @attachment = create(:opportunity, campaign: nil)
553
- end
554
- it_should_behave_like("attach")
555
- end
556
- end
557
-
558
- # POST /campaigns/1/discard
559
- # POST /campaigns/1/discard.xml AJAX
560
- #----------------------------------------------------------------------------
561
- describe "responding to POST discard" do
562
- describe "tasks" do
563
- before do
564
- @model = create(:campaign)
565
- @attachment = create(:task, asset: @model)
566
- end
567
- it_should_behave_like("discard")
568
- end
569
-
570
- describe "leads" do
571
- before do
572
- @attachment = create(:lead)
573
- @model = create(:campaign)
574
- @model.leads << @attachment
575
- end
576
- it_should_behave_like("discard")
577
- end
578
-
579
- describe "opportunities" do
580
- before do
581
- @attachment = create(:opportunity)
582
- @model = create(:campaign)
583
- @model.opportunities << @attachment
584
- end
585
- it_should_behave_like("discard")
586
- end
587
- end
588
-
589
- # POST /campaigns/auto_complete/query AJAX
590
- #----------------------------------------------------------------------------
591
- describe "responding to POST auto_complete" do
592
- before(:each) do
593
- @auto_complete_matches = [create(:campaign, name: "Hello World", user: current_user)]
594
- end
595
-
596
- it_should_behave_like("auto complete")
597
- end
598
-
599
- # GET /campaigns/redraw AJAX
600
- #----------------------------------------------------------------------------
601
- describe "responding to GET redraw" do
602
- it "should save user selected campaign preference" do
603
- get :redraw, params: { per_page: 42, view: "brief", sort_by: "name" }, xhr: true
604
- expect(current_user.preference[:campaigns_per_page]).to eq(42)
605
- expect(current_user.preference[:campaigns_index_view]).to eq("brief")
606
- expect(current_user.preference[:campaigns_sort_by]).to eq("campaigns.name ASC")
607
- end
608
-
609
- it "should reset current page to 1" do
610
- get :redraw, params: { per_page: 42, view: "brief", sort_by: "name" }, xhr: true
611
- expect(session[:campaigns_current_page]).to eq(1)
612
- end
613
-
614
- it "should select @campaigns and render [index] template" do
615
- @campaigns = [
616
- create(:campaign, name: "A", user: current_user),
617
- create(:campaign, name: "B", user: current_user)
618
- ]
619
-
620
- get :redraw, params: { per_page: 1, sort_by: "name" }, xhr: true
621
- expect(assigns(:campaigns)).to eq([@campaigns.first])
622
- expect(response).to render_template("campaigns/index")
623
- end
624
- end
625
-
626
- # POST /campaigns/filter AJAX
627
- #----------------------------------------------------------------------------
628
- describe "responding to POST filter" do
629
- it "should expose filtered campaigns as @campaigns and render [index] template" do
630
- session[:campaigns_filter] = "planned,started"
631
- @campaigns = [create(:campaign, status: "completed", user: current_user)]
632
-
633
- post :filter, params: { status: "completed" }, xhr: true
634
- expect(assigns(:campaigns)).to eq(@campaigns)
635
- expect(response).to render_template("campaigns/index")
636
- end
637
-
638
- it "should reset current page to 1" do
639
- @campaigns = []
640
- post :filter, params: { status: "completed" }, xhr: true
641
-
642
- expect(session[:campaigns_current_page]).to eq(1)
643
- end
644
- end
645
- end