houdini/spec/lib/update/update_charges_spec.rb
2019-08-02 19:07:29 +02:00

47 lines
1.8 KiB
Ruby

# frozen_string_literal: true
# License: AGPL-3.0-or-later WITH Web-Template-Output-Additional-Permission-3.0-or-later
require 'rails_helper'
describe UpdateCharges do
describe '.disburse_all_with_payments', pending: true do
it 'test' do
raise
end
end
describe '.reverse_disburse_all_with_payments' do
let(:payment_to_reverse) { force_create(:payment) }
let(:payment_to_ignore) { force_create(:payment) }
let(:payment_to_reverse_2) { force_create(:payment) }
let(:payment_to_reverse_with_refund) { force_create(:payment) }
let(:reverse_payment_for_refund) { force_create(:payment) }
let!(:charges) do
[force_create(:charge, payment: payment_to_reverse, status: 'disbursed'),
force_create(:charge, payment: payment_to_reverse_2, status: 'disbursed'),
force_create(:charge, payment: payment_to_ignore, status: 'disbursed'),
force_create(:charge, payment: payment_to_reverse_with_refund, status: 'disbursed')]
end
let!(:refunds) { [force_create(:refund, charge: charges.last, payment: reverse_payment_for_refund, disbursed: true)] }
before(:each) do
UpdateCharges.reverse_disburse_all_with_payments([payment_to_reverse.id, payment_to_reverse_2.id, payment_to_reverse_with_refund.id, reverse_payment_for_refund.id])
payment_to_reverse.reload
payment_to_reverse_2.reload
payment_to_reverse_with_refund.reload
payment_to_ignore.reload
end
it 'reverses payments it should' do
expect(payment_to_reverse.charge.status).to eq 'available'
expect(payment_to_reverse_2.charge.status).to eq 'available'
expect(payment_to_reverse_with_refund.charge.status).to eq 'available'
end
it 'does not reverse other payments' do
expect(payment_to_ignore.charge.status).to eq 'disbursed'
end
end
end