spree_core 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 (383) hide show
  1. checksums.yaml +4 -4
  2. data/app/models/concerns/spree/named_type.rb +1 -1
  3. data/app/models/concerns/spree/number_as_param.rb +9 -0
  4. data/app/models/concerns/spree/user_address.rb +4 -2
  5. data/app/models/concerns/spree/user_methods.rb +2 -3
  6. data/app/models/spree/ability.rb +1 -2
  7. data/app/models/spree/address.rb +1 -1
  8. data/app/models/spree/base.rb +2 -0
  9. data/app/models/spree/calculator.rb +1 -1
  10. data/app/models/spree/calculator/percent_per_item.rb +4 -3
  11. data/app/models/spree/calculator/returns/default_refund_amount.rb +16 -14
  12. data/app/models/spree/country.rb +1 -1
  13. data/app/models/spree/credit_card.rb +26 -21
  14. data/app/models/spree/customer_return.rb +2 -2
  15. data/app/models/spree/exchange.rb +7 -2
  16. data/app/models/spree/image.rb +1 -1
  17. data/app/models/spree/inventory_unit.rb +39 -3
  18. data/app/models/spree/line_item.rb +2 -7
  19. data/app/models/spree/option_type.rb +1 -1
  20. data/app/models/spree/option_type_prototype.rb +1 -1
  21. data/app/models/spree/option_value.rb +1 -1
  22. data/app/models/spree/option_value_variant.rb +3 -0
  23. data/app/models/spree/order.rb +82 -81
  24. data/app/models/spree/order/checkout.rb +23 -33
  25. data/app/models/spree/order/currency_updater.rb +1 -1
  26. data/app/models/spree/order/payments.rb +1 -1
  27. data/app/models/spree/order/store_credit.rb +6 -1
  28. data/app/models/spree/order_contents.rb +14 -2
  29. data/app/models/spree/order_inventory.rb +64 -60
  30. data/app/models/spree/payment.rb +8 -13
  31. data/app/models/spree/payment/processing.rb +2 -2
  32. data/app/models/spree/payment_method.rb +4 -2
  33. data/app/models/spree/preference.rb +1 -1
  34. data/app/models/spree/preferences/preferable.rb +1 -1
  35. data/app/models/spree/product.rb +1 -1
  36. data/app/models/spree/product/scopes.rb +2 -2
  37. data/app/models/spree/promotion.rb +2 -2
  38. data/app/models/spree/promotion/rules/option_value.rb +13 -5
  39. data/app/models/spree/promotion_rule_user.rb +1 -1
  40. data/app/models/spree/property_prototype.rb +1 -1
  41. data/app/models/spree/prototype_taxon.rb +1 -1
  42. data/app/models/spree/refund.rb +2 -2
  43. data/app/models/spree/reimbursement.rb +2 -1
  44. data/app/models/spree/reimbursement_type.rb +1 -1
  45. data/app/models/spree/return_authorization.rb +1 -0
  46. data/app/models/spree/return_item.rb +35 -9
  47. data/app/models/spree/role.rb +1 -1
  48. data/app/models/spree/role_user.rb +1 -1
  49. data/app/models/spree/shipment.rb +63 -64
  50. data/app/models/spree/shipment_handler.rb +1 -1
  51. data/app/models/spree/shipping_category.rb +1 -1
  52. data/app/models/spree/shipping_method.rb +12 -10
  53. data/app/models/spree/state_change.rb +1 -1
  54. data/app/models/spree/stock/adjuster.rb +35 -14
  55. data/app/models/spree/stock/availability_validator.rb +1 -1
  56. data/app/models/spree/stock/content_item.rb +9 -8
  57. data/app/models/spree/stock/coordinator.rb +3 -9
  58. data/app/models/spree/stock/estimator.rb +1 -1
  59. data/app/models/spree/stock/inventory_unit_builder.rb +10 -9
  60. data/app/models/spree/stock/package.rb +6 -6
  61. data/app/models/spree/stock/packer.rb +8 -15
  62. data/app/models/spree/stock/prioritizer.rb +13 -10
  63. data/app/models/spree/stock/splitter/weight.rb +62 -10
  64. data/app/models/spree/stock_item.rb +42 -29
  65. data/app/models/spree/stock_location.rb +5 -1
  66. data/app/models/spree/stock_movement.rb +1 -2
  67. data/app/models/spree/stock_transfer.rb +2 -3
  68. data/app/models/spree/store.rb +1 -1
  69. data/app/models/spree/store_credit.rb +9 -6
  70. data/app/models/spree/store_credit_category.rb +1 -1
  71. data/app/models/spree/tax_category.rb +1 -1
  72. data/app/models/spree/tax_rate.rb +1 -1
  73. data/app/models/spree/taxon.rb +5 -2
  74. data/app/models/spree/taxonomy.rb +1 -1
  75. data/app/models/spree/tracker.rb +1 -1
  76. data/app/models/spree/variant.rb +4 -3
  77. data/app/models/spree/zone.rb +19 -21
  78. data/app/views/spree/reimbursement_mailer/reimbursement_email.html.erb +61 -0
  79. data/config/locales/en.yml +7 -6
  80. data/db/migrate/20130807024301_upgrade_adjustments.rb +6 -0
  81. data/db/migrate/20130807024302_rename_adjustment_fields.rb +6 -0
  82. data/db/migrate/20161125065505_add_quantity_to_inventory_units.rb +5 -0
  83. data/db/migrate/20170119122701_add_original_return_item_id_to_spree_inventory_units.rb +29 -0
  84. data/db/migrate/20170315152755_add_unique_index_on_number_to_spree_orders.rb +16 -0
  85. data/db/migrate/20170316154338_add_unique_index_on_number_to_spree_stock_transfer.rb +16 -0
  86. data/db/migrate/20170316205511_add_unique_index_on_number_to_spree_shipment.rb +16 -0
  87. data/db/migrate/20170320134043_add_unique_index_on_number_to_spree_payments.rb +17 -0
  88. data/db/migrate/20170320142750_add_unique_index_on_number_to_spree_return_authorizations.rb +16 -0
  89. data/db/migrate/20170320145040_add_unique_index_on_number_to_spree_customer_returns.rb +16 -0
  90. data/db/migrate/20170320145518_add_unique_index_on_number_to_spree_reimbursements.rb +16 -0
  91. data/db/migrate/20170323151450_add_missing_unique_indexes_for_unique_attributes.rb +37 -0
  92. data/db/migrate/20170329110859_add_index_on_stock_location_to_spree_customer_returns.rb +5 -0
  93. data/db/migrate/20170329113917_add_index_on_prototype_to_spree_option_type_prototype.rb +19 -0
  94. data/db/migrate/20170330082155_add_indexes_to_spree_option_value_variant.rb +19 -0
  95. data/db/migrate/20170330132215_add_index_on_promotion_id_to_order_promotions.rb +5 -0
  96. data/db/migrate/20170331101758_add_indexes_for_property_prototype.rb +20 -0
  97. data/db/migrate/20170331103334_add_index_for_prototype_id_to_prototype_taxons.rb +5 -0
  98. data/db/migrate/20170331110454_add_indexes_to_refunds.rb +6 -0
  99. data/db/migrate/20170331111757_add_indexes_to_reimbursement_credits.rb +6 -0
  100. data/db/migrate/20170331115246_add_indexes_to_return_authorizations.rb +6 -0
  101. data/db/migrate/20170331120125_add_indexes_to_return_items.rb +11 -0
  102. data/db/migrate/20170331121725_add_index_to_role_users.rb +18 -0
  103. data/db/migrate/20170331123625_add_index_to_shipping_method_categories.rb +5 -0
  104. data/db/migrate/20170331123832_add_index_to_shipping_method_zones.rb +20 -0
  105. data/db/migrate/20170331124251_add_index_to_spree_shipping_rates.rb +6 -0
  106. data/db/migrate/20170331124513_add_index_to_spree_stock_items.rb +5 -0
  107. data/db/migrate/20170331124924_add_index_to_spree_stock_movement.rb +5 -0
  108. data/db/migrate/20170413211707_change_indexes_on_friendly_id_slugs.rb +10 -0
  109. data/lib/generators/spree/install/install_generator.rb +41 -36
  110. data/lib/spree/core.rb +0 -1
  111. data/lib/spree/core/engine.rb +3 -3
  112. data/lib/spree/core/importer/order.rb +23 -19
  113. data/lib/spree/core/number_generator.rb +3 -5
  114. data/lib/spree/core/product_duplicator.rb +7 -3
  115. data/lib/spree/core/search/base.rb +1 -0
  116. data/lib/spree/core/validators/email.rb +1 -1
  117. data/lib/spree/core/version.rb +1 -1
  118. data/lib/spree/money.rb +1 -15
  119. data/lib/spree/permitted_attributes.rb +1 -1
  120. data/lib/spree/testing_support/common_rake.rb +0 -2
  121. data/lib/spree/testing_support/factories.rb +3 -3
  122. data/lib/spree/testing_support/factories/address_factory.rb +1 -1
  123. data/lib/spree/testing_support/factories/adjustment_factory.rb +1 -1
  124. data/lib/spree/testing_support/factories/calculator_factory.rb +1 -1
  125. data/lib/spree/testing_support/factories/country_factory.rb +1 -1
  126. data/lib/spree/testing_support/factories/credit_card_factory.rb +1 -1
  127. data/lib/spree/testing_support/factories/customer_return_factory.rb +1 -1
  128. data/lib/spree/testing_support/factories/image_factory.rb +1 -1
  129. data/lib/spree/testing_support/factories/inventory_unit_factory.rb +1 -1
  130. data/lib/spree/testing_support/factories/line_item_factory.rb +1 -1
  131. data/lib/spree/testing_support/factories/options_factory.rb +1 -1
  132. data/lib/spree/testing_support/factories/order_factory.rb +7 -1
  133. data/lib/spree/testing_support/factories/payment_factory.rb +1 -1
  134. data/lib/spree/testing_support/factories/payment_method_factory.rb +1 -1
  135. data/lib/spree/testing_support/factories/price_factory.rb +1 -1
  136. data/lib/spree/testing_support/factories/product_factory.rb +1 -1
  137. data/lib/spree/testing_support/factories/product_option_type_factory.rb +1 -1
  138. data/lib/spree/testing_support/factories/product_property_factory.rb +1 -1
  139. data/lib/spree/testing_support/factories/promotion_category_factory.rb +1 -1
  140. data/lib/spree/testing_support/factories/promotion_factory.rb +1 -1
  141. data/lib/spree/testing_support/factories/promotion_rule_factory.rb +1 -1
  142. data/lib/spree/testing_support/factories/property_factory.rb +1 -1
  143. data/lib/spree/testing_support/factories/prototype_factory.rb +1 -1
  144. data/lib/spree/testing_support/factories/refund_factory.rb +1 -1
  145. data/lib/spree/testing_support/factories/reimbursement_factory.rb +1 -1
  146. data/lib/spree/testing_support/factories/reimbursement_type_factory.rb +1 -1
  147. data/lib/spree/testing_support/factories/return_authorization_factory.rb +1 -1
  148. data/lib/spree/testing_support/factories/return_item_factory.rb +1 -1
  149. data/lib/spree/testing_support/factories/role_factory.rb +1 -1
  150. data/lib/spree/testing_support/factories/shipment_factory.rb +1 -1
  151. data/lib/spree/testing_support/factories/shipping_category_factory.rb +1 -1
  152. data/lib/spree/testing_support/factories/shipping_method_factory.rb +2 -1
  153. data/lib/spree/testing_support/factories/state_factory.rb +1 -1
  154. data/lib/spree/testing_support/factories/stock_factory.rb +1 -1
  155. data/lib/spree/testing_support/factories/stock_item_factory.rb +1 -1
  156. data/lib/spree/testing_support/factories/stock_location_factory.rb +1 -1
  157. data/lib/spree/testing_support/factories/stock_movement_factory.rb +1 -1
  158. data/lib/spree/testing_support/factories/store_credit_category_factory.rb +1 -1
  159. data/lib/spree/testing_support/factories/store_credit_event_factory.rb +1 -1
  160. data/lib/spree/testing_support/factories/store_credit_factory.rb +1 -1
  161. data/lib/spree/testing_support/factories/store_credit_type_factory.rb +1 -1
  162. data/lib/spree/testing_support/factories/store_factory.rb +1 -1
  163. data/lib/spree/testing_support/factories/tag_factory.rb +1 -1
  164. data/lib/spree/testing_support/factories/tax_category_factory.rb +1 -1
  165. data/lib/spree/testing_support/factories/tax_rate_factory.rb +1 -1
  166. data/lib/spree/testing_support/factories/taxon_factory.rb +2 -2
  167. data/lib/spree/testing_support/factories/taxonomy_factory.rb +2 -2
  168. data/lib/spree/testing_support/factories/tracker_factory.rb +1 -1
  169. data/lib/spree/testing_support/factories/user_factory.rb +1 -1
  170. data/lib/spree/testing_support/factories/variant_factory.rb +1 -1
  171. data/lib/spree/testing_support/factories/zone_factory.rb +1 -1
  172. data/lib/spree/testing_support/factories/zone_member_factory.rb +1 -1
  173. data/lib/spree/testing_support/microdata.rb +3 -0
  174. data/lib/spree/testing_support/order_walkthrough.rb +9 -9
  175. data/lib/tasks/exchanges.rake +8 -10
  176. data/spec/helpers/base_helper_spec.rb +200 -0
  177. data/spec/helpers/products_helper_spec.rb +289 -0
  178. data/spec/lib/calculated_adjustments_spec.rb +7 -0
  179. data/spec/lib/i18n_spec.rb +123 -0
  180. data/spec/lib/search/base_spec.rb +86 -0
  181. data/spec/lib/spree/core/controller_helpers/auth_spec.rb +103 -0
  182. data/spec/lib/spree/core/controller_helpers/order_spec.rb +110 -0
  183. data/spec/lib/spree/core/controller_helpers/search_spec.rb +17 -0
  184. data/spec/lib/spree/core/controller_helpers/store_spec.rb +72 -0
  185. data/spec/lib/spree/core/controller_helpers/strong_parameters_spec.rb +39 -0
  186. data/spec/lib/spree/core/delegate_belongs_to_spec.rb +22 -0
  187. data/spec/lib/spree/core/importer/order_spec.rb +607 -0
  188. data/spec/lib/spree/core/number_generator_spec.rb +139 -0
  189. data/spec/lib/spree/core/token_generator_spec.rb +24 -0
  190. data/spec/lib/spree/core/validators/email_spec.rb +54 -0
  191. data/spec/lib/spree/core_spec.rb +23 -0
  192. data/spec/lib/spree/localized_number_spec.rb +54 -0
  193. data/spec/lib/spree/migrations_spec.rb +36 -0
  194. data/spec/lib/spree/money_spec.rb +122 -0
  195. data/spec/lib/tasks/exchanges_spec.rb +136 -0
  196. data/spec/mailers/order_mailer_spec.rb +122 -0
  197. data/spec/mailers/reimbursement_mailer_spec.rb +52 -0
  198. data/spec/mailers/shipment_mailer_spec.rb +81 -0
  199. data/spec/mailers/test_mailer_spec.rb +38 -0
  200. data/spec/models/spree/ability_spec.rb +251 -0
  201. data/spec/models/spree/address_spec.rb +402 -0
  202. data/spec/models/spree/adjustable/adjuster/base_spec.rb +10 -0
  203. data/spec/models/spree/adjustable/adjuster/promotion_spec.rb +211 -0
  204. data/spec/models/spree/adjustable/adjuster/tax_spec.rb +86 -0
  205. data/spec/models/spree/adjustable/adjustments_updater_spec.rb +26 -0
  206. data/spec/models/spree/adjustment_spec.rb +189 -0
  207. data/spec/models/spree/app_configuration_spec.rb +26 -0
  208. data/spec/models/spree/asset_spec.rb +28 -0
  209. data/spec/models/spree/calculator/default_tax_spec.rb +152 -0
  210. data/spec/models/spree/calculator/flat_percent_item_total_spec.rb +25 -0
  211. data/spec/models/spree/calculator/flat_rate_spec.rb +47 -0
  212. data/spec/models/spree/calculator/flexi_rate_spec.rb +41 -0
  213. data/spec/models/spree/calculator/percent_on_line_item_spec.rb +15 -0
  214. data/spec/models/spree/calculator/price_sack_spec.rb +30 -0
  215. data/spec/models/spree/calculator/refunds/default_refund_amount_spec.rb +47 -0
  216. data/spec/models/spree/calculator/shipping.rb +8 -0
  217. data/spec/models/spree/calculator/shipping/flat_percent_item_total_spec.rb +23 -0
  218. data/spec/models/spree/calculator/shipping/flat_rate_spec.rb +13 -0
  219. data/spec/models/spree/calculator/shipping/flexi_rate_spec.rb +52 -0
  220. data/spec/models/spree/calculator/shipping/per_item_spec.rb +20 -0
  221. data/spec/models/spree/calculator/shipping/price_sack_spec.rb +29 -0
  222. data/spec/models/spree/calculator/tiered_flat_rate_spec.rb +40 -0
  223. data/spec/models/spree/calculator/tiered_percent_spec.rb +51 -0
  224. data/spec/models/spree/calculator_spec.rb +69 -0
  225. data/spec/models/spree/classification_spec.rb +93 -0
  226. data/spec/models/spree/concerns/display_money_spec.rb +43 -0
  227. data/spec/models/spree/concerns/user_methods_spec.rb +82 -0
  228. data/spec/models/spree/concerns/vat_price_calculation_spec.rb +66 -0
  229. data/spec/models/spree/country_spec.rb +55 -0
  230. data/spec/models/spree/credit_card_spec.rb +328 -0
  231. data/spec/models/spree/customer_return_spec.rb +240 -0
  232. data/spec/models/spree/exchange_spec.rb +75 -0
  233. data/spec/models/spree/gateway/bogus_simple.rb +20 -0
  234. data/spec/models/spree/gateway/bogus_spec.rb +13 -0
  235. data/spec/models/spree/gateway_spec.rb +61 -0
  236. data/spec/models/spree/image_spec.rb +8 -0
  237. data/spec/models/spree/inventory_unit_spec.rb +256 -0
  238. data/spec/models/spree/line_item_spec.rb +348 -0
  239. data/spec/models/spree/option_type_prototype_spec.rb +9 -0
  240. data/spec/models/spree/option_type_spec.rb +14 -0
  241. data/spec/models/spree/option_value_spec.rb +18 -0
  242. data/spec/models/spree/order/address_spec.rb +50 -0
  243. data/spec/models/spree/order/adjustments_spec.rb +29 -0
  244. data/spec/models/spree/order/callbacks_spec.rb +42 -0
  245. data/spec/models/spree/order/checkout_spec.rb +770 -0
  246. data/spec/models/spree/order/currency_updater_spec.rb +32 -0
  247. data/spec/models/spree/order/finalizing_spec.rb +114 -0
  248. data/spec/models/spree/order/helpers_spec.rb +5 -0
  249. data/spec/models/spree/order/payment_spec.rb +214 -0
  250. data/spec/models/spree/order/risk_assessment_spec.rb +84 -0
  251. data/spec/models/spree/order/shipments_spec.rb +43 -0
  252. data/spec/models/spree/order/state_machine_spec.rb +212 -0
  253. data/spec/models/spree/order/store_credit_spec.rb +457 -0
  254. data/spec/models/spree/order/tax_spec.rb +84 -0
  255. data/spec/models/spree/order/totals_spec.rb +24 -0
  256. data/spec/models/spree/order/updating_spec.rb +18 -0
  257. data/spec/models/spree/order/validations_spec.rb +15 -0
  258. data/spec/models/spree/order_contents_spec.rb +332 -0
  259. data/spec/models/spree/order_inventory_spec.rb +247 -0
  260. data/spec/models/spree/order_merger_spec.rb +135 -0
  261. data/spec/models/spree/order_spec.rb +1067 -0
  262. data/spec/models/spree/order_updater_spec.rb +305 -0
  263. data/spec/models/spree/payment/gateway_options_spec.rb +127 -0
  264. data/spec/models/spree/payment/store_credit_spec.rb +60 -0
  265. data/spec/models/spree/payment_method/store_credit_spec.rb +291 -0
  266. data/spec/models/spree/payment_method_spec.rb +108 -0
  267. data/spec/models/spree/payment_spec.rb +922 -0
  268. data/spec/models/spree/preference_spec.rb +80 -0
  269. data/spec/models/spree/preferences/configuration_spec.rb +30 -0
  270. data/spec/models/spree/preferences/preferable_spec.rb +344 -0
  271. data/spec/models/spree/preferences/scoped_store_spec.rb +58 -0
  272. data/spec/models/spree/preferences/store_spec.rb +46 -0
  273. data/spec/models/spree/price_spec.rb +128 -0
  274. data/spec/models/spree/product/scopes_spec.rb +174 -0
  275. data/spec/models/spree/product_duplicator_spec.rb +102 -0
  276. data/spec/models/spree/product_filter_spec.rb +26 -0
  277. data/spec/models/spree/product_option_type_spec.rb +9 -0
  278. data/spec/models/spree/product_promotion_rule_spec.rb +9 -0
  279. data/spec/models/spree/product_property_spec.rb +26 -0
  280. data/spec/models/spree/product_spec.rb +626 -0
  281. data/spec/models/spree/promotion/actions/create_adjustment_spec.rb +113 -0
  282. data/spec/models/spree/promotion/actions/create_item_adjustments_spec.rb +148 -0
  283. data/spec/models/spree/promotion/actions/create_line_items_spec.rb +86 -0
  284. data/spec/models/spree/promotion/actions/free_shipping_spec.rb +36 -0
  285. data/spec/models/spree/promotion/rules/country_spec.rb +36 -0
  286. data/spec/models/spree/promotion/rules/first_order_spec.rb +75 -0
  287. data/spec/models/spree/promotion/rules/item_total_spec.rb +282 -0
  288. data/spec/models/spree/promotion/rules/one_use_per_user_spec.rb +42 -0
  289. data/spec/models/spree/promotion/rules/option_value_spec.rb +90 -0
  290. data/spec/models/spree/promotion/rules/product_spec.rb +143 -0
  291. data/spec/models/spree/promotion/rules/taxon_spec.rb +102 -0
  292. data/spec/models/spree/promotion/rules/user_logged_in_spec.rb +27 -0
  293. data/spec/models/spree/promotion/rules/user_spec.rb +45 -0
  294. data/spec/models/spree/promotion_action_spec.rb +10 -0
  295. data/spec/models/spree/promotion_category_spec.rb +17 -0
  296. data/spec/models/spree/promotion_handler/cart_spec.rb +102 -0
  297. data/spec/models/spree/promotion_handler/coupon_spec.rb +323 -0
  298. data/spec/models/spree/promotion_handler/free_shipping_spec.rb +48 -0
  299. data/spec/models/spree/promotion_handler/page_spec.rb +44 -0
  300. data/spec/models/spree/promotion_rule_spec.rb +29 -0
  301. data/spec/models/spree/promotion_rule_taxon_spec.rb +9 -0
  302. data/spec/models/spree/promotion_rule_user_spec.rb +9 -0
  303. data/spec/models/spree/promotion_spec.rb +674 -0
  304. data/spec/models/spree/property_prototype_spec.rb +9 -0
  305. data/spec/models/spree/property_spec.rb +5 -0
  306. data/spec/models/spree/prototype_spec.rb +5 -0
  307. data/spec/models/spree/prototype_taxon_spec.rb +9 -0
  308. data/spec/models/spree/refund_reason_spec.rb +20 -0
  309. data/spec/models/spree/refund_spec.rb +195 -0
  310. data/spec/models/spree/reimbursement/credit_spec.rb +36 -0
  311. data/spec/models/spree/reimbursement/reimbursement_type_engine_spec.rb +140 -0
  312. data/spec/models/spree/reimbursement/reimbursement_type_validator_spec.rb +83 -0
  313. data/spec/models/spree/reimbursement_performer_spec.rb +30 -0
  314. data/spec/models/spree/reimbursement_spec.rb +188 -0
  315. data/spec/models/spree/reimbursement_tax_calculator_spec.rb +63 -0
  316. data/spec/models/spree/reimbursement_type/credit_spec.rb +53 -0
  317. data/spec/models/spree/reimbursement_type/exchange_spec.rb +46 -0
  318. data/spec/models/spree/reimbursement_type/original_payment_spec.rb +55 -0
  319. data/spec/models/spree/reimbursement_type/store_credit_spec.rb +101 -0
  320. data/spec/models/spree/return_authorization_reason_spec.rb +7 -0
  321. data/spec/models/spree/return_authorization_spec.rb +230 -0
  322. data/spec/models/spree/return_item/eligibility_validator/default_spec.rb +77 -0
  323. data/spec/models/spree/return_item/eligibility_validator/inventory_shipped_spec.rb +58 -0
  324. data/spec/models/spree/return_item/eligibility_validator/no_reimbursements_spec.rb +61 -0
  325. data/spec/models/spree/return_item/eligibility_validator/order_completed_spec.rb +32 -0
  326. data/spec/models/spree/return_item/eligibility_validator/rma_required_spec.rb +29 -0
  327. data/spec/models/spree/return_item/eligibility_validator/time_since_purchase_spec.rb +35 -0
  328. data/spec/models/spree/return_item/exchange_variant_eligibility/same_option_value_spec.rb +65 -0
  329. data/spec/models/spree/return_item/exchange_variant_eligibility/same_product_spec.rb +43 -0
  330. data/spec/models/spree/return_item_spec.rb +734 -0
  331. data/spec/models/spree/returns_calculator_spec.rb +14 -0
  332. data/spec/models/spree/role_spec.rb +7 -0
  333. data/spec/models/spree/shipment_spec.rb +744 -0
  334. data/spec/models/spree/shipping_calculator_spec.rb +45 -0
  335. data/spec/models/spree/shipping_category_spec.rb +19 -0
  336. data/spec/models/spree/shipping_method_spec.rb +125 -0
  337. data/spec/models/spree/shipping_rate_spec.rb +140 -0
  338. data/spec/models/spree/state_spec.rb +29 -0
  339. data/spec/models/spree/stock/availability_validator_spec.rb +42 -0
  340. data/spec/models/spree/stock/content_item_spec.rb +31 -0
  341. data/spec/models/spree/stock/coordinator_spec.rb +61 -0
  342. data/spec/models/spree/stock/differentiator_spec.rb +39 -0
  343. data/spec/models/spree/stock/estimator_spec.rb +202 -0
  344. data/spec/models/spree/stock/inventory_unit_builder_spec.rb +37 -0
  345. data/spec/models/spree/stock/package_spec.rb +182 -0
  346. data/spec/models/spree/stock/packer_spec.rb +70 -0
  347. data/spec/models/spree/stock/prioritizer_spec.rb +125 -0
  348. data/spec/models/spree/stock/quantifier_spec.rb +126 -0
  349. data/spec/models/spree/stock/splitter/backordered_spec.rb +29 -0
  350. data/spec/models/spree/stock/splitter/base_spec.rb +21 -0
  351. data/spec/models/spree/stock/splitter/shipping_category_spec.rb +47 -0
  352. data/spec/models/spree/stock/splitter/weight_spec.rb +32 -0
  353. data/spec/models/spree/stock_item_spec.rb +465 -0
  354. data/spec/models/spree/stock_location_spec.rb +243 -0
  355. data/spec/models/spree/stock_movement_spec.rb +120 -0
  356. data/spec/models/spree/stock_transfer_spec.rb +50 -0
  357. data/spec/models/spree/store_credit_event_spec.rb +101 -0
  358. data/spec/models/spree/store_credit_spec.rb +798 -0
  359. data/spec/models/spree/store_spec.rb +78 -0
  360. data/spec/models/spree/tax_category_spec.rb +32 -0
  361. data/spec/models/spree/tax_rate_spec.rb +561 -0
  362. data/spec/models/spree/taxon_spec.rb +93 -0
  363. data/spec/models/spree/taxonomy_spec.rb +18 -0
  364. data/spec/models/spree/tracker_spec.rb +21 -0
  365. data/spec/models/spree/user_spec.rb +203 -0
  366. data/spec/models/spree/variant_spec.rb +818 -0
  367. data/spec/models/spree/zone_member_spec.rb +38 -0
  368. data/spec/models/spree/zone_spec.rb +472 -0
  369. data/spec/spec_helper.rb +82 -0
  370. data/spec/support/big_decimal.rb +5 -0
  371. data/spec/support/concerns/adjustment_source.rb +23 -0
  372. data/spec/support/concerns/default_price.rb +37 -0
  373. data/spec/support/rake.rb +13 -0
  374. data/spec/support/test_gateway.rb +2 -0
  375. data/spree_core.gemspec +13 -13
  376. metadata +252 -45
  377. data/app/models/concerns/spree/user_api_authentication.rb +0 -19
  378. data/app/models/spree/calculator/free_shipping.rb +0 -23
  379. data/config/initializers/premailer_rails.rb +0 -3
  380. data/config/initializers/user_class_extensions.rb +0 -10
  381. data/spec/fixtures/microdata.html +0 -22
  382. data/spec/fixtures/microdata_itemref.html +0 -15
  383. data/spec/fixtures/microdata_no_itemscope.html +0 -20
@@ -2,7 +2,7 @@ module Spree
2
2
  class Refund < Spree::Base
3
3
  with_options inverse_of: :refunds do
4
4
  belongs_to :payment
5
- belongs_to :reimbursement
5
+ belongs_to :reimbursement, optional: true
6
6
  end
7
7
  belongs_to :reason, class_name: 'Spree::RefundReason', foreign_key: :refund_reason_id
8
8
 
@@ -43,7 +43,7 @@ module Spree
43
43
  def perform!
44
44
  return true if transaction_id.present?
45
45
 
46
- credit_cents = Spree::Money.new(amount.to_f, currency: payment.currency).amount_in_cents
46
+ credit_cents = Spree::Money.new(amount.to_f, currency: payment.currency).money.cents
47
47
 
48
48
  @response = process!(credit_cents)
49
49
 
@@ -6,7 +6,7 @@ module Spree
6
6
 
7
7
  with_options inverse_of: :reimbursements do
8
8
  belongs_to :order
9
- belongs_to :customer_return, touch: true
9
+ belongs_to :customer_return, touch: true, optional: true
10
10
  end
11
11
 
12
12
  with_options inverse_of: :reimbursement do
@@ -15,6 +15,7 @@ module Spree
15
15
  has_many :return_items
16
16
  end
17
17
 
18
+ validates :number, uniqueness: true
18
19
  validates :order, presence: true
19
20
  validate :validate_return_items_belong_to_same_order
20
21
 
@@ -10,7 +10,7 @@ module Spree
10
10
 
11
11
  has_many :return_items
12
12
 
13
- # This method will reimburse the return items based on however it child implements it
13
+ # This method will reimburse the return items based on however its child implements it
14
14
  # By default it takes a reimbursement, the return items it needs to reimburse, and if
15
15
  # it is a simulation or a real reimbursement. This should return an array
16
16
  def self.reimburse(reimbursement, return_items, simulate)
@@ -17,6 +17,7 @@ module Spree
17
17
 
18
18
  accepts_nested_attributes_for :return_items, allow_destroy: true
19
19
 
20
+ validates :number, uniqueness: true
20
21
  validates :order, :reason, :stock_location, presence: true
21
22
  validate :must_have_shipped_units, on: :create
22
23
 
@@ -5,6 +5,14 @@ module Spree
5
5
  class_attribute :return_eligibility_validator
6
6
  self.return_eligibility_validator = ReturnItem::EligibilityValidator::Default
7
7
 
8
+ def return_quantity=(value)
9
+ @_return_quantity = value.to_i
10
+ end
11
+
12
+ def return_quantity
13
+ @_return_quantity.nil? ? inventory_unit.quantity : @_return_quantity
14
+ end
15
+
8
16
  class_attribute :exchange_variant_engine
9
17
  self.exchange_variant_engine = ReturnItem::ExchangeVariantEligibility::SameProduct
10
18
 
@@ -17,8 +25,10 @@ module Spree
17
25
  belongs_to :customer_return
18
26
  belongs_to :reimbursement
19
27
  end
28
+ has_many :exchange_inventory_units, class_name: 'Spree::InventoryUnit',
29
+ foreign_key: :original_return_item_id,
30
+ inverse_of: :original_return_item
20
31
  belongs_to :exchange_variant, class_name: 'Spree::Variant'
21
- belongs_to :exchange_inventory_unit, class_name: 'Spree::InventoryUnit', inverse_of: :original_return_item
22
32
  belongs_to :preferred_reimbursement_type, class_name: 'Spree::ReimbursementType'
23
33
  belongs_to :override_reimbursement_type, class_name: 'Spree::ReimbursementType'
24
34
 
@@ -27,6 +37,8 @@ module Spree
27
37
  validate :validate_acceptance_status_for_reimbursement
28
38
  validates :inventory_unit, presence: true
29
39
  validate :validate_no_other_completed_return_items, on: :create
40
+ validates :return_quantity, numericality: { greater_than_or_equal_to: 1 }
41
+ validate :sufficient_quantity_for_return
30
42
 
31
43
  after_create :cancel_others, unless: :cancelled?
32
44
 
@@ -42,8 +54,8 @@ module Spree
42
54
  scope :reimbursed, -> { where.not(reimbursement_id: nil) }
43
55
  scope :not_reimbursed, -> { where(reimbursement_id: nil) }
44
56
  scope :exchange_requested, -> { where.not(exchange_variant: nil) }
45
- scope :exchange_processed, -> { where.not(exchange_inventory_unit: nil) }
46
- scope :exchange_required, -> { exchange_requested.where(exchange_inventory_unit: nil) }
57
+ scope :exchange_processed, -> { joins(:exchange_inventory_units).distinct }
58
+ scope :exchange_required, -> { eager_load(:exchange_inventory_units).where(spree_inventory_units: { original_return_item_id: nil }).distinct }
47
59
  scope :resellable, -> { where resellable: true }
48
60
 
49
61
  serialize :acceptance_status_errors
@@ -52,7 +64,9 @@ module Spree
52
64
  delegate :variant, to: :inventory_unit
53
65
  delegate :shipment, to: :inventory_unit
54
66
 
67
+ before_create :extract_inventory_unit, unless: -> { inventory_unit.quantity == return_quantity }
55
68
  before_create :set_default_pre_tax_amount, unless: :pre_tax_amount_changed?
69
+
56
70
  before_save :set_exchange_pre_tax_amount
57
71
 
58
72
  state_machine :reception_status, initial: :awaiting do
@@ -115,7 +129,7 @@ module Spree
115
129
  end
116
130
 
117
131
  def exchange_processed?
118
- exchange_inventory_unit.present?
132
+ exchange_inventory_units.present?
119
133
  end
120
134
 
121
135
  def exchange_required?
@@ -130,17 +144,19 @@ module Spree
130
144
  exchange_variant_engine.eligible_variants(variant)
131
145
  end
132
146
 
133
- def build_exchange_inventory_unit
147
+ def build_default_exchange_inventory_unit
134
148
  # The inventory unit needs to have the new variant
135
149
  # but it also needs to know the original line item
136
150
  # for pricing information for if the inventory unit is
137
151
  # ever returned. This means that the inventory unit's line_item
138
152
  # will have a different variant than the inventory unit itself
139
- super(variant: exchange_variant, line_item: inventory_unit.line_item, order: inventory_unit.order) if exchange_required?
153
+ return unless exchange_required?
154
+ exchange_inventory_units.build(variant: exchange_variant, line_item: inventory_unit.line_item,
155
+ order: inventory_unit.order, quantity: return_quantity)
140
156
  end
141
157
 
142
- def exchange_shipment
143
- exchange_inventory_unit.try(:shipment)
158
+ def exchange_shipments
159
+ exchange_inventory_units.map(&:shipment).uniq
144
160
  end
145
161
 
146
162
  def set_default_pre_tax_amount
@@ -170,7 +186,7 @@ module Spree
170
186
  inventory_unit.return!
171
187
  Spree::StockMovement.create!(
172
188
  stock_item_id: stock_item.id,
173
- quantity: 1,
189
+ quantity: inventory_unit.quantity,
174
190
  originator: return_authorization
175
191
  ) if should_restock?
176
192
  end
@@ -206,6 +222,16 @@ module Spree
206
222
  end
207
223
  end
208
224
 
225
+ def sufficient_quantity_for_return
226
+ # Only perform the check if everything is good so far
227
+ return unless errors.empty? && return_quantity > inventory_unit.quantity
228
+ errors.add(:return_quantity, Spree.t(:cannot_return_more_than_bought_quantity))
229
+ end
230
+
231
+ def extract_inventory_unit
232
+ self.inventory_unit = inventory_unit.split_inventory!(return_quantity)
233
+ end
234
+
209
235
  def set_exchange_pre_tax_amount
210
236
  self.pre_tax_amount = 0.0.to_d if exchange_requested?
211
237
  end
@@ -3,6 +3,6 @@ module Spree
3
3
  has_many :role_users, class_name: 'Spree::RoleUser', dependent: :destroy
4
4
  has_many :users, through: :role_users, class_name: Spree.user_class.to_s
5
5
 
6
- validates :name, presence: true, uniqueness: { allow_blank: true }
6
+ validates :name, presence: true, uniqueness: { case_sensitive: false, allow_blank: true }
7
7
  end
8
8
  end
@@ -1,6 +1,6 @@
1
1
  module Spree
2
2
  class RoleUser < Spree::Base
3
3
  belongs_to :role, class_name: 'Spree::Role'
4
- belongs_to :user, class_name: Spree.user_class
4
+ belongs_to :user, class_name: Spree.user_class.to_s
5
5
  end
6
6
  end
@@ -4,8 +4,7 @@ module Spree
4
4
  class Shipment < Spree::Base
5
5
  include Spree::Core::NumberGenerator.new(prefix: 'H', length: 11)
6
6
 
7
- extend FriendlyId
8
- friendly_id :number, slug_column: :number, use: :slugged
7
+ include NumberAsParam
9
8
 
10
9
  with_options inverse_of: :shipments do
11
10
  belongs_to :address, class_name: 'Spree::Address'
@@ -20,14 +19,14 @@ module Spree
20
19
  has_many :state_changes, as: :stateful
21
20
  end
22
21
  has_many :shipping_methods, through: :shipping_rates
23
- has_one :selected_shipping_rate, -> { where(selected: true).order(:cost) }, class_name: Spree::ShippingRate
24
-
22
+ has_one :selected_shipping_rate, -> { where(selected: true).order(:cost) }, class_name: Spree::ShippingRate.to_s
25
23
 
26
24
  after_save :update_adjustments
27
25
 
28
26
  before_validation :set_cost_zero_when_nil
29
27
 
30
28
  validates :stock_location, presence: true
29
+ validates :number, uniqueness: true
31
30
 
32
31
  attr_accessor :special_instructions
33
32
 
@@ -56,12 +55,12 @@ module Spree
56
55
  end
57
56
 
58
57
  event :ship do
59
- transition from: [:ready, :canceled], to: :shipped
58
+ transition from: %i(ready canceled), to: :shipped
60
59
  end
61
60
  after_transition to: :shipped, do: :after_ship
62
61
 
63
62
  event :cancel do
64
- transition to: :canceled, from: [:pending, :ready]
63
+ transition to: :canceled, from: %i(pending ready)
65
64
  end
66
65
  after_transition to: :canceled, do: :after_cancel
67
66
 
@@ -71,7 +70,7 @@ module Spree
71
70
  }
72
71
  transition from: :canceled, to: :pending
73
72
  end
74
- after_transition from: :canceled, to: [:pending, :ready, :shipped], do: :after_resume
73
+ after_transition from: :canceled, to: %i(pending ready shipped), do: :after_resume
75
74
 
76
75
  after_transition do |shipment, transition|
77
76
  shipment.state_changes.create!(
@@ -101,7 +100,7 @@ module Spree
101
100
  end
102
101
 
103
102
  def backordered?
104
- inventory_units.any? { |inventory_unit| inventory_unit.backordered? }
103
+ inventory_units.any?(&:backordered?)
105
104
  end
106
105
 
107
106
  def currency
@@ -126,7 +125,7 @@ module Spree
126
125
  end
127
126
  alias discounted_amount discounted_cost
128
127
 
129
- def editable_by?(user)
128
+ def editable_by?(_user)
130
129
  !shipped?
131
130
  end
132
131
 
@@ -168,22 +167,21 @@ module Spree
168
167
  def manifest
169
168
  # Grouping by the ID means that we don't have to call out to the association accessor
170
169
  # This makes the grouping by faster because it results in less SQL cache hits.
171
- inventory_units.group_by(&:variant_id).map do |variant_id, units|
172
- units.group_by(&:line_item_id).map do |line_item_id, units|
173
-
170
+ inventory_units.group_by(&:variant_id).map do |_variant_id, units|
171
+ units.group_by(&:line_item_id).map do |_line_item_id, units|
174
172
  states = {}
175
- units.group_by(&:state).each { |state, iu| states[state] = iu.size }
173
+ units.group_by(&:state).each { |state, iu| states[state] = iu.sum(&:quantity) }
176
174
 
177
175
  line_item = units.first.line_item
178
176
  variant = units.first.variant
179
- ManifestItem.new(line_item, variant, units.length, states)
177
+ ManifestItem.new(line_item, variant, units.sum(&:quantity), states)
180
178
  end
181
179
  end.flatten
182
180
  end
183
181
 
184
182
  def process_order_payments
185
- pending_payments = order.pending_payments
186
- .sort_by(&:uncaptured_amount).reverse
183
+ pending_payments = order.pending_payments.
184
+ sort_by(&:uncaptured_amount).reverse
187
185
 
188
186
  shipment_to_pay = final_price_with_items
189
187
  payments_amount = 0
@@ -208,7 +206,7 @@ module Spree
208
206
  end
209
207
 
210
208
  def ready_or_pending?
211
- self.ready? || self.pending?
209
+ ready? || pending?
212
210
  end
213
211
 
214
212
  def refresh_rates(shipping_method_filter = ShippingMethod::DISPLAY_ON_FRONT_END)
@@ -219,12 +217,12 @@ module Spree
219
217
  original_shipping_method_id = shipping_method.try(:id)
220
218
 
221
219
  self.shipping_rates = Stock::Estimator.new(order).
222
- shipping_rates(to_package, shipping_method_filter)
220
+ shipping_rates(to_package, shipping_method_filter)
223
221
 
224
222
  if shipping_method
225
- selected_rate = shipping_rates.detect { |rate|
223
+ selected_rate = shipping_rates.detect do |rate|
226
224
  rate.shipping_method_id == original_shipping_method_id
227
- }
225
+ end
228
226
  self.selected_shipping_rate_id = selected_rate.id if selected_rate
229
227
  end
230
228
 
@@ -238,11 +236,11 @@ module Spree
238
236
  def selected_shipping_rate_id=(id)
239
237
  shipping_rates.update_all(selected: false)
240
238
  shipping_rates.update(id, selected: true)
241
- self.save!
239
+ save!
242
240
  end
243
241
 
244
242
  def set_up_inventory(state, variant, order, line_item)
245
- self.inventory_units.create(
243
+ inventory_units.create(
246
244
  state: state,
247
245
  variant_id: variant.id,
248
246
  order_id: order.id,
@@ -284,7 +282,7 @@ module Spree
284
282
 
285
283
  def update_amounts
286
284
  if selected_shipping_rate
287
- self.update_columns(
285
+ update_columns(
288
286
  cost: selected_shipping_rate.cost,
289
287
  adjustment_total: adjustments.additional.map(&:update!).compact.sum,
290
288
  updated_at: Time.current,
@@ -294,20 +292,20 @@ module Spree
294
292
 
295
293
  # Update Shipment and make sure Order states follow the shipment changes
296
294
  def update_attributes_and_order(params = {})
297
- if self.update_attributes params
298
- if params.has_key? :selected_shipping_rate_id
295
+ if update_attributes params
296
+ if params.key? :selected_shipping_rate_id
299
297
  # Changing the selected Shipping Rate won't update the cost (for now)
300
298
  # so we persist the Shipment#cost before calculating order shipment
301
299
  # total and updating payment state (given a change in shipment cost
302
300
  # might change the Order#payment_state)
303
- self.update_amounts
301
+ update_amounts
304
302
 
305
303
  order.updater.update_shipment_total
306
304
  order.updater.update_payment_state
307
305
 
308
306
  # Update shipment state only after order total is updated because it
309
307
  # (via Order#paid?) affects the shipment state (YAY)
310
- self.update_columns(
308
+ update_columns(
311
309
  state: determine_state(order),
312
310
  updated_at: Time.current
313
311
  )
@@ -332,7 +330,7 @@ module Spree
332
330
  state: new_state,
333
331
  updated_at: Time.current,
334
332
  )
335
- after_ship if new_state == 'shipped' and old_state != 'shipped'
333
+ after_ship if new_state == 'shipped' && old_state != 'shipped'
336
334
  end
337
335
 
338
336
  def transfer_to_location(variant, quantity, stock_location)
@@ -343,8 +341,8 @@ module Spree
343
341
  transaction do
344
342
  new_shipment = order.shipments.create!(stock_location: stock_location)
345
343
 
346
- order.contents.remove(variant, quantity, {shipment: self})
347
- order.contents.add(variant, quantity, {shipment: new_shipment})
344
+ order.contents.remove(variant, quantity, shipment: self)
345
+ order.contents.add(variant, quantity, shipment: new_shipment)
348
346
 
349
347
  refresh_rates
350
348
  save!
@@ -353,16 +351,18 @@ module Spree
353
351
  end
354
352
 
355
353
  def transfer_to_shipment(variant, quantity, shipment_to_transfer_to)
356
- quantity_already_shipment_to_transfer_to = shipment_to_transfer_to.manifest.find{|mi| mi.line_item.variant == variant}.try(:quantity) || 0
354
+ quantity_already_shipment_to_transfer_to = shipment_to_transfer_to.manifest.find do |mi|
355
+ mi.line_item.variant == variant
356
+ end.try(:quantity) || 0
357
357
  final_quantity = quantity + quantity_already_shipment_to_transfer_to
358
358
 
359
- if (quantity <= 0 || self == shipment_to_transfer_to)
359
+ if quantity <= 0 || self == shipment_to_transfer_to
360
360
  raise ArgumentError
361
361
  end
362
362
 
363
363
  transaction do
364
- order.contents.remove(variant, quantity, {shipment: self})
365
- order.contents.add(variant, quantity, {shipment: shipment_to_transfer_to})
364
+ order.contents.remove(variant, quantity, shipment: self)
365
+ order.contents.add(variant, quantity, shipment: shipment_to_transfer_to)
366
366
 
367
367
  refresh_rates
368
368
  save!
@@ -373,45 +373,44 @@ module Spree
373
373
 
374
374
  private
375
375
 
376
- def after_ship
377
- ShipmentHandler.factory(self).perform
378
- end
379
-
380
- def can_get_rates?
381
- order.ship_address && order.ship_address.valid?
382
- end
376
+ def after_ship
377
+ ShipmentHandler.factory(self).perform
378
+ end
383
379
 
384
- def manifest_restock(item)
385
- if item.states["on_hand"].to_i > 0
386
- stock_location.restock item.variant, item.states["on_hand"], self
387
- end
380
+ def can_get_rates?
381
+ order.ship_address && order.ship_address.valid?
382
+ end
388
383
 
389
- if item.states["backordered"].to_i > 0
390
- stock_location.restock_backordered item.variant, item.states["backordered"]
391
- end
384
+ def manifest_restock(item)
385
+ if item.states["on_hand"].to_i.positive?
386
+ stock_location.restock item.variant, item.states["on_hand"], self
392
387
  end
393
388
 
394
- def manifest_unstock(item)
395
- stock_location.unstock item.variant, item.quantity, self
389
+ if item.states["backordered"].to_i.positive?
390
+ stock_location.restock_backordered item.variant, item.states["backordered"]
396
391
  end
392
+ end
397
393
 
398
- def recalculate_adjustments
399
- Adjustable::AdjustmentsUpdater.update(self)
400
- end
394
+ def manifest_unstock(item)
395
+ stock_location.unstock item.variant, item.quantity, self
396
+ end
401
397
 
402
- def send_shipped_email
403
- ShipmentMailer.shipped_email(id).deliver_later
404
- end
398
+ def recalculate_adjustments
399
+ Adjustable::AdjustmentsUpdater.update(self)
400
+ end
405
401
 
406
- def set_cost_zero_when_nil
407
- self.cost = 0 unless self.cost
408
- end
402
+ def send_shipped_email
403
+ ShipmentMailer.shipped_email(id).deliver_later
404
+ end
409
405
 
410
- def update_adjustments
411
- if cost_changed? && state != 'shipped'
412
- recalculate_adjustments
413
- end
414
- end
406
+ def set_cost_zero_when_nil
407
+ self.cost = 0 unless cost
408
+ end
415
409
 
410
+ def update_adjustments
411
+ if saved_change_to_cost? && state != 'shipped'
412
+ recalculate_adjustments
413
+ end
414
+ end
416
415
  end
417
416
  end