2017-07-06 09:41:05 +02:00
|
|
|
# Copyright 2017 ACSONE SA/NV
|
|
|
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
|
|
|
|
|
|
|
from odoo.fields import Date
|
|
|
|
from odoo.tests.common import TransactionCase
|
|
|
|
|
|
|
|
|
|
|
|
class TestAccountMoveFiscalMonth(TransactionCase):
|
|
|
|
def setUp(self):
|
|
|
|
super(TestAccountMoveFiscalMonth, self).setUp()
|
2020-11-17 02:38:56 +01:00
|
|
|
self.AccountObj = self.env["account.account"]
|
|
|
|
self.AccountJournalObj = self.env["account.journal"]
|
|
|
|
self.AccountMoveObj = self.env["account.move"]
|
|
|
|
self.DateRangeObj = self.env["date.range"]
|
|
|
|
|
|
|
|
self.bank_journal = self.AccountJournalObj.search(
|
|
|
|
[("type", "=", "bank")], limit=1
|
|
|
|
)
|
|
|
|
|
|
|
|
self.account_type_recv = self.env.ref("account.data_account_type_receivable")
|
|
|
|
self.account_type_rev = self.env.ref("account.data_account_type_revenue")
|
|
|
|
|
|
|
|
self.account_recv = self.AccountObj.create(
|
|
|
|
{
|
|
|
|
"code": "RECV_DR",
|
|
|
|
"name": "Receivable (test)",
|
|
|
|
"reconcile": True,
|
|
|
|
"user_type_id": self.account_type_recv.id,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
self.account_sale = self.AccountObj.create(
|
|
|
|
{
|
|
|
|
"code": "SALE_DR",
|
|
|
|
"name": "Receivable (sale)",
|
|
|
|
"reconcile": True,
|
|
|
|
"user_type_id": self.account_type_rev.id,
|
|
|
|
}
|
|
|
|
)
|
2017-07-06 09:41:05 +02:00
|
|
|
|
|
|
|
self.date_range_type_month = self.env.ref(
|
2020-11-17 02:38:56 +01:00
|
|
|
"account_fiscal_month.date_range_fiscal_month"
|
|
|
|
)
|
|
|
|
|
|
|
|
self.date_range_january_2017 = self.DateRangeObj.create(
|
|
|
|
{
|
|
|
|
"name": "January 2017",
|
|
|
|
"date_start": "2017-01-01",
|
|
|
|
"date_end": "2017-01-31",
|
|
|
|
"type_id": self.date_range_type_month.id,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
self.date_range_february_2017 = self.DateRangeObj.create(
|
|
|
|
{
|
|
|
|
"name": "February 2017",
|
|
|
|
"date_start": "2017-02-01",
|
|
|
|
"date_end": "2017-02-28",
|
|
|
|
"type_id": self.date_range_type_month.id,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
self.date_range_january_2018 = self.DateRangeObj.create(
|
|
|
|
{
|
|
|
|
"name": "January 2018",
|
|
|
|
"date_start": "2018-01-01",
|
|
|
|
"date_end": "2018-01-31",
|
|
|
|
"type_id": self.date_range_type_month.id,
|
|
|
|
}
|
|
|
|
)
|
2017-07-06 09:41:05 +02:00
|
|
|
|
|
|
|
def create_account_move(self, date_str):
|
2020-11-17 02:38:56 +01:00
|
|
|
return self.AccountMoveObj.create(
|
|
|
|
{
|
|
|
|
"journal_id": self.bank_journal.id,
|
|
|
|
"date": date_str,
|
|
|
|
"line_ids": [
|
|
|
|
(
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
{
|
|
|
|
"name": "Debit",
|
|
|
|
"debit": 1000,
|
|
|
|
"account_id": self.account_recv.id,
|
|
|
|
},
|
|
|
|
),
|
|
|
|
(
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
{
|
|
|
|
"name": "Credit",
|
|
|
|
"credit": 1000,
|
|
|
|
"account_id": self.account_sale.id,
|
|
|
|
},
|
|
|
|
),
|
|
|
|
],
|
|
|
|
}
|
|
|
|
)
|
2017-07-06 09:41:05 +02:00
|
|
|
|
|
|
|
def test_01_account_move_date_range_fm_id_compute(self):
|
2020-11-17 02:38:56 +01:00
|
|
|
january_1st = Date.from_string("2017-01-01")
|
2017-07-06 09:41:05 +02:00
|
|
|
move = self.create_account_move(january_1st)
|
|
|
|
|
|
|
|
self.assertEquals(
|
2020-11-17 02:38:56 +01:00
|
|
|
move.date_range_fm_id,
|
|
|
|
self.date_range_january_2017,
|
|
|
|
msg="Move period should be January 2017",
|
|
|
|
)
|
|
|
|
self.assertTrue(
|
|
|
|
all(
|
|
|
|
[
|
|
|
|
line.date_range_fm_id == self.date_range_january_2017
|
|
|
|
for line in move.line_ids
|
|
|
|
]
|
|
|
|
),
|
|
|
|
msg="All lines period should be January 2017",
|
|
|
|
)
|
|
|
|
|
|
|
|
march_1st = Date.from_string("2017-03-01")
|
2017-07-06 09:41:05 +02:00
|
|
|
move = self.create_account_move(march_1st)
|
|
|
|
self.assertFalse(
|
2020-11-17 02:38:56 +01:00
|
|
|
bool(move.date_range_fm_id), msg="Move shouldn't have any date range"
|
|
|
|
)
|
2017-07-06 09:41:05 +02:00
|
|
|
|
|
|
|
def test_02_account_move_date_range_fm_id_search(self):
|
2020-11-17 02:38:56 +01:00
|
|
|
january_2017_1st = Date.from_string("2017-01-01")
|
|
|
|
february_2017_1st = Date.from_string("2017-02-01")
|
|
|
|
march_2017_1st = Date.from_string("2017-03-01")
|
|
|
|
january_2018_1st = Date.from_string("2018-01-01")
|
2017-07-06 09:41:05 +02:00
|
|
|
|
|
|
|
move_jan_2017 = self.create_account_move(january_2017_1st)
|
|
|
|
move_feb_2017 = self.create_account_move(february_2017_1st)
|
|
|
|
move_march_2017 = self.create_account_move(march_2017_1st)
|
|
|
|
move_jan_2018 = self.create_account_move(january_2018_1st)
|
|
|
|
|
2020-11-17 02:38:56 +01:00
|
|
|
moves = self.AccountMoveObj.search([("date_range_fm_id", "ilike", "January"),])
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
all(
|
|
|
|
[
|
|
|
|
move_jan_2017 in moves,
|
|
|
|
move_feb_2017 not in moves,
|
|
|
|
move_march_2017 not in moves,
|
|
|
|
move_jan_2018 in moves,
|
|
|
|
]
|
|
|
|
),
|
|
|
|
msg="There should be only moves in January",
|
|
|
|
)
|
|
|
|
|
|
|
|
moves = self.AccountMoveObj.search([("date_range_fm_id", "ilike", "2017"),])
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
all(
|
|
|
|
[
|
|
|
|
move_jan_2017 in moves,
|
|
|
|
move_feb_2017 in moves,
|
|
|
|
move_march_2017 not in moves,
|
|
|
|
move_jan_2018 not in moves,
|
|
|
|
]
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
moves = self.AccountMoveObj.search(
|
|
|
|
[("date_range_fm_id", "=", self.date_range_january_2017.id),]
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
all(
|
|
|
|
[
|
|
|
|
move_jan_2017 in moves,
|
|
|
|
move_feb_2017 not in moves,
|
|
|
|
move_march_2017 not in moves,
|
|
|
|
move_jan_2018 not in moves,
|
|
|
|
]
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
moves = self.AccountMoveObj.search(
|
|
|
|
[
|
|
|
|
(
|
|
|
|
"date_range_fm_id",
|
|
|
|
"in",
|
|
|
|
(self.date_range_january_2017.id, self.date_range_february_2017.id),
|
|
|
|
),
|
|
|
|
]
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
all(
|
|
|
|
[
|
|
|
|
move_jan_2017 in moves,
|
|
|
|
move_feb_2017 in moves,
|
|
|
|
move_march_2017 not in moves,
|
|
|
|
move_jan_2018 not in moves,
|
|
|
|
]
|
|
|
|
)
|
|
|
|
)
|