diff --git a/core/app/models/spree/payment_source.rb b/core/app/models/spree/payment_source.rb index 14133f6f7d7..0832fc5de76 100644 --- a/core/app/models/spree/payment_source.rb +++ b/core/app/models/spree/payment_source.rb @@ -7,7 +7,11 @@ class PaymentSource < Spree::Base belongs_to :payment_method, optional: true has_many :payments, as: :source - has_many :wallet_payment_sources, class_name: 'Spree::WalletPaymentSource', as: :payment_source, inverse_of: :payment_source + has_many :wallet_payment_sources, + class_name: 'Spree::WalletPaymentSource', + as: :payment_source, + inverse_of: :payment_source, + dependent: :destroy attr_accessor :imported diff --git a/core/spec/support/concerns/payment_source.rb b/core/spec/support/concerns/payment_source.rb index 10ef52b9cc2..c64c3ea93e8 100644 --- a/core/spec/support/concerns/payment_source.rb +++ b/core/spec/support/concerns/payment_source.rb @@ -13,6 +13,24 @@ it { is_expected.to respond_to(:user) } end + describe "#wallet_payment_sources" do + let(:user) { create(:user) } + + let!(:wallet_payment_source) do + # There are nasty validations that do not matter for this test + payment_source.save(validate: false) + Spree::WalletPaymentSource.new(user: user, payment_source: payment_source).tap do |wps| + wps.save(validate: false) + end + end + + context "when the payment source gets destroyed" do + it "destroys the wallet payment source" do + expect { payment_source.destroy }.to change { Spree::WalletPaymentSource.count }.by(-1) + end + end + end + describe "#can_capture?" do it "should be true if payment is pending" do payment = mock_model(Spree::Payment, pending?: true, created_at: Time.current)