houdini/spec/lib/update/update_charges_spec.rb

44 lines
No EOL
1.8 KiB
Ruby

# 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
fail
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) {[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')]}
let!(:refunds) { [force_create(:refund, charge: charges.last, payment: reverse_payment_for_refund, disbursed: true)]}
before(:each) {
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
}
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