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

118 lines
4.7 KiB
Python

# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from datetime import date
from dateutil.relativedelta import relativedelta
from odoo import Command
from odoo.addons.project.tests.test_project_base import TestProjectCommon
class TestProject(TestProjectCommon):
@classmethod
def setUpClass(cls):
super().setUpClass()
cls.analytic_plan = cls.env['account.analytic.plan'].create({
'name': 'Plan',
})
cls.analytic_account = cls.env['account.analytic.account'].create({
'name': 'Project - AA',
'code': 'AA-1234',
'plan_id': cls.analytic_plan.id,
})
cls.project_goats.write({'analytic_account_id': cls.analytic_account.id})
def test_get_budget_items(self):
if not self.project_pigs.analytic_account_id:
self.assertEqual(self.project_pigs._get_budget_items(False), None, 'No budget should be return since no AA is set into the project.')
self.assertTrue(self.env.user.has_group('analytic.group_analytic_accounting'))
self.assertDictEqual(
self.project_goats._get_budget_items(False),
{
'data': [],
'total': {'allocated': 0, 'progress': 0, 'spent': 0},
'can_add_budget': False,
},
'No budget has been created for this project.'
)
today = date.today()
budget = self.env['crossovered.budget'].create({
'name': 'Project Goats Budget',
'crossovered_budget_line': [Command.create({
'analytic_account_id': self.analytic_account.id,
'date_from': today.replace(day=1),
'date_to': today + relativedelta(months=1, days=-1),
'planned_amount': 500,
})],
})
budget.action_budget_confirm()
budget_items = self.project_goats._get_budget_items(False)
del budget_items['data'][0]['name'] # remove the name because it is a lazy translation.
del budget_items['data'][0]['id']
self.assertDictEqual(budget_items, {
'data': [
{
'allocated': 500,
'budgets': [],
'spent': 0.0,
},
],
'total': {'allocated': 500.0, 'spent': 0.0, 'progress': -1.0},
'can_add_budget': False,
})
def test_get_budget_items_with_action(self):
today = date.today()
budgets = self.env['crossovered.budget']
for budget_name, planned_amount in [
('Project Goats Budget', 500),
('Project Pigs Budget', 1000),
]:
budget = self.env['crossovered.budget'].create({
'name': budget_name,
'crossovered_budget_line': [
Command.create({
'analytic_account_id': self.analytic_account.id,
'date_from': today.replace(day=1),
'date_to': today + relativedelta(months=1, days=-1),
'planned_amount': planned_amount,
}),
],
})
budget.action_budget_confirm()
budgets += budget
self.env.user.groups_id += self.env.ref('account.group_account_user')
budget_items = self.project_goats.with_context({'allowed_company_ids': [self.env.company.id]})._get_budget_items(with_action=True)
del budget_items['data'][0]['name'] # remove the name because it is a lazy translation.
del budget_items['data'][0]['budgets'][0]['name']
del budget_items['data'][0]['budgets'][1]['name']
del budget_items['data'][0]['id']
del budget_items['data'][0]['budgets'][0]['id']
del budget_items['data'][0]['budgets'][1]['id']
self.assertDictEqual(budget_items, {
'data': [
{
'allocated': 1500.0,
'spent': 0.0,
'budgets': [
{'allocated': 500.0, 'spent': 0.0, 'progress': -1.0},
{'allocated': 1000.0, 'spent': 0.0, 'progress': -1.0},
],
'action': {
'name': 'action_view_budget_lines',
'type': 'object',
'domain': f'[["id", "in", {budgets.crossovered_budget_line.ids}]]',
}
},
],
'total': {'allocated': 1500.0, 'spent': 0.0, 'progress': -1.0},
'form_view_id': self.env.ref('project_account_budget.crossovered_budget_view_form_dialog').id,
'can_add_budget': True,
'company_id': self.env.company.id,
})