2019-09-20 17:40:27 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Exports; end
|
|
|
|
|
|
|
|
class Exports::AccountingExportTest < ActionDispatch::IntegrationTest
|
|
|
|
setup do
|
|
|
|
admin = User.with_role(:admin).first
|
|
|
|
login_as(admin, scope: :user)
|
|
|
|
end
|
|
|
|
|
|
|
|
test 'creation modification reservation and re-modification scenario' do
|
|
|
|
# First, we create a new export
|
|
|
|
post '/api/accounting/export',
|
2020-03-13 17:10:38 +01:00
|
|
|
params: {
|
2019-09-20 17:40:27 +02:00
|
|
|
query: {
|
|
|
|
columns: %w[journal_code date account_code account_label piece line_label debit_origin credit_origin debit_euro credit_euro lettering],
|
|
|
|
encoding: 'ISO-8859-1',
|
|
|
|
date_format: '%d/%m/%Y',
|
|
|
|
start_date: '2012-03-12T00:00:00.000Z',
|
2019-12-02 15:29:05 +01:00
|
|
|
end_date: DateTime.current.utc.iso8601,
|
2019-09-20 17:40:27 +02:00
|
|
|
label_max_length: 50,
|
|
|
|
decimal_separator: ',',
|
|
|
|
export_invoices_at_zero: false
|
|
|
|
}.to_json.to_s,
|
|
|
|
extension: 'csv',
|
|
|
|
type: 'acd',
|
|
|
|
key: ';'
|
|
|
|
}.to_json,
|
2020-03-13 17:10:38 +01:00
|
|
|
headers: default_headers
|
2019-09-20 17:40:27 +02:00
|
|
|
|
|
|
|
# Check response format & status
|
|
|
|
assert_equal 200, response.status, response.body
|
2020-03-13 17:10:38 +01:00
|
|
|
assert_equal Mime[:json], response.content_type
|
2019-09-20 17:40:27 +02:00
|
|
|
|
|
|
|
# Check the export was created correctly
|
|
|
|
res = json_response(response.body)
|
|
|
|
e = Export.where(id: res[:export_id]).first
|
|
|
|
assert_not_nil e, 'Export was not created in database'
|
|
|
|
|
|
|
|
# Run the worker
|
|
|
|
worker = AccountingExportWorker.new
|
|
|
|
worker.perform(e.id)
|
|
|
|
|
|
|
|
# notification
|
|
|
|
assert_not_empty Notification.where(attached_object: e)
|
|
|
|
|
|
|
|
# resulting CSV file
|
|
|
|
assert FileTest.exist?(e.file), 'CSV file was not generated'
|
|
|
|
require 'csv'
|
|
|
|
data = CSV.read(e.file, headers: true, col_sep: e.key)
|
|
|
|
|
|
|
|
# test values
|
|
|
|
# first line = client line
|
|
|
|
journal_code = Setting.find_by(name: 'accounting_journal_code').value
|
|
|
|
assert_equal journal_code, data[0][I18n.t('accounting_export.journal_code')], 'Wrong journal code'
|
|
|
|
|
|
|
|
first_invoice = Invoice.first
|
|
|
|
entry_date = first_invoice.created_at.to_date
|
|
|
|
assert_equal entry_date, DateTime.parse(data[0][I18n.t('accounting_export.date')]), 'Wrong date'
|
|
|
|
|
|
|
|
if first_invoice.paid_with_stripe?
|
|
|
|
card_client_code = Setting.find_by(name: 'accounting_card_client_code').value
|
|
|
|
assert_equal card_client_code, data[0][I18n.t('accounting_export.account_code')], 'Account code for card client is wrong'
|
|
|
|
|
|
|
|
card_client_label = Setting.find_by(name: 'accounting_card_client_label').value
|
|
|
|
assert_equal card_client_label, data[0][I18n.t('accounting_export.account_label')], 'Account label for card client is wrong'
|
|
|
|
else
|
|
|
|
STDERR.puts "WARNING: unable to test accurately accounting export: invoice #{first_invoice.id} was not paid by card"
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal first_invoice.reference, data[0][I18n.t('accounting_export.piece')], 'Piece (invoice reference) is wrong'
|
|
|
|
|
|
|
|
if first_invoice.subscription_invoice?
|
|
|
|
assert_match I18n.t('accounting_export.subscription'),
|
|
|
|
data[0][I18n.t('accounting_export.line_label')],
|
|
|
|
'Line label does not contains the reference to the invoiced item'
|
|
|
|
else
|
|
|
|
STDERR.puts "WARNING: unable to test accurately accounting export: invoice #{first_invoice.id} does not have a subscription"
|
|
|
|
end
|
|
|
|
|
|
|
|
if first_invoice.wallet_transaction_id.nil?
|
|
|
|
assert_equal first_invoice.total / 100.00, data[0][I18n.t('accounting_export.debit_origin')].to_f, 'Origin debit amount does not match'
|
|
|
|
assert_equal first_invoice.total / 100.00, data[0][I18n.t('accounting_export.debit_euro')].to_f, 'Euro debit amount does not match'
|
|
|
|
else
|
|
|
|
STDERR.puts "WARNING: unable to test accurately accounting export: invoice #{first_invoice.id} is using wallet"
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal 0, data[0][I18n.t('accounting_export.credit_origin')].to_f, 'Credit origin amount does not match'
|
|
|
|
assert_equal 0, data[0][I18n.t('accounting_export.credit_euro')].to_f, 'Credit euro amount does not match'
|
|
|
|
|
|
|
|
# second line = sold item line
|
|
|
|
assert_equal journal_code, data[1][I18n.t('accounting_export.journal_code')], 'Wrong journal code'
|
|
|
|
assert_equal entry_date, DateTime.parse(data[1][I18n.t('accounting_export.date')]), 'Wrong date'
|
|
|
|
|
|
|
|
if first_invoice.subscription_invoice?
|
|
|
|
subscription_code = Setting.find_by(name: 'accounting_subscription_code').value
|
|
|
|
assert_equal subscription_code, data[1][I18n.t('accounting_export.account_code')], 'Account code for subscription is wrong'
|
|
|
|
|
|
|
|
subscription_label = Setting.find_by(name: 'accounting_subscription_label').value
|
|
|
|
assert_equal subscription_label, data[1][I18n.t('accounting_export.account_label')], 'Account label for subscription is wrong'
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal first_invoice.reference, data[1][I18n.t('accounting_export.piece')], 'Piece (invoice reference) is wrong'
|
2019-10-21 14:23:38 +02:00
|
|
|
assert_match I18n.t('accounting_export.subscription'),
|
|
|
|
data[1][I18n.t('accounting_export.line_label')],
|
|
|
|
'Line label should be empty for non client lines'
|
2019-09-20 17:40:27 +02:00
|
|
|
|
|
|
|
item = first_invoice.invoice_items.first
|
|
|
|
assert_equal item.amount / 100.00, data[1][I18n.t('accounting_export.credit_origin')].to_f, 'Origin credit amount does not match'
|
|
|
|
assert_equal item.amount / 100.00, data[1][I18n.t('accounting_export.credit_euro')].to_f, 'Euro credit amount does not match'
|
|
|
|
|
|
|
|
assert_equal 0, data[1][I18n.t('accounting_export.debit_origin')].to_f, 'Debit origin amount does not match'
|
|
|
|
assert_equal 0, data[1][I18n.t('accounting_export.debit_euro')].to_f, 'Debit euro amount does not match'
|
|
|
|
|
|
|
|
# test with another invoice
|
|
|
|
last_invoice = Invoice.last
|
|
|
|
client_row = data[data.length - 2]
|
|
|
|
item_row = data[data.length - 1]
|
|
|
|
|
|
|
|
if last_invoice.invoiced_type == 'Reservation' && last_invoice.invoiced.reservable_type == 'Machine'
|
|
|
|
assert_match I18n.t('accounting_export.Machine_reservation'),
|
|
|
|
client_row[I18n.t('accounting_export.line_label')],
|
|
|
|
'Line label does not contains the reference to the invoiced item'
|
|
|
|
|
|
|
|
machine_code = Setting.find_by(name: 'accounting_Machine_code').value
|
|
|
|
assert_equal machine_code, item_row[I18n.t('accounting_export.account_code')], 'Account code for machine reservation is wrong'
|
|
|
|
|
|
|
|
machine_label = Setting.find_by(name: 'accounting_Machine_label').value
|
|
|
|
assert_equal machine_label, item_row[I18n.t('accounting_export.account_label')], 'Account label for machine reservation is wrong'
|
|
|
|
|
|
|
|
else
|
|
|
|
STDERR.puts "WARNING: unable to test accurately accounting export: invoice #{last_invoice.id} is not a Machine reservation"
|
|
|
|
end
|
|
|
|
|
|
|
|
# Clean CSV file
|
|
|
|
require 'fileutils'
|
|
|
|
FileUtils.rm(e.file)
|
|
|
|
end
|
|
|
|
end
|