# -*- coding: utf-8 -*- # # # Authors: Adrien Peiffer # Copyright (c) 2014 Acsone SA/NV (http://www.acsone.eu) # All Rights Reserved # # WARNING: This program as such is intended to be used by professional # programmers who take the whole responsibility of assessing all potential # consequences resulting from its eventual inadequacies and bugs. # End users who are looking for a ready-to-use solution with commercial # guarantees and support are strongly advised to contact a Free Software # Service Company. # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as # published by the Free Software Foundation, either version 3 of the # License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see . # # import openerp.tests.common as common from openerp import workflow from openerp import exceptions from datetime import datetime, timedelta from openerp.tools import DEFAULT_SERVER_DATE_FORMAT def get_simple_product_id(self): return self.env['product.product'].create({'name': 'product_test_01', 'lst_price': 2000.00, }) def get_journal_check(self, value): sale_journal_id = self.ref('account.sales_journal') sale_journal = self.env['account.journal'].browse([sale_journal_id]) journal = sale_journal.copy() journal.check_chronology = value return journal def get_simple_account_invoice_line_values(self, product_id): return {'name': 'test', 'account_id': self.ref('account.a_sale'), 'price_unit': 2000.00, 'quantity': 1, 'product_id': product_id, } def create_simple_invoice(self, journal_id, date): partner_id = self.ref('base.res_partner_2') product = get_simple_product_id(self) return self.env['account.invoice']\ .create({'partner_id': partner_id, 'account_id': self.ref('account.a_recv'), 'journal_id': journal_id, 'date_invoice': date, 'invoice_line': [(0, 0, {'name': 'test', 'account_id': self.ref('account.a_sale'), 'price_unit': 2000.00, 'quantity': 1, 'product_id': product.id, } ) ], }) class TestAccountConstraintChronology(common.TransactionCase): def setUp(self): super(TestAccountConstraintChronology, self).setUp() self.context = self.registry("res.users").context_get(self.cr, self.uid) def test_invoice_draft(self): journal = get_journal_check(self, True) today = datetime.now() yesterday = today - timedelta(days=1) date = yesterday.strftime(DEFAULT_SERVER_DATE_FORMAT) create_simple_invoice(self, journal.id, date) date = today.strftime(DEFAULT_SERVER_DATE_FORMAT) invoice_2 = create_simple_invoice(self, journal.id, date) self.assertRaises(exceptions.Warning, workflow.trg_validate, self.uid, 'account.invoice', invoice_2.id, 'invoice_open', self.cr) def test_invoice_validate(self): journal = get_journal_check(self, True) today = datetime.now() tomorrow = today + timedelta(days=1) date = tomorrow.strftime(DEFAULT_SERVER_DATE_FORMAT) invoice = create_simple_invoice(self, journal.id, date) workflow.trg_validate(self.uid, 'account.invoice', invoice.id, 'invoice_open', self.cr) date = today.strftime(DEFAULT_SERVER_DATE_FORMAT) invoice_2 = create_simple_invoice(self, journal.id, date) self.assertRaises(exceptions.Warning, workflow.trg_validate, self.uid, 'account.invoice', invoice_2.id, 'invoice_open', self.cr) def test_invoice_without_date(self): journal = get_journal_check(self, True) today = datetime.now() yesterday = today - timedelta(days=1) date = yesterday.strftime(DEFAULT_SERVER_DATE_FORMAT) create_simple_invoice(self, journal.id, date) invoice_2 = create_simple_invoice(self, journal.id, False) self.assertRaises(exceptions.Warning, workflow.trg_validate, self.uid, 'account.invoice', invoice_2.id, 'invoice_open', self.cr)