solidus_core 2.11.3 → 2.11.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (103) hide show
  1. checksums.yaml +4 -4
  2. data/app/models/spree/address.rb +28 -5
  3. data/app/models/spree/base.rb +39 -14
  4. data/app/models/spree/calculator.rb +8 -4
  5. data/app/models/spree/calculator/free_shipping.rb +1 -0
  6. data/app/models/spree/calculator/percent_per_item.rb +2 -0
  7. data/app/models/spree/calculator/price_sack.rb +1 -0
  8. data/app/models/spree/order/payments.rb +2 -2
  9. data/app/models/spree/order_merger.rb +1 -1
  10. data/app/models/spree/payment.rb +10 -3
  11. data/app/models/spree/payment/cancellation.rb +3 -22
  12. data/app/models/spree/payment_method.rb +3 -0
  13. data/app/models/spree/payment_source.rb +2 -2
  14. data/app/models/spree/product.rb +8 -2
  15. data/app/models/spree/product/scopes.rb +0 -1
  16. data/app/models/spree/promotion_action.rb +3 -0
  17. data/app/models/spree/promotion_rule.rb +4 -0
  18. data/app/models/spree/shipping_method.rb +1 -1
  19. data/app/models/spree/stock/availability_validator.rb +2 -2
  20. data/app/models/spree/stock/inventory_validator.rb +2 -2
  21. data/app/models/spree/taxon/active_storage_attachment.rb +1 -2
  22. data/app/models/spree/taxon/paperclip_attachment.rb +1 -0
  23. data/db/migrate/20210122110141_add_name_to_spree_addresses.rb +13 -0
  24. data/lib/generators/spree/dummy/templates/rails/test.rb +4 -1
  25. data/lib/spree/app_configuration.rb +1 -1
  26. data/lib/spree/core.rb +1 -4
  27. data/lib/spree/core/engine.rb +7 -8
  28. data/lib/spree/core/version.rb +1 -1
  29. data/lib/spree/permitted_attributes.rb +5 -5
  30. data/lib/spree/preferences/persistable.rb +23 -0
  31. data/lib/spree/testing_support.rb +31 -0
  32. data/lib/spree/testing_support/dummy_app.rb +4 -2
  33. data/lib/spree/testing_support/dummy_app/mailer_previews/test_mailer_preview.rb +4 -0
  34. data/lib/spree/testing_support/factories.rb +8 -4
  35. data/lib/spree/testing_support/factories/address_factory.rb +6 -2
  36. data/lib/spree/testing_support/factories/adjustment_factory.rb +10 -5
  37. data/lib/spree/testing_support/factories/adjustment_reason_factory.rb +5 -0
  38. data/lib/spree/testing_support/factories/calculator_factory.rb +5 -0
  39. data/lib/spree/testing_support/factories/carton_factory.rb +7 -2
  40. data/lib/spree/testing_support/factories/country_factory.rb +5 -0
  41. data/lib/spree/testing_support/factories/credit_card_factory.rb +5 -0
  42. data/lib/spree/testing_support/factories/customer_return_factory.rb +8 -3
  43. data/lib/spree/testing_support/factories/image_factory.rb +5 -0
  44. data/lib/spree/testing_support/factories/inventory_unit_factory.rb +9 -4
  45. data/lib/spree/testing_support/factories/line_item_factory.rb +7 -2
  46. data/lib/spree/testing_support/factories/option_type_factory.rb +8 -0
  47. data/lib/spree/testing_support/factories/option_value_factory.rb +5 -0
  48. data/lib/spree/testing_support/factories/order_factory.rb +11 -6
  49. data/lib/spree/testing_support/factories/order_promotion_factory.rb +7 -2
  50. data/lib/spree/testing_support/factories/payment_factory.rb +9 -4
  51. data/lib/spree/testing_support/factories/payment_method_factory.rb +5 -0
  52. data/lib/spree/testing_support/factories/price_factory.rb +6 -1
  53. data/lib/spree/testing_support/factories/product_factory.rb +10 -5
  54. data/lib/spree/testing_support/factories/product_option_type_factory.rb +7 -2
  55. data/lib/spree/testing_support/factories/product_property_factory.rb +7 -2
  56. data/lib/spree/testing_support/factories/promotion_category_factory.rb +5 -0
  57. data/lib/spree/testing_support/factories/promotion_code_factory.rb +7 -2
  58. data/lib/spree/testing_support/factories/promotion_factory.rb +7 -2
  59. data/lib/spree/testing_support/factories/property_factory.rb +5 -0
  60. data/lib/spree/testing_support/factories/refund_factory.rb +7 -2
  61. data/lib/spree/testing_support/factories/refund_reason_factory.rb +5 -0
  62. data/lib/spree/testing_support/factories/reimbursement_factory.rb +6 -1
  63. data/lib/spree/testing_support/factories/reimbursement_type_factory.rb +5 -0
  64. data/lib/spree/testing_support/factories/return_authorization_factory.rb +8 -3
  65. data/lib/spree/testing_support/factories/return_item_factory.rb +8 -3
  66. data/lib/spree/testing_support/factories/return_reason_factory.rb +5 -0
  67. data/lib/spree/testing_support/factories/role_factory.rb +5 -0
  68. data/lib/spree/testing_support/factories/shipment_factory.rb +9 -3
  69. data/lib/spree/testing_support/factories/shipping_category_factory.rb +5 -0
  70. data/lib/spree/testing_support/factories/shipping_method_factory.rb +8 -3
  71. data/lib/spree/testing_support/factories/shipping_rate_factory.rb +7 -2
  72. data/lib/spree/testing_support/factories/state_factory.rb +7 -1
  73. data/lib/spree/testing_support/factories/stock_item_factory.rb +7 -2
  74. data/lib/spree/testing_support/factories/stock_location_factory.rb +8 -3
  75. data/lib/spree/testing_support/factories/stock_movement_factory.rb +6 -1
  76. data/lib/spree/testing_support/factories/stock_package_factory.rb +7 -2
  77. data/lib/spree/testing_support/factories/store_credit_category_factory.rb +5 -0
  78. data/lib/spree/testing_support/factories/store_credit_event_factory.rb +7 -2
  79. data/lib/spree/testing_support/factories/store_credit_factory.rb +8 -3
  80. data/lib/spree/testing_support/factories/store_credit_reason_factory.rb +5 -0
  81. data/lib/spree/testing_support/factories/store_credit_type_factory.rb +5 -0
  82. data/lib/spree/testing_support/factories/store_factory.rb +6 -1
  83. data/lib/spree/testing_support/factories/tax_category_factory.rb +7 -1
  84. data/lib/spree/testing_support/factories/tax_rate_factory.rb +8 -3
  85. data/lib/spree/testing_support/factories/taxon_factory.rb +6 -1
  86. data/lib/spree/testing_support/factories/taxonomy_factory.rb +5 -0
  87. data/lib/spree/testing_support/factories/user_factory.rb +8 -3
  88. data/lib/spree/testing_support/factories/variant_factory.rb +9 -4
  89. data/lib/spree/testing_support/factories/variant_property_rule_condition_factory.rb +7 -2
  90. data/lib/spree/testing_support/factories/variant_property_rule_factory.rb +8 -3
  91. data/lib/spree/testing_support/factories/variant_property_rule_value_factory.rb +7 -2
  92. data/lib/spree/testing_support/factories/zone_factory.rb +7 -2
  93. data/lib/spree/testing_support/factory_bot.rb +68 -0
  94. data/lib/spree/testing_support/order_walkthrough.rb +10 -10
  95. data/lib/spree/testing_support/sequences.rb +4 -1
  96. data/{app/models → lib}/spree/user_class_handle.rb +0 -0
  97. data/lib/tasks/email.rake +3 -2
  98. data/lib/tasks/migrations/migrate_address_names.rake +158 -0
  99. data/lib/tasks/migrations/migrate_default_billing_addresses_to_address_book.rake +38 -0
  100. data/lib/tasks/upgrade.rake +13 -0
  101. data/solidus_core.gemspec +24 -2
  102. metadata +49 -23
  103. data/lib/spree/awesome_nested_set_override.rb +0 -44
@@ -20,11 +20,14 @@ Dummy::Application.configure do
20
20
  # Raise exceptions instead of rendering exception templates
21
21
  config.action_dispatch.show_exceptions = false
22
22
 
23
+ # Disable request forgery protection in test environment
24
+ config.action_controller.allow_forgery_protection = false
25
+
23
26
  # Tell Action Mailer not to deliver emails to the real world.
24
27
  # The :test delivery method accumulates sent emails in the
25
28
  # ActionMailer::Base.deliveries array.
26
29
  config.action_mailer.delivery_method = :test
27
- ActionMailer::Base.default from: "spree@example.com"
30
+ ActionMailer::Base.default from: "solidus@example.com"
28
31
 
29
32
  # Raise on deprecation warnings
30
33
  if ENV['SOLIDUS_RAISE_DEPRECATIONS'].present?
@@ -190,7 +190,7 @@ module Spree
190
190
 
191
191
  # @!attribute [rw] mails_from
192
192
  # @return [String] Email address used as +From:+ field in transactional emails.
193
- preference :mails_from, :string, default: 'spree@example.com'
193
+ preference :mails_from, :string, default: 'solidus@example.com'
194
194
 
195
195
  # @!attribute [rw] max_level_in_taxons_menu
196
196
  # @return [Integer] maximum nesting level in taxons menu (default: +1+)
data/lib/spree/core.rb CHANGED
@@ -90,11 +90,8 @@ require 'spree/core/state_machines'
90
90
  require 'spree/core/stock_configuration'
91
91
  require 'spree/core/validators/email'
92
92
  require 'spree/permission_sets'
93
+ require 'spree/user_class_handle'
93
94
 
94
95
  require 'spree/preferences/store'
95
96
  require 'spree/preferences/static_model_preferences'
96
97
  require 'spree/preferences/scoped_store'
97
-
98
- if Rails.gem_version >= Gem::Version.new('6.1.0.alpha')
99
- require 'spree/awesome_nested_set_override'
100
- end
@@ -86,19 +86,18 @@ module Spree
86
86
  Spree::Config.use_legacy_address_state_validator set to true has been
87
87
  deprecated and will be removed in Solidus 3.0. The Spree::Address state
88
88
  validation has been extracted into a configurable external class.
89
- Switch Spree::Config.use_legacy_address_state_validator to true to start
89
+ Switch Spree::Config.use_legacy_address_state_validator to false to start
90
90
  using the external validation class.
91
91
  DEPRECATION
92
92
  end
93
- end
94
93
 
95
- # Load in mailer previews for apps to use in development.
96
- # We need to make sure we call `Preview.all` before requiring our
97
- # previews, otherwise any previews the app attempts to add need to be
98
- # manually required.
99
- if Rails.env.development?
100
- initializer "spree.mailer_previews" do
94
+ # Load in mailer previews for apps to use in development.
95
+ # We need to make sure we call `Preview.all` before requiring our
96
+ # previews, otherwise any previews the app attempts to add need to be
97
+ # manually required.
98
+ if Rails.env.development? || Rails.env.test?
101
99
  ActionMailer::Preview.all
100
+
102
101
  Dir[root.join("lib/spree/mailer_previews/**/*_preview.rb")].each do |file|
103
102
  require_dependency file
104
103
  end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Spree
4
- VERSION = "2.11.3"
4
+ VERSION = "2.11.8"
5
5
 
6
6
  def self.solidus_version
7
7
  VERSION
@@ -191,12 +191,12 @@ module Spree
191
191
 
192
192
  private
193
193
 
194
- def inject_attributes_to_all_steps(attributes, method)
194
+ def inject_attributes_to_all_steps(attributes, method_name)
195
195
  attributes.each do |attribute|
196
- PermittedAttributes.checkout_address_attributes.send(method, attribute)
197
- PermittedAttributes.checkout_delivery_attributes.send(method, attribute)
198
- PermittedAttributes.checkout_payment_attributes.send(method, attribute)
199
- PermittedAttributes.checkout_confirm_attributes.send(method, attribute)
196
+ PermittedAttributes.checkout_address_attributes.send(method_name, attribute)
197
+ PermittedAttributes.checkout_delivery_attributes.send(method_name, attribute)
198
+ PermittedAttributes.checkout_payment_attributes.send(method_name, attribute)
199
+ PermittedAttributes.checkout_confirm_attributes.send(method_name, attribute)
200
200
  end
201
201
  end
202
202
  end
@@ -0,0 +1,23 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Spree
4
+ module Preferences
5
+ module Persistable
6
+ extend ActiveSupport::Concern
7
+
8
+ included do
9
+ include Spree::Preferences::Preferable
10
+ serialize :preferences, Hash
11
+ after_initialize :initialize_preference_defaults
12
+ end
13
+
14
+ private
15
+
16
+ def initialize_preference_defaults
17
+ if has_attribute?(:preferences)
18
+ self.preferences = default_preferences.merge(preferences)
19
+ end
20
+ end
21
+ end
22
+ end
23
+ end
@@ -0,0 +1,31 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'spree/testing_support/factory_bot'
4
+
5
+ module Spree
6
+ module TestingSupport
7
+ autoload :FactoryBot, "spree/testing_support/factory_bot"
8
+
9
+ autoload :SEQUENCES, "spree/testing_support/factory_bot"
10
+ autoload :FACTORIES, "spree/testing_support/factory_bot"
11
+
12
+ def factory_bot_paths
13
+ Spree::TestingSupport::FactoryBot.definition_file_paths
14
+ end
15
+
16
+ def check_factory_bot_version
17
+ Spree::TestingSupport::FactoryBot.check_version
18
+ end
19
+
20
+ def load_all_factories
21
+ Spree::TestingSupport::FactoryBot.add_paths_and_load!
22
+ end
23
+
24
+ deprecate(
25
+ factory_bot_paths: "Spree::TestingSupport::FactoryBot.definition_file_paths",
26
+ check_factory_bot_version: "Spree::TestingSupport::FactoryBot.check_version",
27
+ load_all_factories: "Spree::TestingSupport::FactoryBot.add_paths_and_load!",
28
+ deprecator: Spree::Deprecation
29
+ )
30
+ end
31
+ end
@@ -16,6 +16,7 @@ RAILS_6_OR_ABOVE = Rails.gem_version >= Gem::Version.new('6.0')
16
16
 
17
17
  # @private
18
18
  class ApplicationController < ActionController::Base
19
+ protect_from_forgery with: :exception
19
20
  end
20
21
 
21
22
  # @private
@@ -51,8 +52,8 @@ module DummyApp
51
52
  config.public_file_server.headers = { 'Cache-Control' => 'public, max-age=3600' }
52
53
  config.whiny_nils = true
53
54
  config.consider_all_requests_local = true
54
- config.action_controller.allow_forgery_protection = true
55
- config.action_controller.default_protect_from_forgery = true
55
+ config.action_controller.allow_forgery_protection = false
56
+ config.action_controller.default_protect_from_forgery = false
56
57
  config.action_controller.perform_caching = false
57
58
  config.action_dispatch.show_exceptions = false
58
59
  config.active_support.deprecation = :stderr
@@ -61,6 +62,7 @@ module DummyApp
61
62
  config.secret_key_base = 'SECRET_TOKEN'
62
63
 
63
64
  config.action_mailer.delivery_job = "ActionMailer::MailDeliveryJob" if RAILS_6_OR_ABOVE
65
+ config.action_mailer.preview_path = File.expand_path('dummy_app/mailer_previews', __dir__)
64
66
  config.active_record.sqlite3.represent_boolean_as_integer = true unless RAILS_6_OR_ABOVE
65
67
 
66
68
  config.storage_path = Rails.root.join('tmp', 'storage')
@@ -0,0 +1,4 @@
1
+ # frozen_string_literal: true
2
+
3
+ class TestMailerPreview < ActionMailer::Preview
4
+ end
@@ -1,7 +1,11 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'factory_bot'
3
+ require 'spree/testing_support/factory_bot'
4
4
 
5
- Dir["#{File.dirname(__FILE__)}/factories/**"].each do |f|
6
- require File.expand_path(f)
7
- end
5
+ Spree::Deprecation.warn(
6
+ "Please do not try to load factories directly. " \
7
+ 'Use factory_bot_rails and rely on the default configuration instead.', caller(1)
8
+ )
9
+
10
+ Spree::TestingSupport::FactoryBot.check_version
11
+ Spree::TestingSupport::FactoryBot::PATHS.each { |path| require path }
@@ -1,8 +1,12 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/state_factory'
4
- require 'spree/testing_support/factories/country_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
5
6
 
7
+ require 'spree/testing_support/factories/state_factory'
8
+ require 'spree/testing_support/factories/country_factory'
9
+ end
6
10
  FactoryBot.define do
7
11
  factory :address, class: 'Spree::Address' do
8
12
  transient do
@@ -1,10 +1,15 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/line_item_factory'
4
- require 'spree/testing_support/factories/order_factory'
5
- require 'spree/testing_support/factories/tax_category_factory'
6
- require 'spree/testing_support/factories/tax_rate_factory'
7
- require 'spree/testing_support/factories/zone_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/line_item_factory'
8
+ require 'spree/testing_support/factories/order_factory'
9
+ require 'spree/testing_support/factories/tax_category_factory'
10
+ require 'spree/testing_support/factories/tax_rate_factory'
11
+ require 'spree/testing_support/factories/zone_factory'
12
+ end
8
13
 
9
14
  FactoryBot.define do
10
15
  factory :adjustment, class: 'Spree::Adjustment' do
@@ -1,5 +1,10 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+ end
7
+
3
8
  FactoryBot.define do
4
9
  factory :adjustment_reason, class: 'Spree::AdjustmentReason' do
5
10
  sequence(:name) { |n| "Refund for return ##{n}" }
@@ -1,5 +1,10 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+ end
7
+
3
8
  FactoryBot.define do
4
9
  factory :calculator, aliases: [:flat_rate_calculator], class: 'Spree::Calculator::FlatRate' do
5
10
  preferred_amount { 10.0 }
@@ -1,7 +1,12 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/shipment_factory'
4
- require 'spree/testing_support/factories/inventory_unit_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/shipment_factory'
8
+ require 'spree/testing_support/factories/inventory_unit_factory'
9
+ end
5
10
 
6
11
  FactoryBot.define do
7
12
  factory :carton, class: 'Spree::Carton' do
@@ -1,5 +1,10 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+ end
7
+
3
8
  require 'carmen'
4
9
 
5
10
  FactoryBot.define do
@@ -1,5 +1,10 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+ end
7
+
3
8
  FactoryBot.define do
4
9
  factory :credit_card, class: 'Spree::CreditCard' do
5
10
  verification_value { 123 }
@@ -1,8 +1,13 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/stock_location_factory'
4
- require 'spree/testing_support/factories/order_factory'
5
- require 'spree/testing_support/factories/return_item_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/stock_location_factory'
8
+ require 'spree/testing_support/factories/order_factory'
9
+ require 'spree/testing_support/factories/return_item_factory'
10
+ end
6
11
 
7
12
  FactoryBot.define do
8
13
  factory :customer_return, class: 'Spree::CustomerReturn' do
@@ -1,5 +1,10 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+ end
7
+
3
8
  FactoryBot.define do
4
9
  factory :image, class: 'Spree::Image' do
5
10
  attachment { Spree::Core::Engine.root.join('lib', 'spree', 'testing_support', 'fixtures', 'blank.jpg').open }
@@ -1,9 +1,14 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/line_item_factory'
4
- require 'spree/testing_support/factories/variant_factory'
5
- require 'spree/testing_support/factories/order_factory'
6
- require 'spree/testing_support/factories/shipment_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/line_item_factory'
8
+ require 'spree/testing_support/factories/variant_factory'
9
+ require 'spree/testing_support/factories/order_factory'
10
+ require 'spree/testing_support/factories/shipment_factory'
11
+ end
7
12
 
8
13
  FactoryBot.define do
9
14
  factory :inventory_unit, class: 'Spree::InventoryUnit' do
@@ -1,7 +1,12 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/order_factory'
4
- require 'spree/testing_support/factories/product_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/order_factory'
8
+ require 'spree/testing_support/factories/product_factory'
9
+ end
5
10
 
6
11
  FactoryBot.define do
7
12
  factory :line_item, class: 'Spree::LineItem' do
@@ -1,5 +1,13 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/product_factory'
8
+ require 'spree/testing_support/factories/option_type_factory'
9
+ end
10
+
3
11
  FactoryBot.define do
4
12
  factory :option_type, class: 'Spree::OptionType' do
5
13
  sequence(:name) { |n| "foo-size-#{n}" }
@@ -1,5 +1,10 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+ end
7
+
3
8
  FactoryBot.define do
4
9
  factory :option_value, class: 'Spree::OptionValue' do
5
10
  sequence(:name) { |n| "Size-#{n}" }
@@ -1,11 +1,16 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/address_factory'
4
- require 'spree/testing_support/factories/shipment_factory'
5
- require 'spree/testing_support/factories/store_factory'
6
- require 'spree/testing_support/factories/user_factory'
7
- require 'spree/testing_support/factories/line_item_factory'
8
- require 'spree/testing_support/factories/payment_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/address_factory'
8
+ require 'spree/testing_support/factories/shipment_factory'
9
+ require 'spree/testing_support/factories/store_factory'
10
+ require 'spree/testing_support/factories/user_factory'
11
+ require 'spree/testing_support/factories/line_item_factory'
12
+ require 'spree/testing_support/factories/payment_factory'
13
+ end
9
14
 
10
15
  FactoryBot.define do
11
16
  factory :order, class: 'Spree::Order' do
@@ -1,7 +1,12 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/order_factory'
4
- require 'spree/testing_support/factories/promotion_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/order_factory'
8
+ require 'spree/testing_support/factories/promotion_factory'
9
+ end
5
10
 
6
11
  FactoryBot.define do
7
12
  factory :order_promotion, class: 'Spree::OrderPromotion' do
@@ -1,9 +1,14 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'spree/testing_support/factories/payment_method_factory'
4
- require 'spree/testing_support/factories/credit_card_factory'
5
- require 'spree/testing_support/factories/order_factory'
6
- require 'spree/testing_support/factories/store_credit_factory'
3
+ require 'spree/testing_support/factory_bot'
4
+ Spree::TestingSupport::FactoryBot.when_cherry_picked do
5
+ Spree::TestingSupport::FactoryBot.deprecate_cherry_picking
6
+
7
+ require 'spree/testing_support/factories/payment_method_factory'
8
+ require 'spree/testing_support/factories/credit_card_factory'
9
+ require 'spree/testing_support/factories/order_factory'
10
+ require 'spree/testing_support/factories/store_credit_factory'
11
+ end
7
12
 
8
13
  FactoryBot.define do
9
14
  factory :payment, aliases: [:credit_card_payment], class: 'Spree::Payment' do