spree_core 3.0.10 → 3.1.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (289) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/javascripts/spree.js.coffee.erb +12 -3
  3. data/app/helpers/spree/base_helper.rb +4 -1
  4. data/app/helpers/spree/products_helper.rb +37 -6
  5. data/app/mailers/spree/base_mailer.rb +11 -2
  6. data/app/models/concerns/spree/adjustment_source.rb +3 -10
  7. data/app/models/concerns/spree/default_price.rb +7 -1
  8. data/app/models/concerns/spree/named_type.rb +1 -1
  9. data/app/models/concerns/spree/user_api_authentication.rb +7 -1
  10. data/app/models/concerns/spree/user_methods.rb +47 -0
  11. data/app/models/concerns/spree/user_reporting.rb +2 -2
  12. data/app/models/concerns/spree/vat_price_calculation.rb +47 -0
  13. data/app/models/spree/address.rb +8 -7
  14. data/app/models/spree/adjustable/adjuster/base.rb +25 -0
  15. data/app/models/spree/adjustable/adjuster/promotion.rb +41 -0
  16. data/app/models/spree/adjustable/adjuster/tax.rb +26 -0
  17. data/app/models/spree/adjustable/adjustments_updater.rb +22 -45
  18. data/app/models/spree/adjustment.rb +8 -10
  19. data/app/models/spree/app_configuration.rb +5 -2
  20. data/app/models/spree/base.rb +4 -0
  21. data/app/models/spree/calculator.rb +0 -5
  22. data/app/models/spree/calculator/default_tax.rb +2 -10
  23. data/app/models/spree/classification.rb +7 -3
  24. data/app/models/spree/country.rb +14 -3
  25. data/app/models/spree/credit_card.rb +21 -31
  26. data/app/models/spree/customer_return.rb +7 -15
  27. data/app/models/spree/gateway.rb +7 -6
  28. data/app/models/spree/image.rb +1 -1
  29. data/app/models/spree/inventory_unit.rb +9 -6
  30. data/app/models/spree/legacy_user.rb +1 -6
  31. data/app/models/spree/line_item.rb +69 -68
  32. data/app/models/spree/log_entry.rb +1 -4
  33. data/app/models/spree/option_type.rb +15 -6
  34. data/app/models/spree/option_type_prototype.rb +9 -0
  35. data/app/models/spree/option_value.rb +11 -3
  36. data/app/models/spree/option_value_variant.rb +6 -0
  37. data/app/models/spree/order.rb +113 -64
  38. data/app/models/spree/order/checkout.rb +8 -11
  39. data/app/models/spree/order/currency_updater.rb +1 -1
  40. data/app/models/spree/order/store_credit.rb +96 -0
  41. data/app/models/spree/order_contents.rb +6 -1
  42. data/app/models/spree/order_inventory.rb +4 -8
  43. data/app/models/spree/order_promotion.rb +6 -0
  44. data/app/models/spree/order_updater.rb +2 -7
  45. data/app/models/spree/payment.rb +46 -19
  46. data/app/models/spree/payment/gateway_options.rb +8 -4
  47. data/app/models/spree/payment_method.rb +12 -13
  48. data/app/models/spree/payment_method/store_credit.rb +130 -0
  49. data/app/models/spree/preference.rb +1 -1
  50. data/app/models/spree/price.rb +16 -6
  51. data/app/models/spree/product.rb +52 -49
  52. data/app/models/spree/product/scopes.rb +7 -2
  53. data/app/models/spree/product_option_type.rb +7 -2
  54. data/app/models/spree/product_promotion_rule.rb +9 -0
  55. data/app/models/spree/product_property.rb +8 -10
  56. data/app/models/spree/promotion.rb +19 -19
  57. data/app/models/spree/promotion/rules/product.rb +3 -1
  58. data/app/models/spree/promotion/rules/taxon.rb +2 -1
  59. data/app/models/spree/promotion/rules/user.rb +4 -4
  60. data/app/models/spree/promotion_action.rb +3 -3
  61. data/app/models/spree/promotion_category.rb +1 -1
  62. data/app/models/spree/promotion_rule_taxon.rb +9 -0
  63. data/app/models/spree/promotion_rule_user.rb +9 -0
  64. data/app/models/spree/property.rb +2 -1
  65. data/app/models/spree/property_prototype.rb +9 -0
  66. data/app/models/spree/prototype.rb +8 -3
  67. data/app/models/spree/prototype_taxon.rb +9 -0
  68. data/app/models/spree/refund.rb +10 -7
  69. data/app/models/spree/refund_reason.rb +1 -1
  70. data/app/models/spree/reimbursement.rb +12 -16
  71. data/app/models/spree/reimbursement_type/reimbursement_helpers.rb +23 -6
  72. data/app/models/spree/reimbursement_type/store_credit.rb +28 -0
  73. data/app/models/spree/return_authorization.rb +8 -13
  74. data/app/models/spree/return_authorization_reason.rb +1 -1
  75. data/app/models/spree/return_item.rb +13 -12
  76. data/app/models/spree/return_item/eligibility_validator/time_since_purchase.rb +1 -1
  77. data/app/models/spree/role.rb +3 -2
  78. data/app/models/spree/role_user.rb +6 -0
  79. data/app/models/spree/shipment.rb +18 -23
  80. data/app/models/spree/shipment_handler.rb +2 -2
  81. data/app/models/spree/shipping_category.rb +6 -3
  82. data/app/models/spree/shipping_method.rb +11 -10
  83. data/app/models/spree/shipping_method_zone.rb +6 -0
  84. data/app/models/spree/shipping_rate.rb +16 -29
  85. data/app/models/spree/state.rb +3 -2
  86. data/app/models/spree/state_change.rb +1 -1
  87. data/app/models/spree/stock/content_item.rb +10 -12
  88. data/app/models/spree/stock/coordinator.rb +13 -14
  89. data/app/models/spree/stock/estimator.rb +28 -30
  90. data/app/models/spree/stock/inventory_unit_builder.rb +1 -9
  91. data/app/models/spree/stock/packer.rb +1 -1
  92. data/app/models/spree/stock/quantifier.rb +5 -5
  93. data/app/models/spree/stock/splitter/backordered.rb +2 -2
  94. data/app/models/spree/stock_item.rb +12 -18
  95. data/app/models/spree/stock_location.rb +4 -7
  96. data/app/models/spree/stock_movement.rb +11 -9
  97. data/app/models/spree/stock_transfer.rb +11 -12
  98. data/app/models/spree/store.rb +14 -6
  99. data/app/models/spree/store_credit.rb +252 -0
  100. data/app/models/spree/store_credit_category.rb +22 -0
  101. data/app/models/spree/store_credit_event.rb +38 -0
  102. data/app/models/spree/store_credit_type.rb +6 -0
  103. data/app/models/spree/tax_category.rb +3 -8
  104. data/app/models/spree/tax_rate.rb +56 -122
  105. data/app/models/spree/taxon.rb +11 -5
  106. data/app/models/spree/tracker.rb +12 -1
  107. data/app/models/spree/validations/db_maximum_length_validator.rb +2 -1
  108. data/app/models/spree/variant.rb +82 -50
  109. data/app/models/spree/zone.rb +21 -17
  110. data/app/models/spree/zone_member.rb +6 -0
  111. data/app/validators/db_maximum_length_validator.rb +11 -0
  112. data/app/views/layouts/spree/base_mailer.html.erb +38 -781
  113. data/app/views/spree/order_mailer/_adjustment.html.erb +8 -0
  114. data/app/views/spree/order_mailer/_subtotal.html.erb +8 -0
  115. data/app/views/spree/order_mailer/_total.html.erb +8 -0
  116. data/app/views/spree/order_mailer/cancel_email.html.erb +13 -28
  117. data/app/views/spree/order_mailer/cancel_email.text.erb +1 -1
  118. data/app/views/spree/order_mailer/confirm_email.html.erb +49 -63
  119. data/app/views/spree/order_mailer/confirm_email.text.erb +1 -1
  120. data/app/views/spree/shared/_base_mailer_header.html.erb +5 -7
  121. data/app/views/spree/shared/_base_mailer_stylesheets.html.erb +777 -0
  122. data/app/views/spree/shared/_error_messages.html.erb +1 -1
  123. data/app/views/spree/shared/_mailer_line_item.html.erb +12 -0
  124. data/app/views/spree/shipment_mailer/shipped_email.html.erb +21 -14
  125. data/app/views/spree/shipment_mailer/shipped_email.text.erb +3 -3
  126. data/config/initializers/user_class_extensions.rb +7 -38
  127. data/config/locales/en.yml +113 -13
  128. data/config/routes.rb +7 -0
  129. data/db/default/spree/default_reimbursement_type.rb +1 -1
  130. data/db/default/spree/zones.rb +4 -5
  131. data/db/migrate/20150118210639_create_spree_store_credits.rb +24 -0
  132. data/db/migrate/20150118211500_create_spree_store_credit_categories.rb +8 -0
  133. data/db/migrate/20150118212051_create_spree_store_credit_events.rb +17 -0
  134. data/db/migrate/20150118212101_create_spree_store_credit_types.rb +10 -0
  135. data/db/migrate/20150314013438_add_missing_indexes.rb +25 -0
  136. data/db/migrate/20150317174308_remove_duplicated_indexes_from_multi_columns.rb +18 -0
  137. data/db/migrate/20150324104002_remove_user_index_from_spree_state_changes.rb +14 -0
  138. data/db/migrate/20150522071831_add_position_to_spree_payment_methods.rb +5 -0
  139. data/db/migrate/20150626181949_add_taxable_adjustment_total_to_line_item.rb +19 -0
  140. data/db/migrate/20150627090949_migrate_payment_methods_display.rb +12 -0
  141. data/db/migrate/20150714154102_spree_payment_method_store_credits.rb +12 -0
  142. data/db/migrate/20150726141425_rename_has_and_belongs_to_associations_to_model_names.rb +18 -0
  143. data/db/migrate/20150727191614_spree_store_credit_types.rb +11 -0
  144. data/db/migrate/20150819154308_add_discontinued_to_products_and_variants.rb +68 -0
  145. data/db/migrate/20151220072838_remove_shipping_method_id_from_spree_orders.rb +13 -0
  146. data/db/migrate/20160207191757_add_id_column_to_earlier_habtm_tables.rb +16 -0
  147. data/db/migrate/20160219165458_add_indexes.rb +14 -0
  148. data/lib/generators/spree/dummy/templates/rails/database.yml +31 -24
  149. data/lib/generators/spree/dummy/templates/rails/test.rb +2 -1
  150. data/lib/spree/core.rb +16 -0
  151. data/lib/spree/core/controller_helpers/auth.rb +1 -1
  152. data/lib/spree/core/controller_helpers/common.rb +3 -3
  153. data/lib/spree/core/controller_helpers/order.rb +6 -5
  154. data/lib/spree/core/controller_helpers/search.rb +1 -1
  155. data/lib/spree/core/controller_helpers/store.rb +29 -0
  156. data/lib/spree/core/delegate_belongs_to.rb +2 -2
  157. data/lib/spree/core/engine.rb +30 -25
  158. data/lib/spree/core/environment.rb +1 -1
  159. data/lib/spree/core/importer/order.rb +37 -40
  160. data/lib/spree/core/number_generator.rb +52 -0
  161. data/lib/spree/core/product_filters.rb +1 -1
  162. data/lib/spree/core/search/base.rb +4 -3
  163. data/lib/spree/core/version.rb +1 -1
  164. data/lib/spree/localized_number.rb +3 -1
  165. data/lib/spree/permitted_attributes.rb +5 -2
  166. data/lib/spree/testing_support/common_rake.rb +3 -3
  167. data/lib/spree/testing_support/factories.rb +3 -3
  168. data/lib/spree/testing_support/factories/address_factory.rb +1 -1
  169. data/lib/spree/testing_support/factories/country_factory.rb +2 -2
  170. data/lib/spree/testing_support/factories/order_factory.rb +2 -2
  171. data/lib/spree/testing_support/factories/payment_factory.rb +5 -0
  172. data/lib/spree/testing_support/factories/payment_method_factory.rb +8 -0
  173. data/lib/spree/testing_support/factories/promotion_rule_factory.rb +5 -0
  174. data/lib/spree/testing_support/factories/refund_factory.rb +9 -1
  175. data/lib/spree/testing_support/factories/return_authorization_factory.rb +2 -0
  176. data/lib/spree/testing_support/factories/state_factory.rb +2 -2
  177. data/lib/spree/testing_support/factories/store_credit_category_factory.rb +9 -0
  178. data/lib/spree/testing_support/factories/store_credit_event_factory.rb +8 -0
  179. data/lib/spree/testing_support/factories/store_credit_factory.rb +17 -0
  180. data/lib/spree/testing_support/factories/store_credit_type_factory.rb +11 -0
  181. data/lib/spree/testing_support/factories/user_factory.rb +1 -1
  182. data/lib/spree/testing_support/factories/zone_member_factory.rb +6 -0
  183. data/lib/spree/testing_support/microdata.rb +189 -0
  184. data/lib/tasks/core.rake +68 -0
  185. data/lib/tasks/exchanges.rake +2 -2
  186. data/spec/fixtures/microdata.html +22 -0
  187. data/spec/fixtures/microdata_itemref.html +15 -0
  188. data/spec/fixtures/microdata_no_itemscope.html +20 -0
  189. data/spec/helpers/base_helper_spec.rb +64 -1
  190. data/spec/helpers/products_helper_spec.rb +75 -3
  191. data/spec/lib/i18n_spec.rb +2 -2
  192. data/spec/lib/search/base_spec.rb +2 -2
  193. data/spec/lib/spree/core/controller_helpers/auth_spec.rb +4 -2
  194. data/spec/lib/spree/core/controller_helpers/store_spec.rb +56 -0
  195. data/spec/lib/spree/core/importer/order_spec.rb +226 -123
  196. data/spec/lib/spree/core/number_generator_spec.rb +175 -0
  197. data/spec/lib/spree/core_spec.rb +23 -0
  198. data/spec/lib/spree/localized_number_spec.rb +10 -0
  199. data/spec/mailers/order_mailer_spec.rb +11 -13
  200. data/spec/mailers/shipment_mailer_spec.rb +26 -8
  201. data/spec/mailers/test_mailer_spec.rb +15 -1
  202. data/spec/models/option_type_prototype_spec.rb +9 -0
  203. data/spec/models/spree/ability_spec.rb +6 -13
  204. data/spec/models/spree/address_spec.rb +1 -1
  205. data/spec/models/spree/adjustable/adjuster/base_spec.rb +10 -0
  206. data/spec/models/spree/adjustable/adjuster/promotion_spec.rb +211 -0
  207. data/spec/models/spree/adjustable/adjuster/tax_spec.rb +86 -0
  208. data/spec/models/spree/adjustable/adjustments_updater_spec.rb +2 -262
  209. data/spec/models/spree/adjustment_spec.rb +27 -1
  210. data/spec/models/spree/app_configuration_spec.rb +5 -2
  211. data/spec/models/spree/calculator/default_tax_spec.rb +39 -14
  212. data/spec/models/spree/concerns/user_methods_spec.rb +55 -0
  213. data/spec/models/spree/concerns/vat_price_calculation_spec.rb +66 -0
  214. data/spec/models/spree/country_spec.rb +45 -8
  215. data/spec/models/spree/credit_card_spec.rb +8 -8
  216. data/spec/models/spree/customer_return_spec.rb +4 -26
  217. data/spec/models/spree/gateway_spec.rb +7 -0
  218. data/spec/models/spree/image_spec.rb +3 -0
  219. data/spec/models/spree/inventory_unit_spec.rb +1 -18
  220. data/spec/models/spree/line_item_spec.rb +78 -18
  221. data/spec/models/spree/option_type_spec.rb +2 -2
  222. data/spec/models/spree/option_value_spec.rb +8 -3
  223. data/spec/models/spree/order/checkout_spec.rb +49 -39
  224. data/spec/models/spree/order/currency_updater_spec.rb +3 -3
  225. data/spec/models/spree/order/finalizing_spec.rb +0 -3
  226. data/spec/models/spree/order/payment_spec.rb +1 -1
  227. data/spec/models/spree/order/state_machine_spec.rb +1 -6
  228. data/spec/models/spree/order/store_credit_spec.rb +423 -0
  229. data/spec/models/spree/order/updating_spec.rb +2 -2
  230. data/spec/models/spree/order_contents_spec.rb +42 -1
  231. data/spec/models/spree/order_inventory_spec.rb +27 -17
  232. data/spec/models/spree/order_spec.rb +65 -52
  233. data/spec/models/spree/payment/gateway_options_spec.rb +10 -2
  234. data/spec/models/spree/payment/store_credit_spec.rb +60 -0
  235. data/spec/models/spree/payment_method/store_credit_spec.rb +291 -0
  236. data/spec/models/spree/payment_method_spec.rb +22 -14
  237. data/spec/models/spree/payment_spec.rb +37 -44
  238. data/spec/models/spree/price_spec.rb +86 -0
  239. data/spec/models/spree/product/scopes_spec.rb +35 -0
  240. data/spec/models/spree/product_option_type_spec.rb +6 -2
  241. data/spec/models/spree/product_promotion_rule_spec.rb +9 -0
  242. data/spec/models/spree/product_property_spec.rb +11 -0
  243. data/spec/models/spree/product_spec.rb +82 -15
  244. data/spec/models/spree/promotion/actions/create_item_adjustments_spec.rb +1 -1
  245. data/spec/models/spree/promotion/rules/user_spec.rb +8 -0
  246. data/spec/models/spree/promotion_action_spec.rb +1 -1
  247. data/spec/models/spree/promotion_rule_spec.rb +1 -1
  248. data/spec/models/spree/promotion_rule_taxon_spec.rb +9 -0
  249. data/spec/models/spree/promotion_rule_user_spec.rb +9 -0
  250. data/spec/models/spree/promotion_spec.rb +57 -36
  251. data/spec/models/spree/property_prototype_spec.rb +9 -0
  252. data/spec/models/spree/prototype_taxon_spec.rb +9 -0
  253. data/spec/models/spree/refund_reason_spec.rb +7 -0
  254. data/spec/models/spree/reimbursement_spec.rb +3 -30
  255. data/spec/models/spree/reimbursement_tax_calculator_spec.rb +17 -5
  256. data/spec/models/spree/reimbursement_type/store_credit_spec.rb +101 -0
  257. data/spec/models/spree/return_authorization_reason_spec.rb +7 -0
  258. data/spec/models/spree/return_authorization_spec.rb +2 -22
  259. data/spec/models/spree/return_item_spec.rb +50 -1
  260. data/spec/models/spree/returns_calculator_spec.rb +1 -1
  261. data/spec/models/spree/role_spec.rb +7 -0
  262. data/spec/models/spree/shipment_spec.rb +17 -17
  263. data/spec/models/spree/shipping_calculator_spec.rb +2 -2
  264. data/spec/models/spree/shipping_category_spec.rb +14 -0
  265. data/spec/models/spree/shipping_method_spec.rb +9 -2
  266. data/spec/models/spree/shipping_rate_spec.rb +40 -41
  267. data/spec/models/spree/state_spec.rb +12 -1
  268. data/spec/models/spree/stock/content_item_spec.rb +9 -0
  269. data/spec/models/spree/stock/estimator_spec.rb +56 -8
  270. data/spec/models/spree/stock/quantifier_spec.rb +61 -32
  271. data/spec/models/spree/stock_item_spec.rb +19 -1
  272. data/spec/models/spree/store_credit_event_spec.rb +101 -0
  273. data/spec/models/spree/store_credit_spec.rb +786 -0
  274. data/spec/models/spree/store_spec.rb +39 -11
  275. data/spec/models/spree/tax_category_spec.rb +6 -1
  276. data/spec/models/spree/tax_rate_spec.rb +204 -44
  277. data/spec/models/spree/user_spec.rb +105 -38
  278. data/spec/models/spree/variant_spec.rb +281 -9
  279. data/spec/models/spree/zone_member_spec.rb +38 -0
  280. data/spec/models/spree/zone_spec.rb +32 -8
  281. data/spec/spec_helper.rb +3 -0
  282. data/spec/support/concerns/{adjustment_source_spec.rb → adjustment_source.rb} +0 -0
  283. data/spec/support/concerns/{default_price_spec.rb → default_price.rb} +9 -0
  284. data/spec/validators/db_maximum_length_validator_spec.rb +22 -0
  285. data/spree_core.gemspec +5 -6
  286. metadata +99 -36
  287. data/CHANGELOG.md +0 -4
  288. data/app/models/concerns/spree/number_generator.rb +0 -39
  289. data/spec/models/spree/validations/db_maximum_length_validator_spec.rb +0 -24
@@ -8,11 +8,37 @@ describe Spree::Adjustment, :type => :model do
8
8
  let(:order) { Spree::Order.new }
9
9
 
10
10
  before do
11
- allow(order).to receive(:update!)
11
+ allow(order).to receive(:update_with_updater!)
12
12
  end
13
13
 
14
14
  let(:adjustment) { Spree::Adjustment.create!(label: 'Adjustment', adjustable: order, order: order, amount: 5) }
15
15
 
16
+ describe 'scopes' do
17
+ describe '.for_complete_order' do
18
+ let(:complete_order) { Spree::Order.create! completed_at: Time.current }
19
+ let(:incomplete_order) { Spree::Order.create! completed_at: nil }
20
+ let(:adjustment_for_complete_order) { Spree::Adjustment.create!(label: 'Adjustment', adjustable: complete_order, order: complete_order, amount: 5) }
21
+ let(:adjustment_for_incomplete_order) { Spree::Adjustment.create!(label: 'Adjustment', adjustable: incomplete_order, order: incomplete_order, amount: 5) }
22
+
23
+ subject { Spree::Adjustment.for_complete_order }
24
+
25
+ it { is_expected.to include(adjustment_for_complete_order) }
26
+ it { is_expected.to_not include(adjustment_for_incomplete_order) }
27
+ end
28
+
29
+ describe '.for_incomplete_order' do
30
+ let(:complete_order) { Spree::Order.create! completed_at: Time.current }
31
+ let(:incomplete_order) { Spree::Order.create! completed_at: nil }
32
+ let(:adjustment_for_complete_order) { Spree::Adjustment.create!(label: 'Adjustment', adjustable: complete_order, order: complete_order, amount: 5) }
33
+ let(:adjustment_for_incomplete_order) { Spree::Adjustment.create!(label: 'Adjustment', adjustable: incomplete_order, order: incomplete_order, amount: 5) }
34
+
35
+ subject { Spree::Adjustment.for_incomplete_order }
36
+
37
+ it { is_expected.to_not include(adjustment_for_complete_order) }
38
+ it { is_expected.to include(adjustment_for_incomplete_order) }
39
+ end
40
+ end
41
+
16
42
  context '#create & #destroy' do
17
43
  let(:adjustment) { Spree::Adjustment.new(label: "Adjustment", amount: 5, order: order, adjustable: create(:line_item)) }
18
44
 
@@ -1,7 +1,6 @@
1
1
  require 'spec_helper'
2
2
 
3
3
  describe Spree::AppConfiguration, :type => :model do
4
-
5
4
  let (:prefs) { Rails.application.config.spree.preferences }
6
5
 
7
6
  it "should be available from the environment" do
@@ -19,5 +18,9 @@ describe Spree::AppConfiguration, :type => :model do
19
18
  expect(prefs.searcher_class).to eq Spree::Core::Search::Base
20
19
  end
21
20
 
21
+ describe 'admin_path' do
22
+ it { expect(Spree::Config).to have_preference(:admin_path) }
23
+ it { expect(Spree::Config.preferred_admin_path_type).to eq(:string) }
24
+ it { expect(Spree::Config.preferred_admin_path_default).to eq('/admin') }
25
+ end
22
26
  end
23
-
@@ -1,23 +1,23 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spree::Calculator::DefaultTax, :type => :model do
3
+ describe Spree::Calculator::DefaultTax, type: :model do
4
4
  let!(:country) { create(:country) }
5
- let!(:zone) { create(:zone, :name => "Country Zone", :default_tax => true, :zone_members => []) }
6
- let!(:tax_category) { create(:tax_category, :tax_rates => []) }
7
- let!(:rate) { create(:tax_rate, :tax_category => tax_category, :amount => 0.05, :included_in_price => included_in_price) }
5
+ let!(:zone) { create(:zone, name: "Country Zone", default_tax: true, zone_members: []) }
6
+ let!(:tax_category) { create(:tax_category, tax_rates: []) }
7
+ let!(:rate) { create(:tax_rate, tax_category: tax_category, amount: 0.05, included_in_price: included_in_price) }
8
8
  let(:included_in_price) { false }
9
- let!(:calculator) { Spree::Calculator::DefaultTax.new(:calculable => rate ) }
9
+ let!(:calculator) { Spree::Calculator::DefaultTax.new(calculable: rate) }
10
10
  let!(:order) { create(:order) }
11
- let!(:line_item) { create(:line_item, :price => 10, :quantity => 3, :tax_category => tax_category) }
12
- let!(:shipment) { create(:shipment, :cost => 15) }
11
+ let!(:line_item) { create(:line_item, price: 10, quantity: 3, tax_category: tax_category) }
12
+ let!(:shipment) { create(:shipment, cost: 15) }
13
13
 
14
14
  context "#compute" do
15
15
  context "when given an order" do
16
16
  let!(:line_item_1) { line_item }
17
- let!(:line_item_2) { create(:line_item, :price => 10, :quantity => 3, :tax_category => tax_category) }
17
+ let!(:line_item_2) { create(:line_item, price: 10, quantity: 3, tax_category: tax_category) }
18
18
 
19
19
  before do
20
- allow(order).to receive_messages :line_items => [line_item_1, line_item_2]
20
+ allow(order).to receive_messages line_items: [line_item_1, line_item_2]
21
21
  end
22
22
 
23
23
  context "when no line items match the tax category" do
@@ -51,7 +51,6 @@ describe Spree::Calculator::DefaultTax, :type => :model do
51
51
  # Amount is 0.51665, which will be rounded to...
52
52
  expect(calculator.compute(order)).to eq(0.52)
53
53
  end
54
-
55
54
  end
56
55
  end
57
56
 
@@ -77,10 +76,9 @@ describe Spree::Calculator::DefaultTax, :type => :model do
77
76
  context "when tax is included in price" do
78
77
  let(:included_in_price) { true }
79
78
  context "when the variant matches the tax category" do
80
-
81
79
  context "when line item is discounted" do
82
80
  before do
83
- line_item.promo_total = -1
81
+ line_item.taxable_adjustment_total = -1
84
82
  Spree::TaxRate.store_pre_tax_amount(line_item, [rate])
85
83
  end
86
84
 
@@ -88,7 +86,6 @@ describe Spree::Calculator::DefaultTax, :type => :model do
88
86
  expect(calculator.compute(line_item)).to eql 1.38
89
87
  end
90
88
  end
91
-
92
89
  it "should be equal to the item's full price * rate" do
93
90
  Spree::TaxRate.store_pre_tax_amount(line_item, [rate])
94
91
  expect(calculator.compute(line_item)).to eql 1.43
@@ -98,7 +95,7 @@ describe Spree::Calculator::DefaultTax, :type => :model do
98
95
 
99
96
  context "when tax is not included in price" do
100
97
  context "when the line item is discounted" do
101
- before { line_item.promo_total = -1 }
98
+ before { line_item.taxable_adjustment_total = -1 }
102
99
 
103
100
  it "should be equal to the item's pre-tax total * rate" do
104
101
  expect(calculator.compute(line_item)).to eq(1.45)
@@ -124,4 +121,32 @@ describe Spree::Calculator::DefaultTax, :type => :model do
124
121
  end
125
122
  end
126
123
  end
124
+
125
+ context "when given a line_item" do
126
+ let(:rate) { create(:tax_rate, amount: 0.07, included_in_price: true) }
127
+ let(:line_item) { create(:line_item, quantity: 50, price: 8.50) }
128
+
129
+ subject do
130
+ Spree::Calculator::DefaultTax.new(calculable: rate).
131
+ compute_line_item(line_item)
132
+ end
133
+
134
+ describe "#compute_line_item" do
135
+ it "computes the line item right" do
136
+ Spree::TaxRate.store_pre_tax_amount(line_item, [rate])
137
+ expect(subject).to eq(27.80)
138
+ end
139
+
140
+ context "with a 40$ promo" do
141
+ before do
142
+ allow(line_item).to receive(:taxable_adjustment_total).and_return(BigDecimal.new("-40"))
143
+ Spree::TaxRate.store_pre_tax_amount(line_item, [rate])
144
+ end
145
+
146
+ it "computes the line item right" do
147
+ expect(subject).to eq(25.19)
148
+ end
149
+ end
150
+ end
151
+ end
127
152
  end
@@ -0,0 +1,55 @@
1
+ require 'spec_helper'
2
+
3
+ describe Spree::UserMethods do
4
+ let(:test_user) { create :user }
5
+
6
+ describe 'Associations' do
7
+ subject { test_user }
8
+
9
+ it 'should have many promotion_rule_users' do
10
+ is_expected.to have_many(:promotion_rule_users).with_foreign_key(:user_id).
11
+ class_name('Spree::PromotionRuleUser').dependent(:destroy)
12
+ end
13
+
14
+ it 'should have many role_users' do
15
+ is_expected.to have_many(:role_users).class_name('Spree::RoleUser').
16
+ with_foreign_key(:user_id).dependent(:destroy)
17
+ end
18
+ end
19
+
20
+ describe '#has_spree_role?' do
21
+ subject { test_user.has_spree_role? name }
22
+
23
+ let(:role) { Spree::Role.create(name: name) }
24
+ let(:name) { 'test' }
25
+
26
+ context 'with a role' do
27
+ before { test_user.spree_roles << role }
28
+ it { is_expected.to be_truthy }
29
+ end
30
+
31
+ context 'without a role' do
32
+ it { is_expected.to be_falsy }
33
+ end
34
+ end
35
+
36
+ describe '#last_incomplete_spree_order' do
37
+ subject { test_user.last_incomplete_spree_order }
38
+
39
+ context 'with an incomplete order' do
40
+ let(:last_incomplete_order) { create :order, user: test_user }
41
+
42
+ before do
43
+ create(:order, user: test_user, created_at: 1.day.ago)
44
+ create(:order, user: create(:user))
45
+ last_incomplete_order
46
+ end
47
+
48
+ it { is_expected.to eq last_incomplete_order }
49
+ end
50
+
51
+ context 'without an incomplete order' do
52
+ it { is_expected.to be_nil }
53
+ end
54
+ end
55
+ end
@@ -0,0 +1,66 @@
1
+ require "spec_helper"
2
+
3
+ module Spree
4
+ describe VatPriceCalculation do
5
+ let(:test_class) do
6
+ Class.new do
7
+ include VatPriceCalculation
8
+ def total; 10.0; end
9
+ end
10
+ end
11
+
12
+ describe "#gross_amount" do
13
+ let(:zone) { Zone.new }
14
+ let(:tax_category) { TaxCategory.new }
15
+ let(:price_options) do
16
+ {
17
+ tax_zone: zone,
18
+ tax_category: tax_category
19
+ }
20
+ end
21
+ let(:amount) { 100 }
22
+
23
+ subject(:gross_amount) { test_class.new.gross_amount(amount, price_options) }
24
+
25
+ context "with no default zone set" do
26
+ it "does not call TaxRate.included_tax_amount_for" do
27
+ expect(TaxRate).not_to receive(:included_tax_amount_for)
28
+ gross_amount
29
+ end
30
+ end
31
+
32
+ context "with no zone given" do
33
+ let(:zone) { nil }
34
+ it "does not call TaxRate.included_tax_amount_for" do
35
+ expect(TaxRate).not_to receive(:included_tax_amount_for)
36
+ gross_amount
37
+ end
38
+ end
39
+
40
+ context "with a default zone set" do
41
+ let(:default_zone) { Spree::Zone.new }
42
+ before do
43
+ allow(Spree::Zone).to receive(:default_tax).and_return(default_zone)
44
+ end
45
+
46
+ context "and zone equal to the default zone" do
47
+ let(:zone) { default_zone }
48
+
49
+ it "does not call 'TaxRate.included_tax_amount_for'" do
50
+ expect(TaxRate).not_to receive(:included_tax_amount_for)
51
+ gross_amount
52
+ end
53
+ end
54
+
55
+ context "and zone not equal to default zone" do
56
+ let(:zone) { Spree::Zone.new }
57
+
58
+ it "calls TaxRate.included_tax_amount_for two times" do
59
+ expect(TaxRate).to receive(:included_tax_amount_for).twice
60
+ gross_amount
61
+ end
62
+ end
63
+ end
64
+ end
65
+ end
66
+ end
@@ -1,18 +1,55 @@
1
1
  require 'spec_helper'
2
2
 
3
3
  describe Spree::Country, type: :model do
4
+ let(:america) { create :country }
5
+ let(:canada) { create :country, name: 'Canada', iso_name: 'CANADA', numcode: '124' }
6
+
7
+ describe 'Callbacks' do
8
+ it { is_expected.to callback(:ensure_not_default).before(:destroy) }
9
+ end
10
+
11
+ describe 'Associations' do
12
+ it { is_expected.to have_many(:addresses).dependent(:restrict_with_error) }
13
+ end
14
+
15
+ describe 'Validations' do
16
+ it { is_expected.to validate_presence_of(:name) }
17
+ it { is_expected.to validate_presence_of(:iso_name) }
18
+ it { is_expected.to validate_uniqueness_of(:iso_name).case_insensitive }
19
+ it { is_expected.to validate_uniqueness_of(:name).case_insensitive }
20
+ end
21
+
4
22
  describe '.default' do
5
- let(:america) { create :country }
6
- let(:canada) { create :country, name: 'Canada' }
23
+ context 'when default_country_id config is set' do
24
+ before { Spree::Config[:default_country_id] = canada.id }
25
+ it 'will return the country from the config' do
26
+ expect(described_class.default.id).to eql canada.id
27
+ end
28
+ end
29
+
30
+ context 'config is not set though record for america exists' do
31
+ before { america.touch }
32
+ it 'will return the US' do
33
+ expect(described_class.default.id).to eql america.id
34
+ end
35
+ end
36
+ end
37
+
38
+ describe 'ensure default country in not deleted' do
39
+ before { Spree::Config[:default_country_id] = america.id }
40
+
41
+ context 'will not destroy country if it is default' do
42
+ subject { america.destroy }
43
+ it { is_expected.to be_falsy }
7
44
 
8
- it 'will return the country from the config' do
9
- Spree::Config[:default_country_id] = canada.id
10
- expect(described_class.default.id).to eql canada.id
45
+ context 'error should be default country cannot be deleted' do
46
+ before { subject }
47
+ it { expect(america.errors[:base]).to include(Spree.t(:default_country_cannot_be_deleted)) }
48
+ end
11
49
  end
12
50
 
13
- it 'will return the US if config is not set' do
14
- america.touch
15
- expect(described_class.default.id).to eql america.id
51
+ context 'will destroy if it is not a default' do
52
+ it { expect(canada.destroy).to be_truthy }
16
53
  end
17
54
  end
18
55
  end
@@ -5,7 +5,7 @@ describe Spree::CreditCard, type: :model do
5
5
  {
6
6
  number: '4111111111111111',
7
7
  verification_value: '123',
8
- expiry: "12 / #{(Time.now.year + 1).to_s.last(2)}",
8
+ expiry: "12 / #{(Time.current.year + 1).to_s.last(2)}",
9
9
  name: 'Spree Commerce'
10
10
  }
11
11
  end
@@ -42,12 +42,12 @@ describe Spree::CreditCard, type: :model do
42
42
 
43
43
  context "#can_capture?" do
44
44
  it "should be true if payment is pending" do
45
- payment = mock_model(Spree::Payment, pending?: true, created_at: Time.now)
45
+ payment = mock_model(Spree::Payment, pending?: true, created_at: Time.current)
46
46
  expect(credit_card.can_capture?(payment)).to be true
47
47
  end
48
48
 
49
49
  it "should be true if payment is checkout" do
50
- payment = mock_model(Spree::Payment, pending?: false, checkout?: true, created_at: Time.now)
50
+ payment = mock_model(Spree::Payment, pending?: false, checkout?: true, created_at: Time.current)
51
51
  expect(credit_card.can_capture?(payment)).to be true
52
52
  end
53
53
  end
@@ -273,8 +273,8 @@ describe Spree::CreditCard, type: :model do
273
273
  context "#to_active_merchant" do
274
274
  before do
275
275
  credit_card.number = "4111111111111111"
276
- credit_card.year = Time.now.year
277
- credit_card.month = Time.now.month
276
+ credit_card.year = Time.current.year
277
+ credit_card.month = Time.current.month
278
278
  credit_card.name = "Ludwig van Beethoven"
279
279
  credit_card.verification_value = 123
280
280
  end
@@ -282,8 +282,8 @@ describe Spree::CreditCard, type: :model do
282
282
  it "converts to an ActiveMerchant::Billing::CreditCard object" do
283
283
  am_card = credit_card.to_active_merchant
284
284
  expect(am_card.number).to eq("4111111111111111")
285
- expect(am_card.year).to eq(Time.now.year)
286
- expect(am_card.month).to eq(Time.now.month)
285
+ expect(am_card.year).to eq(Time.current.year)
286
+ expect(am_card.month).to eq(Time.current.month)
287
287
  expect(am_card.first_name).to eq("Ludwig")
288
288
  expect(am_card.last_name).to eq("van Beethoven")
289
289
  expect(am_card.verification_value).to eq(123)
@@ -317,7 +317,7 @@ describe Spree::CreditCard, type: :model do
317
317
  user = FactoryGirl.create(:user)
318
318
  first = FactoryGirl.create(:credit_card, user: user, default: true)
319
319
  second = FactoryGirl.create(:credit_card, user: user, default: false)
320
- first.update_columns(year: DateTime.now.year, month: 1.month.ago.month)
320
+ first.update_columns(year: DateTime.current.year, month: 1.month.ago.month)
321
321
 
322
322
  expect { second.update_attributes!(default: true) }.not_to raise_error
323
323
  end
@@ -1,6 +1,6 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Spree::CustomerReturn, :type => :model do
3
+ describe Spree::CustomerReturn, type: :model do
4
4
  before do
5
5
  allow_any_instance_of(Spree::Order).to receive_messages(return!: true)
6
6
  end
@@ -79,30 +79,8 @@ describe Spree::CustomerReturn, :type => :model do
79
79
  end
80
80
  end
81
81
 
82
- describe ".before_create" do
83
- describe "#generate_number" do
84
- context "number is assigned" do
85
- let(:customer_return) { Spree::CustomerReturn.new(number: '123') }
86
-
87
- it "should return the assigned number" do
88
- customer_return.save
89
- expect(customer_return.number).to eq('123')
90
- end
91
- end
92
-
93
- context "number is not assigned" do
94
- let(:customer_return) { Spree::CustomerReturn.new(number: nil) }
95
-
96
- before do
97
- allow(customer_return).to receive_messages(valid?: true, process_return!: true)
98
- end
99
-
100
- it "should assign number with random CR number" do
101
- customer_return.save
102
- expect(customer_return.number).to match(/CR\d{9}/)
103
- end
104
- end
105
- end
82
+ describe 'whitelisted_ransackable_attributes' do
83
+ it { expect(Spree::CustomerReturn.whitelisted_ransackable_attributes).to eq(%w(number)) }
106
84
  end
107
85
 
108
86
  describe "#pre_tax_total" do
@@ -194,7 +172,7 @@ describe Spree::CustomerReturn, :type => :model do
194
172
  end
195
173
 
196
174
  context "to a different stock location" do
197
- let(:new_stock_location) { create(:stock_location, :name => "other") }
175
+ let(:new_stock_location) { create(:stock_location, name: "other") }
198
176
 
199
177
  it "should update the stock item counts in new stock location" do
200
178
  expect {