spree_backend 3.2.9 → 3.3.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (196) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/spree/backend/admin.js +16 -15
  3. data/app/assets/javascripts/spree/backend/checkouts/edit.js +25 -26
  4. data/app/assets/javascripts/spree/backend/general_settings.js.coffee +10 -12
  5. data/app/assets/javascripts/spree/backend/payments/edit.js.coffee +4 -6
  6. data/app/assets/javascripts/spree/backend/returns/return_item_selection.js +7 -1
  7. data/app/assets/javascripts/spree/backend/stock_transfer.js.coffee +4 -1
  8. data/app/assets/javascripts/spree/backend/user_picker.js +3 -1
  9. data/app/assets/javascripts/spree/backend.js +3 -3
  10. data/app/controllers/spree/admin/countries_controller.rb +1 -0
  11. data/app/controllers/spree/admin/log_entries_controller.rb +2 -2
  12. data/app/controllers/spree/admin/orders/customer_details_controller.rb +5 -6
  13. data/app/controllers/spree/admin/orders_controller.rb +4 -4
  14. data/app/controllers/spree/admin/payments_controller.rb +21 -10
  15. data/app/controllers/spree/admin/products_controller.rb +5 -0
  16. data/app/controllers/spree/admin/promotion_rules_controller.rb +11 -7
  17. data/app/controllers/spree/admin/stock_transfers_controller.rb +1 -1
  18. data/app/controllers/spree/admin/taxons_controller.rb +31 -23
  19. data/app/helpers/spree/admin/base_helper.rb +1 -1
  20. data/app/helpers/spree/admin/navigation_helper.rb +10 -4
  21. data/app/views/spree/admin/adjustments/_adjustments_table.html.erb +2 -2
  22. data/app/views/spree/admin/general_settings/edit.html.erb +8 -8
  23. data/app/views/spree/admin/images/_form.html.erb +2 -2
  24. data/app/views/spree/admin/images/edit.html.erb +2 -2
  25. data/app/views/spree/admin/images/new.html.erb +1 -1
  26. data/app/views/spree/admin/option_types/_form.html.erb +2 -2
  27. data/app/views/spree/admin/option_types/index.html.erb +4 -4
  28. data/app/views/spree/admin/orders/_line_items.html.erb +40 -38
  29. data/app/views/spree/admin/orders/_shipment.html.erb +77 -76
  30. data/app/views/spree/admin/orders/customer_details/_form.html.erb +5 -5
  31. data/app/views/spree/admin/orders/index.html.erb +16 -16
  32. data/app/views/spree/admin/payment_methods/_form.html.erb +2 -2
  33. data/app/views/spree/admin/payments/_list.html.erb +1 -1
  34. data/app/views/spree/admin/products/_add_stock_form.html.erb +3 -3
  35. data/app/views/spree/admin/products/_form.html.erb +16 -16
  36. data/app/views/spree/admin/products/index.html.erb +4 -4
  37. data/app/views/spree/admin/products/new.html.erb +8 -8
  38. data/app/views/spree/admin/promotion_categories/index.html.erb +3 -3
  39. data/app/views/spree/admin/promotions/_form.html.erb +3 -3
  40. data/app/views/spree/admin/promotions/_promotion_rule.html.erb +1 -1
  41. data/app/views/spree/admin/promotions/actions/_create_adjustment.html.erb +2 -2
  42. data/app/views/spree/admin/promotions/actions/_create_item_adjustments.html.erb +2 -2
  43. data/app/views/spree/admin/promotions/actions/_create_line_items.html.erb +2 -4
  44. data/app/views/spree/admin/promotions/edit.html.erb +3 -3
  45. data/app/views/spree/admin/promotions/index.html.erb +6 -6
  46. data/app/views/spree/admin/promotions/rules/_item_total.html.erb +2 -2
  47. data/app/views/spree/admin/promotions/rules/_option_value.html.erb +4 -4
  48. data/app/views/spree/admin/properties/_form.html.erb +2 -2
  49. data/app/views/spree/admin/properties/index.html.erb +6 -6
  50. data/app/views/spree/admin/prototypes/index.html.erb +4 -4
  51. data/app/views/spree/admin/reimbursement_types/_form.html.erb +4 -4
  52. data/app/views/spree/admin/reimbursements/edit.html.erb +1 -1
  53. data/app/views/spree/admin/return_authorizations/_form.html.erb +13 -1
  54. data/app/views/spree/admin/return_index/customer_returns.html.erb +2 -2
  55. data/app/views/spree/admin/return_index/return_authorizations.html.erb +5 -5
  56. data/app/views/spree/admin/shared/_content_header.html.erb +2 -2
  57. data/app/views/spree/admin/shared/_header.html.erb +2 -2
  58. data/app/views/spree/admin/shared/_index_table_options.html.erb +2 -2
  59. data/app/views/spree/admin/shared/_order_summary.html.erb +1 -1
  60. data/app/views/spree/admin/shared/_table_filter.html.erb +1 -1
  61. data/app/views/spree/admin/shared/_translations.html.erb +0 -1
  62. data/app/views/spree/admin/shared/_update_order_state.js.erb +1 -1
  63. data/app/views/spree/admin/shipping_methods/_form.html.erb +10 -10
  64. data/app/views/spree/admin/state_changes/index.html.erb +3 -3
  65. data/app/views/spree/admin/states/_form.html.erb +2 -2
  66. data/app/views/spree/admin/stock_locations/_form.html.erb +2 -2
  67. data/app/views/spree/admin/stock_locations/_transfer_stock_form.html.erb +4 -4
  68. data/app/views/spree/admin/stock_transfers/index.html.erb +3 -3
  69. data/app/views/spree/admin/stock_transfers/new.html.erb +2 -2
  70. data/app/views/spree/admin/store_credits/index.html.erb +1 -1
  71. data/app/views/spree/admin/tax_rates/_form.html.erb +2 -2
  72. data/app/views/spree/admin/taxonomies/_list.html.erb +2 -2
  73. data/app/views/spree/admin/taxonomies/{edit.erb → edit.html.erb} +0 -0
  74. data/app/views/spree/admin/taxonomies/index.html.erb +2 -2
  75. data/app/views/spree/admin/taxons/_form.html.erb +5 -5
  76. data/app/views/spree/admin/taxons/edit.html.erb +3 -0
  77. data/app/views/spree/admin/trackers/_form.html.erb +2 -2
  78. data/app/views/spree/admin/users/_addresses_form.html.erb +2 -2
  79. data/app/views/spree/admin/users/_form.html.erb +2 -2
  80. data/app/views/spree/admin/users/_user_page_actions.html.erb +1 -1
  81. data/app/views/spree/admin/users/index.html.erb +5 -5
  82. data/app/views/spree/admin/users/items.html.erb +1 -1
  83. data/app/views/spree/admin/users/orders.html.erb +1 -1
  84. data/app/views/spree/admin/variants/_form.html.erb +2 -2
  85. data/app/views/spree/admin/zones/_form.html.erb +2 -2
  86. data/app/views/spree/layouts/admin.html.erb +3 -3
  87. data/config/initializers/assets.rb +1 -1
  88. data/lib/spree/backend/engine.rb +0 -1
  89. data/spec/controllers/spree/admin/base_controller_spec.rb +46 -0
  90. data/spec/controllers/spree/admin/customer_returns_controller_spec.rb +185 -0
  91. data/spec/controllers/spree/admin/general_settings_controller_spec.rb +41 -0
  92. data/spec/controllers/spree/admin/missing_products_controller_spec.rb +18 -0
  93. data/spec/controllers/spree/admin/orders/customer_details_controller_spec.rb +199 -0
  94. data/spec/controllers/spree/admin/orders_controller_spec.rb +296 -0
  95. data/spec/controllers/spree/admin/payment_methods_controller_spec.rb +64 -0
  96. data/spec/controllers/spree/admin/payments_controller_spec.rb +97 -0
  97. data/spec/controllers/spree/admin/products_controller_spec.rb +137 -0
  98. data/spec/controllers/spree/admin/promotion_actions_controller_spec.rb +21 -0
  99. data/spec/controllers/spree/admin/promotion_rules_controller_spec.rb +21 -0
  100. data/spec/controllers/spree/admin/promotions_controller_spec.rb +44 -0
  101. data/spec/controllers/spree/admin/refunds_controller_spec.rb +32 -0
  102. data/spec/controllers/spree/admin/reimbursements_controller_spec.rb +74 -0
  103. data/spec/controllers/spree/admin/reports_controller_spec.rb +42 -0
  104. data/spec/controllers/spree/admin/resource_controller_spec.rb +252 -0
  105. data/spec/controllers/spree/admin/return_authorizations_controller_spec.rb +225 -0
  106. data/spec/controllers/spree/admin/return_index_controller_spec.rb +37 -0
  107. data/spec/controllers/spree/admin/return_items_controller_spec.rb +27 -0
  108. data/spec/controllers/spree/admin/shipping_methods_controller_spec.rb +14 -0
  109. data/spec/controllers/spree/admin/stock_items_controller_spec.rb +19 -0
  110. data/spec/controllers/spree/admin/stock_locations_controller_spec.rb +41 -0
  111. data/spec/controllers/spree/admin/stock_transfers_controller_spec.rb +41 -0
  112. data/spec/controllers/spree/admin/tax_categories_controller_spec.rb +34 -0
  113. data/spec/controllers/spree/admin/users_controller_spec.rb +161 -0
  114. data/spec/controllers/spree/admin/variants_controller_spec.rb +32 -0
  115. data/spec/features/admin/configuration/analytics_tracker_spec.rb +47 -0
  116. data/spec/features/admin/configuration/countries_spec.rb +24 -0
  117. data/spec/features/admin/configuration/general_settings_spec.rb +44 -0
  118. data/spec/features/admin/configuration/payment_methods_spec.rb +63 -0
  119. data/spec/features/admin/configuration/roles_spec.rb +47 -0
  120. data/spec/features/admin/configuration/shipping_methods_spec.rb +62 -0
  121. data/spec/features/admin/configuration/states_spec.rb +68 -0
  122. data/spec/features/admin/configuration/stock_locations_spec.rb +48 -0
  123. data/spec/features/admin/configuration/store_credit_categories_spec.rb +50 -0
  124. data/spec/features/admin/configuration/tax_categories_spec.rb +56 -0
  125. data/spec/features/admin/configuration/tax_rates_spec.rb +18 -0
  126. data/spec/features/admin/configuration/zones_spec.rb +39 -0
  127. data/spec/features/admin/homepage_spec.rb +89 -0
  128. data/spec/features/admin/locale_spec.rb +31 -0
  129. data/spec/features/admin/orders/adjustments_promotions_spec.rb +53 -0
  130. data/spec/features/admin/orders/adjustments_spec.rb +124 -0
  131. data/spec/features/admin/orders/cancelling_and_resuming_spec.rb +47 -0
  132. data/spec/features/admin/orders/customer_details_spec.rb +154 -0
  133. data/spec/features/admin/orders/line_items_spec.rb +51 -0
  134. data/spec/features/admin/orders/listing_spec.rb +224 -0
  135. data/spec/features/admin/orders/log_entries_spec.rb +55 -0
  136. data/spec/features/admin/orders/new_order_spec.rb +186 -0
  137. data/spec/features/admin/orders/order_details_spec.rb +660 -0
  138. data/spec/features/admin/orders/payments_spec.rb +244 -0
  139. data/spec/features/admin/orders/risk_analysis_spec.rb +48 -0
  140. data/spec/features/admin/orders/shipments_spec.rb +64 -0
  141. data/spec/features/admin/orders/state_changes_spec.rb +21 -0
  142. data/spec/features/admin/products/edit/images_spec.rb +86 -0
  143. data/spec/features/admin/products/edit/products_spec.rb +56 -0
  144. data/spec/features/admin/products/edit/taxons_spec.rb +41 -0
  145. data/spec/features/admin/products/edit/variants_spec.rb +56 -0
  146. data/spec/features/admin/products/option_types_spec.rb +114 -0
  147. data/spec/features/admin/products/products_spec.rb +445 -0
  148. data/spec/features/admin/products/properties_spec.rb +147 -0
  149. data/spec/features/admin/products/prototypes_spec.rb +112 -0
  150. data/spec/features/admin/products/stock_management_spec.rb +124 -0
  151. data/spec/features/admin/products/taxonomies_spec.rb +52 -0
  152. data/spec/features/admin/products/variant_spec.rb +50 -0
  153. data/spec/features/admin/promotions/adjustments_spec.rb +258 -0
  154. data/spec/features/admin/promotions/option_value_rule_spec.rb +70 -0
  155. data/spec/features/admin/promotions/tiered_calculator_spec.rb +70 -0
  156. data/spec/features/admin/refund_reasons/refund_reasons_spec.rb +57 -0
  157. data/spec/features/admin/reimbursement_type/edit_reimbursement_type_spec.rb +36 -0
  158. data/spec/features/admin/reimbursement_type/new_reimbursement_type_spec.rb +62 -0
  159. data/spec/features/admin/reports_spec.rb +61 -0
  160. data/spec/features/admin/return_authorization_reasons/return_authorization_reasons_spec.rb +63 -0
  161. data/spec/features/admin/returns/customer_returns_spec.rb +80 -0
  162. data/spec/features/admin/returns/return_authorizations_spec.rb +152 -0
  163. data/spec/features/admin/stock_transfer_spec.rb +91 -0
  164. data/spec/features/admin/store_credits_spec.rb +93 -0
  165. data/spec/features/admin/taxons_spec.rb +53 -0
  166. data/spec/features/admin/users_spec.rb +286 -0
  167. data/spec/helpers/admin/base_helper_spec.rb +30 -0
  168. data/spec/helpers/admin/navigation_helper_spec.rb +111 -0
  169. data/spec/helpers/admin/promotion_rules_helper_spec.rb +12 -0
  170. data/spec/helpers/admin/stock_movements_helper_spec.rb +30 -0
  171. data/spec/models/spree/resource_spec.rb +48 -0
  172. data/spec/routing/admin_path_spec.rb +22 -0
  173. data/spec/spec_helper.rb +144 -0
  174. data/spec/support/appear_before_matcher.rb +8 -0
  175. data/spec/support/ror_ringer.jpeg +0 -0
  176. data/spec/test_views/spree/admin/submodule/posts/edit.html.erb +1 -0
  177. data/spec/test_views/spree/admin/submodule/posts/new.html.erb +1 -0
  178. data/spec/test_views/spree/admin/widgets/edit.html.erb +1 -0
  179. data/spec/test_views/spree/admin/widgets/new.html.erb +1 -0
  180. data/spree_backend.gemspec +4 -4
  181. data/vendor/assets/javascripts/jquery.jstree/jquery.jstree.js +130 -154
  182. metadata +106 -29
  183. data/vendor/assets/images/jquery-ui/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
  184. data/vendor/assets/images/jquery-ui/ui-bg_flat_0_eeeeee_40x100.png +0 -0
  185. data/vendor/assets/images/jquery-ui/ui-bg_flat_55_ffffff_40x100.png +0 -0
  186. data/vendor/assets/images/jquery-ui/ui-bg_flat_75_ffffff_40x100.png +0 -0
  187. data/vendor/assets/images/jquery-ui/ui-bg_glass_65_ffffff_1x400.png +0 -0
  188. data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_100_f6f6f6_1x100.png +0 -0
  189. data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_25_0073ea_1x100.png +0 -0
  190. data/vendor/assets/images/jquery-ui/ui-bg_highlight-soft_50_dddddd_1x100.png +0 -0
  191. data/vendor/assets/images/jquery-ui/ui-icons_0073ea_256x240.png +0 -0
  192. data/vendor/assets/images/jquery-ui/ui-icons_454545_256x240.png +0 -0
  193. data/vendor/assets/images/jquery-ui/ui-icons_666666_256x240.png +0 -0
  194. data/vendor/assets/images/jquery-ui/ui-icons_ff0084_256x240.png +0 -0
  195. data/vendor/assets/images/jquery-ui/ui-icons_ffffff_256x240.png +0 -0
  196. data/vendor/assets/stylesheets/jquery-ui.datepicker.css.erb +0 -357
@@ -0,0 +1,296 @@
1
+ require 'spec_helper'
2
+ require 'cancan'
3
+ require 'spree/testing_support/bar_ability'
4
+
5
+ # Ability to test access to specific model instances
6
+ class OrderSpecificAbility
7
+ include CanCan::Ability
8
+
9
+ def initialize(user)
10
+ can [:admin, :manage], Spree::Order, number: 'R987654321'
11
+ end
12
+ end
13
+
14
+ describe Spree::Admin::OrdersController, type: :controller do
15
+
16
+ context "with authorization" do
17
+ stub_authorization!
18
+
19
+ before do
20
+ request.env["HTTP_REFERER"] = "http://localhost:3000"
21
+
22
+ # ensure no respond_overrides are in effect
23
+ if Spree::BaseController.spree_responders[:OrdersController].present?
24
+ Spree::BaseController.spree_responders[:OrdersController].clear
25
+ end
26
+ end
27
+
28
+ let(:order) do
29
+ mock_model(
30
+ Spree::Order,
31
+ completed?: true,
32
+ total: 100,
33
+ number: 'R123456789',
34
+ all_adjustments: adjustments,
35
+ billing_address: mock_model(Spree::Address)
36
+ )
37
+ end
38
+
39
+ let(:adjustments) { double('adjustments') }
40
+
41
+ before do
42
+ allow(Spree::Order).to receive_message_chain(:includes, find_by!: order)
43
+ end
44
+
45
+ context "#approve" do
46
+ it "approves an order" do
47
+ expect(order).to receive(:approved_by).with(controller.try_spree_current_user)
48
+ spree_put :approve, id: order.number
49
+ expect(flash[:success]).to eq Spree.t(:order_approved)
50
+ end
51
+ end
52
+
53
+ context "#cancel" do
54
+ it "cancels an order" do
55
+ expect(order).to receive(:canceled_by).with(controller.try_spree_current_user)
56
+ spree_put :cancel, id: order.number
57
+ expect(flash[:success]).to eq Spree.t(:order_canceled)
58
+ end
59
+ end
60
+
61
+ context "#resume" do
62
+ it "resumes an order" do
63
+ expect(order).to receive(:resume!)
64
+ spree_put :resume, id: order.number
65
+ expect(flash[:success]).to eq Spree.t(:order_resumed)
66
+ end
67
+ end
68
+
69
+ context "pagination" do
70
+ it "can page through the orders" do
71
+ spree_get :index, page: 2, per_page: 10
72
+ expect(assigns[:orders].offset_value).to eq(10)
73
+ expect(assigns[:orders].limit_value).to eq(10)
74
+ end
75
+ end
76
+
77
+ # Test for #3346
78
+ context "#new" do
79
+ it "a new order has the current user assigned as a creator" do
80
+ spree_get :new
81
+ expect(assigns[:order].created_by).to eq(controller.try_spree_current_user)
82
+ end
83
+ end
84
+
85
+ # Regression test for #3684
86
+ describe "#edit" do
87
+ let(:display_value) { Spree::ShippingMethod::DISPLAY_ON_BACK_END }
88
+
89
+ before do
90
+ allow(controller).to receive(:can_not_transition_without_customer_info)
91
+ allow(order).to receive(:refresh_shipment_rates).with(display_value).and_return(true)
92
+ end
93
+
94
+ after do
95
+ spree_get :edit, id: order.number
96
+ end
97
+
98
+ it { expect(controller).to receive(:can_not_transition_without_customer_info) }
99
+ it { expect(order).to receive(:refresh_shipment_rates).with(display_value).and_return(true) }
100
+ end
101
+
102
+ # Test for #3919
103
+ context "search" do
104
+ let(:user) { create(:user) }
105
+
106
+ before do
107
+ allow(controller).to receive_messages spree_current_user: user
108
+ user.spree_roles << Spree::Role.find_or_create_by(name: 'admin')
109
+
110
+ create(:completed_order_with_totals)
111
+ expect(Spree::Order.count).to eq 1
112
+ end
113
+
114
+ def send_request
115
+ spree_get :index, q: {
116
+ line_items_variant_id_in: Spree::Order.first.variants.map(&:id)
117
+ }
118
+ end
119
+
120
+ it 'does not display duplicate results' do
121
+ send_request
122
+ expect(assigns[:orders].map { |o| o.number }.count).to eq 1
123
+ end
124
+
125
+ it 'preloads users' do
126
+ expect(Spree::Order).to receive(:preload).with(:user).and_return(Spree::Order.all)
127
+ send_request
128
+ end
129
+ end
130
+
131
+ context "#open_adjustments" do
132
+ let(:closed) { double('closed_adjustments') }
133
+
134
+ before do
135
+ allow(adjustments).to receive(:closed).and_return(closed)
136
+ allow(closed).to receive(:update_all)
137
+ end
138
+
139
+ it "changes all the closed adjustments to open" do
140
+ expect(adjustments).to receive(:closed).and_return(closed)
141
+ expect(closed).to receive(:update_all).with(state: 'open')
142
+ spree_post :open_adjustments, id: order.number
143
+ end
144
+
145
+ it "sets the flash success message" do
146
+ spree_post :open_adjustments, id: order.number
147
+ expect(flash[:success]).to eql('All adjustments successfully opened!')
148
+ end
149
+
150
+ context 'when referer' do
151
+ before(:each) do
152
+ request.env['HTTP_REFERER'] = root_url
153
+ end
154
+
155
+ it "redirects back" do
156
+ spree_post :open_adjustments, id: order.number
157
+ expect(response).to redirect_to(root_url)
158
+ end
159
+ end
160
+
161
+ context 'when no referer' do
162
+ before(:each) do
163
+ request.env['HTTP_REFERER'] = nil
164
+ end
165
+
166
+ it 'refirects to fallback location' do
167
+ spree_post :open_adjustments, id: order.number
168
+ expect(response).to redirect_to(admin_order_adjustments_url(order))
169
+ end
170
+ end
171
+ end
172
+
173
+ context "#close_adjustments" do
174
+ let(:open) { double('open_adjustments') }
175
+
176
+ before do
177
+ allow(adjustments).to receive(:open).and_return(open)
178
+ allow(open).to receive(:update_all)
179
+ end
180
+
181
+ it "changes all the open adjustments to closed" do
182
+ expect(adjustments).to receive(:open).and_return(open)
183
+ expect(open).to receive(:update_all).with(state: 'closed')
184
+ spree_post :close_adjustments, id: order.number
185
+ end
186
+
187
+ it "sets the flash success message" do
188
+ spree_post :close_adjustments, id: order.number
189
+ expect(flash[:success]).to eql('All adjustments successfully closed!')
190
+ end
191
+
192
+ context 'when referer' do
193
+ before(:each) do
194
+ request.env['HTTP_REFERER'] = root_url
195
+ end
196
+
197
+ it "redirects back" do
198
+ spree_post :close_adjustments, id: order.number
199
+ expect(response).to redirect_to(root_url)
200
+ end
201
+ end
202
+
203
+ context 'when no referer' do
204
+ before(:each) do
205
+ request.env['HTTP_REFERER'] = nil
206
+ end
207
+
208
+ it 'refirects to fallback location' do
209
+ spree_post :close_adjustments, id: order.number
210
+ expect(response).to redirect_to(admin_order_adjustments_url(order))
211
+ end
212
+ end
213
+ end
214
+ end
215
+
216
+ context '#authorize_admin' do
217
+ let(:user) { create(:user) }
218
+ let(:order) { create(:completed_order_with_totals, number: 'R987654321') }
219
+
220
+ def with_ability(ability)
221
+ Spree::Ability.register_ability(ability)
222
+ yield
223
+ ensure
224
+ Spree::Ability.remove_ability(ability)
225
+ end
226
+
227
+ before do
228
+ allow(Spree::Order).to receive_messages find: order
229
+ allow(controller).to receive_messages spree_current_user: user
230
+ end
231
+
232
+ it 'should grant access to users with an admin role' do
233
+ user.spree_roles << Spree::Role.find_or_create_by(name: 'admin')
234
+ spree_post :index
235
+ expect(response).to render_template :index
236
+ end
237
+
238
+ it 'should grant access to users with an bar role' do
239
+ with_ability(BarAbility) do
240
+ user.spree_roles << Spree::Role.find_or_create_by(name: 'bar')
241
+ spree_post :index
242
+ expect(response).to render_template :index
243
+ end
244
+ end
245
+
246
+ it 'should deny access to users with an bar role' do
247
+ with_ability(BarAbility) do
248
+ allow(order).to receive(:update_attributes).and_return true
249
+ allow(order).to receive(:user).and_return Spree.user_class.new
250
+ allow(order).to receive(:token).and_return nil
251
+ user.spree_roles.clear
252
+ user.spree_roles << Spree::Role.find_or_create_by(name: 'bar')
253
+ spree_put :update, id: order.number
254
+ expect(response).to redirect_to(spree.forbidden_path)
255
+ end
256
+ end
257
+
258
+ it 'should deny access to users without an admin role' do
259
+ allow(user).to receive_messages has_spree_role?: false
260
+ spree_post :index
261
+ expect(response).to redirect_to(spree.forbidden_path)
262
+ end
263
+
264
+ it 'should deny access to not signed in users' do
265
+ allow(controller).to receive_messages spree_current_user: nil
266
+ spree_get :index
267
+ expect(response).to redirect_to(spree.root_path)
268
+ end
269
+
270
+ it 'should restrict returned order(s) on index when using OrderSpecificAbility' do
271
+ number = order.number
272
+
273
+ 3.times { create(:completed_order_with_totals) }
274
+ expect(Spree::Order.complete.count).to eq 4
275
+
276
+ with_ability(OrderSpecificAbility) do
277
+ allow(user).to receive_messages has_spree_role?: false
278
+ spree_get :index
279
+ expect(response).to render_template :index
280
+ expect(assigns['orders'].distinct(false).size).to eq 1
281
+ expect(assigns['orders'].first.number).to eq number
282
+ expect(Spree::Order.accessible_by(Spree::Ability.new(user), :index).pluck(:number)).to eq [number]
283
+ end
284
+ end
285
+ end
286
+
287
+ context "order number not given" do
288
+ stub_authorization!
289
+
290
+ it "raise active record not found" do
291
+ expect {
292
+ spree_get :edit, id: 99999999
293
+ }.to raise_error ActiveRecord::RecordNotFound
294
+ end
295
+ end
296
+ end
@@ -0,0 +1,64 @@
1
+ require 'spec_helper'
2
+
3
+ module Spree
4
+ class GatewayWithPassword < PaymentMethod
5
+ preference :password, :string, default: "password"
6
+ end
7
+
8
+ describe Admin::PaymentMethodsController, type: :controller do
9
+ stub_authorization!
10
+
11
+ let(:payment_method) { GatewayWithPassword.create!(name: "Bogus", preferred_password: "haxme") }
12
+
13
+ # regression test for #2094
14
+ it "does not clear password on update" do
15
+ expect(payment_method.preferred_password).to eq("haxme")
16
+ spree_put :update, id: payment_method.id, payment_method: { type: payment_method.class.to_s, preferred_password: "" }
17
+ expect(response).to redirect_to(spree.edit_admin_payment_method_path(payment_method))
18
+
19
+ payment_method.reload
20
+ expect(payment_method.preferred_password).to eq("haxme")
21
+ end
22
+
23
+ it 'saves payment method preferences on update' do
24
+ spree_put :update,
25
+ id: payment_method.id,
26
+ payment_method: {
27
+ type: payment_method.class.to_s,
28
+ name: 'Bogus'
29
+ },
30
+ gateway_with_password: {
31
+ preferred_password: "abc"
32
+ }
33
+
34
+ payment_method.reload
35
+ expect(payment_method.preferred_password).to eq("abc")
36
+ end
37
+
38
+ context "tries to save invalid payment" do
39
+ it "doesn't break, responds nicely" do
40
+ expect {
41
+ spree_post :create, payment_method: { name: "", type: "Spree::Gateway::Bogus" }
42
+ }.not_to raise_error
43
+ end
44
+ end
45
+
46
+ it "can create a payment method of a valid type" do
47
+ expect {
48
+ spree_post :create, payment_method: { name: "Test Method", type: "Spree::Gateway::Bogus" }
49
+ }.to change(Spree::PaymentMethod, :count).by(1)
50
+
51
+ expect(response).to be_redirect
52
+ expect(response).to redirect_to spree.edit_admin_payment_method_path(assigns(:payment_method))
53
+ end
54
+
55
+ it "can not create a payment method of an invalid type" do
56
+ expect {
57
+ spree_post :create, payment_method: { name: "Invalid Payment Method", type: "Spree::InvalidType" }
58
+ }.to change(Spree::PaymentMethod, :count).by(0)
59
+
60
+ expect(response).to be_redirect
61
+ expect(response).to redirect_to spree.new_admin_payment_method_path
62
+ end
63
+ end
64
+ end
@@ -0,0 +1,97 @@
1
+ require 'spec_helper'
2
+
3
+ module Spree
4
+ module Admin
5
+ describe PaymentsController, type: :controller do
6
+ stub_authorization!
7
+
8
+ let(:order) { create(:order) }
9
+
10
+ context "with a valid credit card" do
11
+ let(:order) { create(:order_with_line_items, state: "payment") }
12
+ let(:payment_method) { create(:credit_card_payment_method, display_on: "back_end") }
13
+
14
+ before do
15
+ attributes = {
16
+ order_id: order.number,
17
+ card: "new",
18
+ payment: {
19
+ amount: order.total,
20
+ payment_method_id: payment_method.id.to_s,
21
+ source_attributes: {
22
+ name: "Test User",
23
+ number: "4111 1111 1111 1111",
24
+ expiry: "09 / #{Time.current.year + 1}",
25
+ verification_value: "123"
26
+ }
27
+ }
28
+ }
29
+ spree_post :create, attributes
30
+ end
31
+
32
+ it "should process payment correctly" do
33
+ expect(order.payments.count).to eq(1)
34
+ expect(response).to redirect_to(spree.admin_order_payments_path(order))
35
+ expect(order.reload.state).to eq('complete')
36
+ end
37
+
38
+ # Regression for #4768
39
+ it "doesnt process the same payment twice" do
40
+ expect(Spree::LogEntry.where(source: order.payments.first).count).to eq(1)
41
+ end
42
+ end
43
+
44
+ # Regression test for #3233
45
+ context "with a backend payment method" do
46
+ before do
47
+ @payment_method = create(:check_payment_method, display_on: "back_end")
48
+ end
49
+
50
+ it "loads backend payment methods" do
51
+ spree_get :new, order_id: order.number
52
+ expect(response.status).to eq(200)
53
+ expect(assigns[:payment_methods]).to include(@payment_method)
54
+ end
55
+ end
56
+
57
+ context "order has billing address" do
58
+ before do
59
+ order.bill_address = create(:address)
60
+ order.save!
61
+ end
62
+
63
+ context "order does not have payments" do
64
+ it "redirect to new payments page" do
65
+ spree_get :index, { amount: 100, order_id: order.number }
66
+ expect(response).to redirect_to(spree.new_admin_order_payment_path(order))
67
+ end
68
+ end
69
+
70
+ context "order has payments" do
71
+ before do
72
+ order.payments << create(:payment, amount: order.total, order: order, state: 'completed')
73
+ end
74
+
75
+ it "shows the payments page" do
76
+ spree_get :index, { amount: 100, order_id: order.number }
77
+ expect(response.code).to eq "200"
78
+ end
79
+ end
80
+
81
+ end
82
+
83
+ context "order does not have a billing address" do
84
+ before do
85
+ order.bill_address = nil
86
+ order.save
87
+ end
88
+
89
+ it "should redirect to the customer details page" do
90
+ spree_get :index, { amount: 100, order_id: order.number }
91
+ expect(response).to redirect_to(spree.edit_admin_order_customer_path(order))
92
+ end
93
+ end
94
+
95
+ end
96
+ end
97
+ end
@@ -0,0 +1,137 @@
1
+ require 'spec_helper'
2
+
3
+ describe Spree::Admin::ProductsController, type: :controller do
4
+ stub_authorization!
5
+
6
+ context "#index" do
7
+ let(:ability_user) { stub_model(Spree::LegacyUser, has_spree_role?: true) }
8
+
9
+ # Regression test for #1259
10
+ it "can find a product by SKU" do
11
+ product = create(:product, sku: "ABC123")
12
+ spree_get :index, q: { sku_start: "ABC123" }
13
+ expect(assigns[:collection]).not_to be_empty
14
+ expect(assigns[:collection]).to include(product)
15
+ end
16
+ end
17
+
18
+ # regression test for #1370
19
+ context "adding properties to a product" do
20
+ let!(:product) { create(:product) }
21
+ specify do
22
+ spree_put :update, id: product.to_param, product: { product_properties_attributes: { "1" => { property_name: "Foo", value: "bar" } } }
23
+ expect(flash[:success]).to eq("Product #{product.name.inspect} has been successfully updated!")
24
+ end
25
+
26
+ end
27
+
28
+ # regression test for #801
29
+ describe '#destroy' do
30
+ let(:product) { mock_model(Spree::Product) }
31
+ let(:products) { double(ActiveRecord::Relation) }
32
+
33
+ def send_request
34
+ spree_delete :destroy, id: product, format: :js
35
+ end
36
+
37
+ context 'will successfully destroy product' do
38
+ before do
39
+ allow(Spree::Product).to receive(:friendly).and_return(products)
40
+ allow(products).to receive(:find).with(product.id.to_s).and_return(product)
41
+ allow(product).to receive(:destroy).and_return(true)
42
+ end
43
+
44
+ describe 'expects to receive' do
45
+ it { expect(Spree::Product).to receive(:friendly).and_return(products) }
46
+ it { expect(products).to receive(:find).with(product.id.to_s).and_return(product) }
47
+ it { expect(product).to receive(:destroy).and_return(true) }
48
+
49
+ after { send_request }
50
+ end
51
+
52
+ describe 'assigns' do
53
+ before { send_request }
54
+ it { expect(assigns(:product)).to eq(product) }
55
+ end
56
+
57
+ describe 'response' do
58
+ before { send_request }
59
+ it { expect(response).to have_http_status(:ok) }
60
+ it { expect(flash[:success]).to eq(Spree.t('notice_messages.product_deleted')) }
61
+ end
62
+ end
63
+
64
+ context 'will not successfully destroy product' do
65
+ before do
66
+ allow(Spree::Product).to receive(:friendly).and_return(products)
67
+ allow(products).to receive(:find).with(product.id.to_s).and_return(product)
68
+ allow(product).to receive(:destroy).and_return(false)
69
+ end
70
+
71
+ describe 'expects to receive' do
72
+ it { expect(Spree::Product).to receive(:friendly).and_return(products) }
73
+ it { expect(products).to receive(:find).with(product.id.to_s).and_return(product) }
74
+ it { expect(product).to receive(:destroy).and_return(false) }
75
+
76
+ after { send_request }
77
+ end
78
+
79
+ describe 'assigns' do
80
+ before { send_request }
81
+ it { expect(assigns(:product)).to eq(product) }
82
+ end
83
+
84
+ describe 'response' do
85
+ before { send_request }
86
+ it { expect(response).to have_http_status(:ok) }
87
+ it { expect(flash[:error]).to eq(Spree.t('notice_messages.product_not_deleted')) }
88
+ end
89
+ end
90
+ end
91
+
92
+ describe '#clone' do
93
+ let(:product) { create(:custom_product, name: 'MyProduct', sku: 'MySku') }
94
+ let(:product2) { create(:custom_product, name: 'COPY OF MyProduct', sku: 'COPY OF MySku') }
95
+ let(:variant) do
96
+ create(:master_variant, name: 'COPY OF MyProduct', sku: 'COPY OF MySku', created_at: product.created_at - 1.day)
97
+ end
98
+
99
+ def send_request
100
+ spree_post :clone, id: product, format: :js
101
+ end
102
+
103
+ context 'will successfully clone product' do
104
+ before do
105
+ allow(product).to receive(:duplicate).and_return(product2)
106
+ end
107
+
108
+ describe 'response' do
109
+ before { send_request }
110
+ it { expect(response).to have_http_status(:found) }
111
+ it { expect(response).to be_redirect }
112
+ it { expect(flash[:success]).to eq(Spree.t('notice_messages.product_cloned')) }
113
+ end
114
+ end
115
+
116
+ context 'will not successfully clone product' do
117
+ before do
118
+ variant
119
+ end
120
+
121
+ describe 'response' do
122
+ before { send_request }
123
+ it { expect(response).to have_http_status(:found) }
124
+ it { expect(response).to be_redirect }
125
+ it { expect(flash[:error]).to eq(Spree.t('notice_messages.product_not_cloned')) }
126
+ end
127
+ end
128
+ end
129
+
130
+ context "stock" do
131
+ let(:product) { create(:product) }
132
+ it "restricts stock location based on accessible attributes" do
133
+ expect(Spree::StockLocation).to receive(:accessible_by).and_return([])
134
+ spree_get :stock, id: product
135
+ end
136
+ end
137
+ end
@@ -0,0 +1,21 @@
1
+ require 'spec_helper'
2
+
3
+ describe Spree::Admin::PromotionActionsController, type: :controller do
4
+ stub_authorization!
5
+
6
+ let!(:promotion) { create(:promotion) }
7
+
8
+ it "can create a promotion action of a valid type" do
9
+ spree_post :create, promotion_id: promotion.id, action_type: "Spree::Promotion::Actions::CreateAdjustment"
10
+ expect(response).to be_redirect
11
+ expect(response).to redirect_to spree.edit_admin_promotion_path(promotion)
12
+ expect(promotion.actions.count).to eq(1)
13
+ end
14
+
15
+ it "can not create a promotion action of an invalid type" do
16
+ spree_post :create, promotion_id: promotion.id, action_type: "Spree::InvalidType"
17
+ expect(response).to be_redirect
18
+ expect(response).to redirect_to spree.edit_admin_promotion_path(promotion)
19
+ expect(promotion.rules.count).to eq(0)
20
+ end
21
+ end
@@ -0,0 +1,21 @@
1
+ require 'spec_helper'
2
+
3
+ describe Spree::Admin::PromotionRulesController, type: :controller do
4
+ stub_authorization!
5
+
6
+ let!(:promotion) { create(:promotion) }
7
+
8
+ it "can create a promotion rule of a valid type" do
9
+ spree_post :create, promotion_id: promotion.id, promotion_rule: { type: "Spree::Promotion::Rules::Product" }
10
+ expect(response).to be_redirect
11
+ expect(response).to redirect_to spree.edit_admin_promotion_path(promotion)
12
+ expect(promotion.rules.count).to eq(1)
13
+ end
14
+
15
+ it "can not create a promotion rule of an invalid type" do
16
+ spree_post :create, promotion_id: promotion.id, promotion_rule: { type: "Spree::InvalidType" }
17
+ expect(response).to be_redirect
18
+ expect(response).to redirect_to spree.edit_admin_promotion_path(promotion)
19
+ expect(promotion.rules.count).to eq(0)
20
+ end
21
+ end
@@ -0,0 +1,44 @@
1
+ require 'spec_helper'
2
+
3
+ describe Spree::Admin::PromotionsController, type: :controller do
4
+ stub_authorization!
5
+
6
+ let!(:promotion1) { create(:promotion, name: "name1", code: "code1", path: "path1") }
7
+ let!(:promotion2) { create(:promotion, name: "name2", code: "code2", path: "path2") }
8
+ let!(:category) { create :promotion_category }
9
+
10
+ context "#index" do
11
+ it "succeeds" do
12
+ spree_get :index
13
+ expect(assigns[:promotions]).to match_array [promotion2, promotion1]
14
+ end
15
+
16
+ it "assigns promotion categories" do
17
+ spree_get :index
18
+ expect(assigns[:promotion_categories]).to match_array [category]
19
+ end
20
+
21
+ context "search" do
22
+ it "pages results" do
23
+ spree_get :index, per_page: '1'
24
+ expect(assigns[:promotions]).to eq [promotion2]
25
+ end
26
+
27
+ it "filters by name" do
28
+ spree_get :index, q: {name_cont: promotion1.name}
29
+ expect(assigns[:promotions]).to eq [promotion1]
30
+ end
31
+
32
+ it "filters by code" do
33
+ spree_get :index, q: {code_cont: promotion1.code}
34
+ expect(assigns[:promotions]).to eq [promotion1]
35
+ end
36
+
37
+ it "filters by path" do
38
+ spree_get :index, q: {path_cont: promotion1.path}
39
+ expect(assigns[:promotions]).to eq [promotion1]
40
+ end
41
+ end
42
+ end
43
+
44
+ end