1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-18 07:52:23 +01:00

115 lines
4.1 KiB
Ruby
Raw Normal View History

2020-03-13 17:10:38 +01:00
# frozen_string_literal: true
2016-11-28 11:49:59 +01:00
module Events
class AsUserTest < ActionDispatch::IntegrationTest
2016-12-01 12:12:44 +01:00
test 'reserve event with many prices and payment means and VAT' do
vlonchamp = User.find_by(username: 'vlonchamp')
login_as(vlonchamp, scope: :user)
2016-11-28 11:49:59 +01:00
radio = Event.find(4)
availability = radio.availability
reservations_count = Reservation.count
invoice_count = Invoice.count
invoice_items_count = InvoiceItem.count
users_credit_count = UsersCredit.count
wallet_transactions_count = WalletTransaction.count
2016-11-28 11:49:59 +01:00
2016-12-01 12:12:44 +01:00
# Enable the VAT at 19.6%
vat_active = Setting.find_by(name: 'invoice_VAT-active')
vat_active.value = 'true'
vat_active.save!
vat_rate = Setting.find_by(name: 'invoice_VAT-rate')
vat_rate.value = '19.6'
vat_rate.save!
2016-11-28 11:49:59 +01:00
# Reserve the 'radio' event
VCR.use_cassette('reserve_event_with_many_prices_and_payment_means') do
post '/api/payments/confirm_payment',
2020-03-13 17:10:38 +01:00
params: {
payment_method_id: stripe_payment_method,
cart_items: {
reservation: {
user_id: User.find_by(username: 'vlonchamp').id,
reservable_id: radio.id,
reservable_type: 'Event',
nb_reserve_places: 2,
slots_attributes: [
{
start_at: availability.start_at,
end_at: availability.end_at,
availability_id: availability.id,
offered: false
}
],
tickets_attributes: [
{
event_price_category_id: radio.event_price_categories[0].id,
booked: 2
},
{
event_price_category_id: radio.event_price_categories[1].id,
booked: 2
}
]
},
coupon_code: 'SUNNYFABLAB'
}
2020-03-13 17:10:38 +01:00
}.to_json, headers: default_headers
2016-11-28 11:49:59 +01:00
end
vlonchamp.wallet.reload
# general assertions
assert_equal 201, response.status
assert_equal reservations_count + 1, Reservation.count
assert_equal invoice_count + 1, Invoice.count
assert_equal invoice_items_count + 1, InvoiceItem.count
assert_equal users_credit_count, UsersCredit.count
assert_equal wallet_transactions_count + 1, WalletTransaction.count
# reservation assertions
reservation = Reservation.last
assert reservation.invoice
assert_equal 1, reservation.invoice.invoice_items.count
# invoice assertions
invoice = reservation.invoice
refute invoice.stp_payment_intent_id.blank?
refute invoice.total.blank?
2020-03-13 17:10:38 +01:00
assert_equal 43_350, invoice.total # total minus coupon
# invoice_items assertions
## reservation
reservation_item = invoice.invoice_items.first
assert_not_nil reservation_item
2020-03-13 17:10:38 +01:00
assert_equal 51_000, reservation_item.amount # full total
# invoice assertions
invoice = Invoice.find_by(invoiced: reservation)
assert_invoice_pdf invoice
VCR.use_cassette('reserve_event_with_many_prices_and_payment_means_retrieve_invoice_from_stripe') do
2020-06-10 11:33:03 +02:00
stp_intent = Stripe::PaymentIntent.retrieve(invoice.stp_payment_intent_id, api_key: Setting.get('stripe_secret_key'))
assert_equal stp_intent.amount, (invoice.total - invoice.wallet_amount) # total minus coupon minus wallet = amount really payed by the user
end
# wallet assertions
assert_equal vlonchamp.wallet.amount, 0
assert_equal vlonchamp.wallet.wallet_transactions.count, 2
transaction = vlonchamp.wallet.wallet_transactions.last
assert_equal transaction.transaction_type, 'debit'
assert_equal transaction.amount, 10
assert_equal transaction.amount, invoice.wallet_amount / 100.0
# notifications
assert_not_empty Notification.where(attached_object: reservation)
assert_not_empty Notification.where(attached_object: invoice)
2016-11-28 11:49:59 +01:00
end
end
end