1
0
forked from Mapan/odoo17e
odoo17e-kedaikipas58/addons/account_disallowed_expenses_fleet/tests/test_deferred_fleet.py
2024-12-10 09:04:09 +07:00

164 lines
7.0 KiB
Python

# -*- coding: utf-8 -*-
from odoo.addons.account_reports.tests.common import TestAccountReportsCommon
from odoo import Command, fields
from odoo.tests import tagged
@tagged('post_install', '-at_install')
class TestDeferredFleet(TestAccountReportsCommon):
@classmethod
def setUpClass(cls, chart_template_ref=None):
super().setUpClass(chart_template_ref=chart_template_ref)
cls.expense_accounts = [cls.env['account.account'].create({
'name': f'Expense {i}',
'code': f'EXP{i}',
'account_type': 'expense',
}) for i in range(3)]
cls.company = cls.company_data['company']
cls.company.deferred_journal_id = cls.company_data['default_journal_misc'].id
cls.company.deferred_expense_account_id = cls.company_data['default_account_deferred_expense'].id
cls.expense_lines = [
[cls.expense_accounts[0], 1000, '2023-01-01', '2023-04-30'], # 4 full months (=250/month)
[cls.expense_accounts[0], 1050, '2023-01-16', '2023-04-30'], # 3 full months + 15 days (=300/month)
[cls.expense_accounts[1], 1225, '2023-01-01', '2023-04-15'], # 3 full months + 15 days (=350/month)
[cls.expense_accounts[2], 1680, '2023-01-21', '2023-04-14'], # 2 full months + 10 days + 14 days (=600/month)
[cls.expense_accounts[2], 225, '2023-04-01', '2023-04-15'], # 15 days (=450/month)
]
cls.batmobile, cls.batpod = cls.env['fleet.vehicle'].create([{
'model_id': cls.env['fleet.vehicle.model'].create({
'name': name,
'brand_id': cls.env['fleet.vehicle.model.brand'].create({
'name': 'Wayne Enterprises',
}).id,
'vehicle_type': vehicle_type,
'default_fuel_type': 'hydrogen',
}).id,
'rate_ids': [Command.create({
'date_from': fields.Date.from_string('2022-01-01'),
'rate': rate,
})],
} for name, vehicle_type, rate in [('Batmobile', 'car', 31.0), ('Batpod', 'bike', 56.0)]
])
def test_deferred_fleet_on_validation_mode(self):
move = self.env['account.move'].create({
'move_type': 'in_invoice',
'partner_id': self.partner_a.id,
'date': '2023-01-01',
'invoice_date': '2023-01-01',
'journal_id': self.company_data['default_journal_purchase'].id,
'invoice_line_ids': [
Command.create({
'product_id': self.product_a.id,
'quantity': 1,
'account_id': self.expense_accounts[0].id,
'price_unit': 1000,
'deferred_start_date': '2023-02-01',
'deferred_end_date': '2023-02-28',
'vehicle_id': self.batmobile.id,
}),
]
})
move.action_post()
self.assertRecordValues(move.deferred_move_ids.line_ids, [
{'vehicle_id': self.batmobile.id} for _ in range(4)
])
def test_deferred_fleet_manually_and_grouped_mode(self):
"""
Test that the vehicle is correctly exported to the deferred move lines in the manually & grouped mode
We cannot have multiple vehicles on the same move line (on one account), therefore, we'll have as many
deferral lines as we have unique combinations of (account_id, vehicle_id).
"""
self.company.generate_deferred_expense_entries_method = 'manual'
self.company.deferred_amount_computation_method = 'month'
def get_line(vehicle, account, amount):
return Command.create({
'quantity': 1,
'account_id': account.id,
'price_unit': amount,
'deferred_start_date': '2023-01-01',
'deferred_end_date': '2023-10-31',
'vehicle_id': vehicle.id if vehicle else False,
})
self.env['account.move'].create({
'move_type': 'in_invoice',
'partner_id': self.partner_a.id,
'date': '2023-01-01',
'invoice_date': '2023-01-01',
'journal_id': self.company_data['default_journal_purchase'].id,
'invoice_line_ids': [
get_line(self.batmobile, self.expense_accounts[0], 1000),
get_line(self.batpod, self.expense_accounts[0], 2000),
get_line(self.batpod, self.expense_accounts[1], 5000),
get_line(self.batpod, self.expense_accounts[1], 10000),
get_line(False, self.expense_accounts[1], 10000),
get_line(False, self.expense_accounts[1], 10000),
]
}).action_post()
options = self._generate_options(self.env.ref('account_reports.deferred_expense_report'), '2023-01-01', '2023-01-31')
deferral_entries = self.env['account.deferred.expense.report.handler']._generate_deferral_entry(options)
# account 0, vehicle 0: 1000
# account 0, vehicle 1: 2000
# account 1, vehicle 1: 15000
# account 1, no vehicle: 20000
expected_values = [{
'account_id': self.expense_accounts[0].id,
'vehicle_id': self.batmobile.id,
'balance': -1000,
}, {
'account_id': self.expense_accounts[0].id,
'vehicle_id': self.batmobile.id,
'balance': 100,
}, {
'account_id': self.expense_accounts[0].id,
'vehicle_id': self.batpod.id,
'balance': -2000,
}, {
'account_id': self.expense_accounts[0].id,
'vehicle_id': self.batpod.id,
'balance': 200,
}, {
'account_id': self.expense_accounts[1].id,
'vehicle_id': self.batpod.id,
'balance': -15000,
}, {
'account_id': self.expense_accounts[1].id,
'vehicle_id': self.batpod.id,
'balance': 1500,
}, {
'account_id': self.expense_accounts[1].id,
'vehicle_id': False,
'balance': -20000,
}, {
'account_id': self.expense_accounts[1].id,
'vehicle_id': False,
'balance': 2000,
}, {
'account_id': self.company.deferred_expense_account_id.id,
'vehicle_id': self.batmobile.id,
'balance': 900,
}, {
'account_id': self.company.deferred_expense_account_id.id,
'vehicle_id': self.batpod.id,
'balance': 13500 + 1800,
}, {
'account_id': self.company.deferred_expense_account_id.id,
'vehicle_id': False,
'balance': 18000,
}]
for line, expected in zip(deferral_entries[0].line_ids, expected_values):
self.assertRecordValues(line, [{
'account_id': expected['account_id'],
'vehicle_id': expected['vehicle_id'],
'balance': expected['balance'],
}
])