2018-01-16 02:34:37 -08:00
|
|
|
from flectra.addons.account.tests.account_test_classes import AccountingTestCase
|
|
|
|
from flectra.osv.orm import except_orm
|
2018-01-16 11:28:15 +05:30
|
|
|
from datetime import datetime, timedelta
|
2018-01-16 02:34:37 -08:00
|
|
|
from flectra.tools import DEFAULT_SERVER_DATE_FORMAT
|
2018-01-16 11:28:15 +05:30
|
|
|
|
|
|
|
class TestPeriodState(AccountingTestCase):
|
|
|
|
"""
|
|
|
|
Forbid creation of Journal Entries for a closed period.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
super(TestPeriodState, self).setUp()
|
|
|
|
self.user_id = self.env.user
|
|
|
|
self.day_before_yesterday = datetime.now() - timedelta(2)
|
|
|
|
self.yesterday = datetime.now() - timedelta(1)
|
|
|
|
self.yesterday_str = self.yesterday.strftime(DEFAULT_SERVER_DATE_FORMAT)
|
|
|
|
#make sure there is no unposted entry
|
|
|
|
draft_entries = self.env['account.move'].search([('date', '<=', self.yesterday_str), ('state', '=', 'draft')])
|
|
|
|
if draft_entries:
|
|
|
|
draft_entries.post()
|
|
|
|
self.user_id.company_id.write({'fiscalyear_lock_date': self.yesterday_str})
|
|
|
|
self.sale_journal_id = self.env['account.journal'].search([('type', '=', 'sale')])[0]
|
|
|
|
self.account_id = self.env['account.account'].search([('internal_type', '=', 'receivable')])[0]
|
|
|
|
|
|
|
|
def test_period_state(self):
|
|
|
|
with self.assertRaises(except_orm):
|
|
|
|
move = self.env['account.move'].create({
|
|
|
|
'name': '/',
|
|
|
|
'journal_id': self.sale_journal_id.id,
|
|
|
|
'date': self.day_before_yesterday.strftime(DEFAULT_SERVER_DATE_FORMAT),
|
|
|
|
'line_ids': [(0, 0, {
|
|
|
|
'name': 'foo',
|
|
|
|
'debit': 10,
|
|
|
|
'account_id': self.account_id.id,
|
|
|
|
}), (0, 0, {
|
|
|
|
'name': 'bar',
|
|
|
|
'credit': 10,
|
|
|
|
'account_id': self.account_id.id,
|
|
|
|
})]
|
|
|
|
})
|
|
|
|
move.post()
|