fat_free_crm 0.20.1 → 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 +1 -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 +3 -3
  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
data/fat_free_crm.gemspec DELETED
@@ -1,62 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- $LOAD_PATH.push File.expand_path('vendor/gems/globby-0.1.2/lib', __dir__)
4
- require 'globby'
5
- rules = File.read("#{File.expand_path(__dir__)}/.gitignore").split("\n")
6
- rules << '.git'
7
- files = Globby.reject(rules)
8
-
9
- $LOAD_PATH.push File.expand_path('lib', __dir__)
10
- require 'fat_free_crm/version'
11
-
12
- Gem::Specification.new do |gem|
13
- gem.name = 'fat_free_crm'
14
- gem.authors = ['Michael Dvorkin', 'Stephen Kenworthy', "Daniel O'Connor"]
15
- gem.summary = 'Fat Free CRM'
16
- gem.description = 'An open source, Ruby on Rails customer relationship management platform'
17
- gem.homepage = 'http://fatfreecrm.com'
18
- gem.email = ['mike@fatfreecrm.com', 'steveyken@gmail.com', 'daniel.oconnor@gmail.com']
19
- gem.files = files
20
- gem.version = FatFreeCRM::VERSION::STRING
21
- gem.required_ruby_version = '>= 2.4.0'
22
- gem.license = 'MIT'
23
-
24
- gem.add_dependency 'rails', '~> 6.0.0'
25
- gem.add_dependency 'rails-i18n'
26
- gem.add_dependency 'rails-observers'
27
- gem.add_dependency 'activemodel-serializers-xml'
28
- gem.add_dependency 'sprockets-rails', '>= 3.0.0'
29
- gem.add_dependency 'responders', '~> 3.0'
30
- gem.add_dependency 'jquery-rails'
31
- gem.add_dependency 'jquery-migrate-rails'
32
- gem.add_dependency 'jquery-ui-rails'
33
- gem.add_dependency 'select2-rails'
34
- gem.add_dependency 'simple_form'
35
- gem.add_dependency 'will_paginate'
36
- gem.add_dependency 'paperclip'
37
- gem.add_dependency 'paper_trail', '~> 12.0.0'
38
- gem.add_dependency 'devise', '~> 4.6'
39
- gem.add_dependency 'devise-encryptable', '~> 0.2.0'
40
- gem.add_dependency 'acts_as_commentable', '~> 6.0.0'
41
- gem.add_dependency 'acts-as-taggable-on', '>= 3.4.3'
42
- gem.add_dependency 'dynamic_form'
43
- gem.add_dependency 'haml'
44
- gem.add_dependency 'sass'
45
- gem.add_dependency 'acts_as_list'
46
- gem.add_dependency 'ffaker', '>= 2'
47
- gem.add_dependency 'cancancan', '~> 3.0.0'
48
- gem.add_dependency 'font-awesome-rails'
49
- gem.add_dependency 'premailer'
50
- gem.add_dependency 'nokogiri'
51
- gem.add_dependency 'responds_to_parent'
52
- gem.add_dependency 'rails3-jquery-autocomplete'
53
- gem.add_dependency 'thor'
54
- gem.add_dependency 'rails_autolink'
55
- gem.add_dependency 'coffee-script-source', '~> 1.8', '>= 1.8.0' # pegged until https://github.com/jashkenas/coffeescript/issues/3829 is resolved
56
- gem.add_dependency 'country_select'
57
-
58
- # FatFreeCRM has released it's own versions of the following gems:
59
- #-----------------------------------------------------------------
60
- gem.add_dependency 'ransack', '>= 1.6.2'
61
- gem.add_dependency 'email_reply_parser_ffcrm'
62
- end
data/lib/tasks/.gitkeep DELETED
File without changes
File without changes
data/script/rails DELETED
@@ -1,8 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # frozen_string_literal: true
3
-
4
- # This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application.
5
-
6
- APP_PATH = File.expand_path('../config/application', __dir__)
7
- require File.expand_path('../config/boot', __dir__)
8
- require 'rails/commands'
@@ -1,11 +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 Admin::GroupsController do
11
- end
@@ -1,251 +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 Admin::UsersController do
11
- before(:each) do
12
- login_admin
13
- set_current_tab(:users)
14
- end
15
-
16
- # GET /admin/users
17
- # GET /admin/users.xml HTML
18
- #----------------------------------------------------------------------------
19
- describe "GET index" do
20
- it "assigns all users as @users and renders [index] template" do
21
- @users = [current_user, create(:user)]
22
-
23
- get :index
24
- expect(assigns[:users].first).to eq(@users.last) # get_users() sorts by id DESC
25
- expect(assigns[:users].last).to eq(@users.first)
26
- expect(response).to render_template("admin/users/index")
27
- end
28
-
29
- it "performs lookup using query string" do
30
- @amy = create(:user, username: "amy_anderson")
31
- @bob = create(:user, username: "bob_builder")
32
-
33
- get :index, params: { query: "amy_anderson" }
34
- expect(assigns[:users]).to eq([@amy])
35
- expect(assigns[:current_query]).to eq("amy_anderson")
36
- expect(session[:users_current_query]).to eq("amy_anderson")
37
- end
38
- end
39
-
40
- # GET /admin/users/1
41
- # GET /admin/users/1.xml
42
- #----------------------------------------------------------------------------
43
- describe "GET show" do
44
- it "assigns the requested user as @user and renders [show] template" do
45
- @user = create(:user)
46
-
47
- get :show, params: { id: @user.id }
48
- expect(assigns[:user]).to eq(@user)
49
- expect(response).to render_template("admin/users/show")
50
- end
51
- end
52
-
53
- # GET /admin/users/1/edit AJAX
54
- #----------------------------------------------------------------------------
55
- describe "GET edit" do
56
- it "assigns the requested user as @user and renders [edit] template" do
57
- @user = create(:user)
58
-
59
- get :edit, params: { id: @user.id }, xhr: true
60
- expect(assigns[:user]).to eq(@user)
61
- expect(assigns[:previous]).to eq(nil)
62
- expect(response).to render_template("admin/users/edit")
63
- end
64
-
65
- it "assigns the previous user as @previous when necessary" do
66
- @user = create(:user)
67
- @previous = create(:user)
68
-
69
- get :edit, params: { id: @user.id, previous: @previous.id }, xhr: true
70
- expect(assigns[:previous]).to eq(@previous)
71
- end
72
-
73
- it "reloads current page with the flash message if user got deleted" do
74
- @user = create(:user)
75
- @user.destroy
76
-
77
- get :edit, params: { id: @user.id }, xhr: true
78
- expect(flash[:warning]).not_to eq(nil)
79
- expect(response.body).to eq("window.location.reload();")
80
- end
81
-
82
- it "notifies the view if previous user got deleted" do
83
- @user = create(:user)
84
- @previous = create(:user)
85
- @previous.destroy
86
-
87
- get :edit, params: { id: @user.id, previous: @previous.id }, xhr: true
88
- expect(flash[:warning]).to eq(nil) # no warning, just silently remove the div
89
- expect(assigns[:previous]).to eq(@previous.id)
90
- expect(response).to render_template("admin/users/edit")
91
- end
92
- end
93
-
94
- # PUT /admin/users/1
95
- # PUT /admin/users/1.xml AJAX
96
- #----------------------------------------------------------------------------
97
- describe "PUT update" do
98
- describe "with valid params" do
99
- it "updates the requested user, assigns it to @user, and renders [update] template" do
100
- @user = create(:user, username: "flip", email: "flip@example.com")
101
-
102
- put :update, params: { id: @user.id, user: { username: "flop", email: "flop@example.com" } }, xhr: true
103
- expect(assigns[:user]).to eq(@user.reload)
104
- expect(assigns[:user].username).to eq("flop")
105
- expect(response).to render_template("admin/users/update")
106
- end
107
-
108
- it "reloads current page is the user got deleted" do
109
- @user = create(:user)
110
- @user.destroy
111
-
112
- put :update, params: { id: @user.id, user: { username: "flop", email: "flop@example.com" } }, xhr: true
113
- expect(flash[:warning]).not_to eq(nil)
114
- expect(response.body).to eq("window.location.reload();")
115
- end
116
-
117
- it "assigns admin rights when requested so" do
118
- @user = create(:user, admin: false)
119
- put :update, params: { id: @user.id, user: { admin: "1", username: @user.username, email: @user.email } }, xhr: true
120
- expect(assigns[:user]).to eq(@user.reload)
121
- expect(assigns[:user].admin).to eq(true)
122
- expect(response).to render_template("admin/users/update")
123
- end
124
-
125
- it "revokes admin rights when requested so" do
126
- @user = create(:user, admin: true)
127
- put :update, params: { id: @user.id, user: { admin: "0", username: @user.username, email: @user.email } }, xhr: true
128
- expect(assigns[:user]).to eq(@user.reload)
129
- expect(assigns[:user].admin).to eq(false)
130
- expect(response).to render_template("admin/users/update")
131
- end
132
- end
133
-
134
- describe "with invalid params" do
135
- it "doesn't update the requested user, but assigns it to @user and renders [update] template" do
136
- @user = create(:user, username: "flip", email: "flip@example.com")
137
-
138
- put :update, params: { id: @user.id, user: {} }, xhr: true
139
- expect(assigns[:user]).to eq(@user.reload)
140
- expect(assigns[:user].username).to eq("flip")
141
- expect(response).to render_template("admin/users/update")
142
- end
143
- end
144
- end
145
-
146
- # GET /admin/users/1/confirm AJAX
147
- #----------------------------------------------------------------------------
148
- describe "GET confirm" do
149
- it "assigns the requested user as @user and renders [confirm] template" do
150
- @user = create(:user)
151
-
152
- get :confirm, params: { id: @user.id }, xhr: true
153
- expect(assigns[:user]).to eq(@user)
154
- expect(response).to render_template("admin/users/confirm")
155
- end
156
-
157
- it "reloads current page is the user got deleted" do
158
- @user = create(:user)
159
- @user.destroy
160
-
161
- get :confirm, params: { id: @user.id }, xhr: true
162
- expect(flash[:warning]).not_to eq(nil)
163
- expect(response.body).to eq("window.location.reload();")
164
- end
165
- end
166
-
167
- # DELETE /admin/users/1
168
- # DELETE /admin/users/1.xml AJAX
169
- #----------------------------------------------------------------------------
170
- describe "DELETE destroy" do
171
- it "destroys the requested user and renders [destroy] template" do
172
- @user = create(:user)
173
-
174
- delete :destroy, params: { id: @user.id }, xhr: true
175
- expect { User.find(@user.id) }.to raise_error(ActiveRecord::RecordNotFound)
176
- expect(response).to render_template("admin/users/destroy")
177
- end
178
-
179
- it "handles the case when the requested user can't be deleted" do
180
- @user = create(:user)
181
- @account = create(:account, user: @user) # Plant artifact to prevent the user from being deleted.
182
-
183
- delete :destroy, params: { id: @user.id }, xhr: true
184
- expect(flash[:warning]).not_to eq(nil)
185
- expect { User.find(@user.id) }.not_to raise_error
186
- expect(response).to render_template("admin/users/destroy")
187
- end
188
- end
189
-
190
- # POST /users/auto_complete/query AJAX
191
- #----------------------------------------------------------------------------
192
- describe "POST auto_complete" do
193
- before(:each) do
194
- @auto_complete_matches = [create(:user, first_name: "Hello")]
195
- end
196
-
197
- it_should_behave_like("auto complete")
198
- end
199
-
200
- # PUT /admin/users/1/suspend
201
- # PUT /admin/users/1/suspend.xml AJAX
202
- #----------------------------------------------------------------------------
203
- describe "PUT suspend" do
204
- it "suspends the requested user" do
205
- @user = create(:user)
206
-
207
- put :suspend, params: { id: @user.id }, xhr: true
208
- expect(assigns[:user].suspended?).to eq(true)
209
- expect(response).to render_template("admin/users/suspend")
210
- end
211
-
212
- it "doesn't suspend current user" do
213
- @user = current_user
214
-
215
- put :suspend, params: { id: @user.id }, xhr: true
216
- expect(assigns[:user].suspended?).to eq(false)
217
- expect(response).to render_template("admin/users/suspend")
218
- end
219
-
220
- it "reloads current page is the user got deleted" do
221
- @user = create(:user)
222
- @user.destroy
223
-
224
- put :suspend, params: { id: @user.id }, xhr: true
225
- expect(flash[:warning]).not_to eq(nil)
226
- expect(response.body).to eq("window.location.reload();")
227
- end
228
- end
229
-
230
- # PUT /admin/users/1/reactivate
231
- # PUT /admin/users/1/reactivate.xml AJAX
232
- #----------------------------------------------------------------------------
233
- describe "PUT reactivate" do
234
- it "re-activates the requested user" do
235
- @user = create(:user, suspended_at: Time.now.yesterday)
236
-
237
- put :reactivate, params: { id: @user.id }, xhr: true
238
- expect(assigns[:user].suspended?).to eq(false)
239
- expect(response).to render_template("admin/users/reactivate")
240
- end
241
-
242
- it "reloads current page is the user got deleted" do
243
- @user = create(:user)
244
- @user.destroy
245
-
246
- put :reactivate, params: { id: @user.id }, xhr: true
247
- expect(flash[:warning]).not_to eq(nil)
248
- expect(response.body).to eq("window.location.reload();")
249
- end
250
- end
251
- end
@@ -1,43 +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 'spec_helper'
9
-
10
- describe ApplicationController do
11
- describe "auto_complete_ids_to_exclude" do
12
- it "should return [] when related is nil" do
13
- expect(controller.send(:auto_complete_ids_to_exclude, nil)).to eq([])
14
- end
15
-
16
- it "should return [] when related is ''" do
17
- expect(controller.send(:auto_complete_ids_to_exclude, '')).to eq([])
18
- end
19
-
20
- it "should return campaign id 5 when related is '5' and controller is campaigns" do
21
- expect(controller.send(:auto_complete_ids_to_exclude, '5').sort).to eq([5])
22
- end
23
-
24
- it "should return [6, 9] when related is 'campaigns/7'" do
25
- allow(controller).to receive(:controller_name).and_return('opportunities')
26
- campaign = double(Campaign, opportunities: [double(id: 6), double(id: 9)])
27
- expect(Campaign).to receive(:find_by_id).with('7').and_return(campaign)
28
- expect(controller.send(:auto_complete_ids_to_exclude, 'campaigns/7').sort).to eq([6, 9])
29
- end
30
-
31
- it "should return [] when related object is not found" do
32
- expect(Campaign).to receive(:find_by_id).with('7').and_return(nil)
33
- expect(controller.send(:auto_complete_ids_to_exclude, 'campaigns/7')).to eq([])
34
- end
35
-
36
- it "should return [] when related object association is not found" do
37
- allow(controller).to receive(:controller_name).and_return('not_a_method_that_exists')
38
- campaign = double(Campaign)
39
- expect(Campaign).to receive(:find_by_id).with('7').and_return(campaign)
40
- expect(controller.send(:auto_complete_ids_to_exclude, 'campaigns/7')).to eq([])
41
- end
42
- end
43
- end
@@ -1,195 +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 'spec_helper'
9
-
10
- describe CommentsController do
11
- COMMENTABLE = %i[account campaign contact lead opportunity].freeze
12
-
13
- before(:each) do
14
- login
15
- end
16
-
17
- # GET /comments
18
- # GET /comments.xml
19
- #----------------------------------------------------------------------------
20
- describe "responding to GET index" do
21
- COMMENTABLE.each do |asset|
22
- describe "(HTML)" do
23
- before(:each) do
24
- @asset = create(asset)
25
- end
26
-
27
- it "should redirect to the asset landing page if the asset is found" do
28
- get :index, params: { "#{asset}_id": @asset.id }
29
- expect(response).to redirect_to(controller: asset.to_s.pluralize, action: :show, id: @asset.id)
30
- end
31
-
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 }
34
- expect(flash[:warning]).not_to eq(nil)
35
- expect(response).to redirect_to(root_path)
36
- end
37
- end
38
-
39
- describe "(JSON)" do
40
- before(:each) do
41
- @asset = create(asset)
42
- @asset.comments = [create(:comment, commentable: @asset)]
43
- request.env["HTTP_ACCEPT"] = "application/json"
44
- end
45
-
46
- it "should render all comments as JSON if the asset is found found" do
47
- get :index, params: { "#{asset}_id": @asset.id }
48
- expect(response.body).to eq(assigns[:comments].to_json)
49
- end
50
-
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 }
53
- expect(flash[:warning]).not_to eq(nil)
54
- expect(response.code).to eq("404")
55
- end
56
- end
57
-
58
- describe "(XML)" do
59
- before(:each) do
60
- @asset = create(asset)
61
- @asset.comments = [create(:comment, commentable: @asset)]
62
- request.env["HTTP_ACCEPT"] = "application/xml"
63
- end
64
-
65
- it "should render all comments as XML if the asset is found found" do
66
- get :index, params: { "#{asset}_id": @asset.id }
67
- expect(response.body).to eq(assigns[:comments].to_xml)
68
- end
69
-
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 }
72
- expect(flash[:warning]).not_to eq(nil)
73
- expect(response.code).to eq("404")
74
- end
75
- end
76
- end
77
- end
78
-
79
- # GET /comments/1/edit AJAX
80
- #----------------------------------------------------------------------------
81
- describe "responding to GET edit" do
82
- COMMENTABLE.each do |asset|
83
- it "should expose the requested comment as @commment and render [edit] template" do
84
- @asset = create(asset)
85
- @comment = create(:comment, id: 42, commentable: @asset, user: current_user)
86
- allow(Comment).to receive(:new).and_return(@comment)
87
-
88
- get :edit, params: { id: 42 }, xhr: true
89
- expect(assigns[:comment]).to eq(@comment)
90
- expect(response).to render_template("comments/edit")
91
- end
92
- end
93
- end
94
-
95
- # POST /comments
96
- # POST /comments.xml AJAX
97
- #----------------------------------------------------------------------------
98
- describe "responding to POST create" do
99
- describe "with valid params" do
100
- COMMENTABLE.each do |asset|
101
- it "should expose a newly created comment as @comment for the #{asset}" do
102
- @asset = create(asset)
103
- @comment = build(:comment, commentable: @asset, user: current_user)
104
- allow(Comment).to receive(:new).and_return(@comment)
105
-
106
- post :create, params: { comment: { commentable_type: asset.to_s.classify, commentable_id: @asset.id, user_id: current_user.id, comment: "Hello" } }, xhr: true
107
- expect(assigns[:comment]).to eq(@comment)
108
- expect(response).to render_template("comments/create")
109
- end
110
- end
111
- end
112
-
113
- describe "with invalid params" do
114
- COMMENTABLE.each do |asset|
115
- it "should expose a newly created but unsaved comment as @comment for #{asset}" do
116
- @asset = create(asset)
117
- @comment = build(:comment, commentable: @asset, user: current_user)
118
- allow(Comment).to receive(:new).and_return(@comment)
119
-
120
- post :create, params: { comment: {} }, xhr: true
121
- expect(assigns[:comment]).to eq(@comment)
122
- expect(response).to render_template("comments/create")
123
- end
124
- end
125
- end
126
- end
127
-
128
- # PUT /comments/1
129
- # PUT /comments/1.xml not implemened
130
- #----------------------------------------------------------------------------
131
- # describe "responding to PUT update" do
132
- #
133
- # describe "with valid params" do
134
- # it "should update the requested comment" do
135
- # Comment.should_receive(:find).with("37").and_return(mock_comment)
136
- # mock_comment.should_receive(:update).with({'these' => 'params'})
137
- # put :update, :id => "37", :comment => {:these => 'params'}
138
- # end
139
- #
140
- # it "should expose the requested comment as @comment" do
141
- # Comment.stub(:find).and_return(mock_comment(:update => true))
142
- # put :update, :id => "1"
143
- # assigns(:comment).should equal(mock_comment)
144
- # end
145
- #
146
- # it "should redirect to the comment" do
147
- # Comment.stub(:find).and_return(mock_comment(:update => true))
148
- # put :update, :id => "1"
149
- # response.should redirect_to(comment_path(mock_comment))
150
- # end
151
- # end
152
- #
153
- # describe "with invalid params" do
154
- # it "should update the requested comment" do
155
- # Comment.should_receive(:find).with("37").and_return(mock_comment)
156
- # mock_comment.should_receive(:update).with({'these' => 'params'})
157
- # put :update, :id => "37", :comment => {:these => 'params'}
158
- # end
159
- #
160
- # it "should expose the comment as @comment" do
161
- # Comment.stub(:find).and_return(mock_comment(:update => false))
162
- # put :update, :id => "1"
163
- # assigns(:comment).should equal(mock_comment)
164
- # end
165
- #
166
- # it "should re-render the 'edit' template" do
167
- # Comment.stub(:find).and_return(mock_comment(:update => false))
168
- # put :update, :id => "1"
169
- # response.should render_template('edit')
170
- # end
171
- # end
172
- #
173
- # end
174
-
175
- # DELETE /comments/1
176
- # DELETE /comments/1.xml AJAX
177
- #----------------------------------------------------------------------------
178
- describe "responding to DELETE destroy" do
179
- describe "AJAX request" do
180
- describe "with valid params" do
181
- COMMENTABLE.each do |asset|
182
- it "should destroy the requested comment and render [destroy] template" do
183
- @asset = create(asset)
184
- @comment = create(:comment, commentable: @asset, user: current_user)
185
- allow(Comment).to receive(:new).and_return(@comment)
186
-
187
- delete :destroy, params: { id: @comment.id }, xhr: true
188
- expect { Comment.find(@comment.id) }.to raise_error(ActiveRecord::RecordNotFound)
189
- expect(response).to render_template("comments/destroy")
190
- end
191
- end
192
- end
193
- end
194
- end
195
- end
@@ -1,37 +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 EmailsController, "handling GET /emails" do
11
- MEDIATOR = %i[account campaign contact lead opportunity].freeze
12
-
13
- before(:each) do
14
- login
15
- end
16
-
17
- # DELETE /emails/1
18
- # DELETE /emails/1.xml AJAX
19
- #----------------------------------------------------------------------------
20
- describe "responding to DELETE destroy" do
21
- describe "AJAX request" do
22
- describe "with valid params" do
23
- MEDIATOR.each do |asset|
24
- it "should destroy the requested email and render [destroy] template" do
25
- @asset = create(asset)
26
- @email = create(:email, mediator: @asset, user: current_user)
27
- allow(Email).to receive(:new).and_return(@email)
28
-
29
- delete :destroy, params: { id: @email.id }, xhr: true
30
- expect { Email.find(@email.id) }.to raise_error(ActiveRecord::RecordNotFound)
31
- expect(response).to render_template("emails/destroy")
32
- end
33
- end
34
- end
35
- end
36
- end
37
- end