1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-25 14:52:20 +01:00

96 lines
2.9 KiB
Ruby
Raw Normal View History

2020-03-13 17:10:38 +01:00
# frozen_string_literal: true
2021-07-02 15:45:52 +02:00
require 'test_helper'
2023-02-24 17:26:55 +01:00
module Prices; end
2016-12-12 16:44:56 +01:00
2023-02-24 17:26:55 +01:00
class Prices::AsAdminTest < ActionDispatch::IntegrationTest
setup do
admin = User.with_role(:admin).first
login_as(admin, scope: :user)
end
test 'compute price for a simple training' do
user = User.find_by(username: 'jdupond')
availability = Availability.find(2)
slot = Availability.find(2).slots.first
printer_training = availability.trainings.first
2016-12-12 16:44:56 +01:00
2023-02-24 17:26:55 +01:00
post '/api/prices/compute',
params: {
customer_id: user.id,
items: [
{
reservation: {
reservable_id: printer_training.id,
reservable_type: printer_training.class.name,
slots_reservations_attributes: [
{
slot_id: slot.id,
offered: false
}
]
}
2023-02-24 17:26:55 +01:00
}
]
}.to_json,
headers: default_headers
2016-12-12 16:44:56 +01:00
2023-02-24 17:26:55 +01:00
# Check response format & status
assert_equal 200, response.status, response.body
assert_match Mime[:json].to_s, response.content_type
2016-12-12 16:44:56 +01:00
2023-02-24 17:26:55 +01:00
# Check the price was computed correctly
price = json_response(response.body)
assert_equal (printer_training.trainings_pricings.where(group_id: user.group_id).first.amount / 100.0),
price[:price],
'Computed price did not match training price'
end
2016-12-12 16:44:56 +01:00
2023-02-24 17:26:55 +01:00
test 'compute price for a machine reservation with an offered slot and a subscription' do
user = User.find_by(username: 'jdupond')
availability = Availability.find(3)
laser = availability.machines.where(id: 1).first
plan = Plan.find_by(group_id: user.group_id, interval: 'month')
2016-12-12 16:44:56 +01:00
2023-02-24 17:26:55 +01:00
post '/api/prices/compute',
params: {
customer_id: user.id,
items: [
{
reservation: {
reservable_id: laser.id,
reservable_type: laser.class.name,
slots_reservations_attributes: [
{
slot_id: availability.slots.first.id,
offered: true
},
{
slot_id: availability.slots.last.id,
offered: false
}
]
}
},
{
subscription: {
plan_id: plan.id
}
2023-02-24 17:26:55 +01:00
}
]
}.to_json,
headers: default_headers
2016-12-12 16:44:56 +01:00
2023-02-24 17:26:55 +01:00
# Check response format & status
assert_equal 200, response.status, response.body
assert_match Mime[:json].to_s, response.content_type
2016-12-12 16:44:56 +01:00
2023-02-24 17:26:55 +01:00
# Check the event was created correctly
price = json_response(response.body)
assert_equal ((laser.prices.where(group_id: user.group_id, plan_id: plan.id).first.amount + plan.amount) / 100.0),
price[:price],
'Computed price did not match machine + subscription price'
2016-12-12 16:44:56 +01:00
end
end