2
0

[MIG] Migration of account_asset_batch_compute

This commit is contained in:
Adrien Peiffer (ACSONE) 2017-03-23 07:52:07 +01:00 committed by Javier Iniesta
parent b5db09dc88
commit 2db6a14053
8 changed files with 100 additions and 93 deletions

View File

@ -9,16 +9,12 @@ Account Asset Batch Compute
Add the possibility to compute assets in batch. Add the possibility to compute assets in batch.
This module adds a flag on compute assets wizard in order to execute this process in batch. This module adds a flag on compute assets wizard in order to execute this process in batch.
Usage Usage
===== =====
.. image:: https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas .. image:: https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas
:alt: Try me on Runbot :alt: Try me on Runbot
:target: https://runbot.odoo-community.org/runbot/92/8.0 :target: https://runbot.odoo-community.org/runbot/92/10.0
Bug Tracker Bug Tracker
=========== ===========

View File

@ -1,18 +1,18 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# Copyright 2016 ACSONE SA/NV # Copyright 2016-2017 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{ {
'name': 'Account Asset Batch Compute', 'name': 'Account Asset Batch Compute',
'summary': """ 'summary': """
Add the possibility to compute assets in batch""", Add the possibility to compute assets in batch""",
'version': '8.0.1.0.0', 'version': '10.0.1.0.0',
'license': 'AGPL-3', 'license': 'AGPL-3',
'author': 'ACSONE SA/NV,Odoo Community Association (OCA)', 'author': 'ACSONE SA/NV,Odoo Community Association (OCA)',
'website': 'www.acsone.eu', 'website': 'www.acsone.eu',
'depends': [ 'depends': [
'account_asset_management', 'account_asset_management',
'connector', 'queue_job',
], ],
'data': [ 'data': [
'wizards/asset_depreciation_confirmation_wizard.xml', 'wizards/asset_depreciation_confirmation_wizard.xml',

View File

@ -1 +1 @@
from . import account_asset_asset from . import account_asset

View File

@ -0,0 +1,37 @@
# -*- coding: utf-8 -*-
# Copyright 2016 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from openerp import api, models, _
import logging
_logger = logging.getLogger(__name__)
try:
from odoo.addons.queue_job.job import job
except ImportError:
_logger.debug('Can not `import queue_job`.')
def empty_decorator(func):
return func
job = empty_decorator
class AccountAsset(models.Model):
_inherit = 'account.asset'
@api.multi
@job(default_channel='root.account_asset_batch_compute')
def _compute_entries(self, date_end, check_triggers=False):
if self.env.context.get('asset_batch_processing'):
for record in self:
description =\
_("Creating move for asset with id %s to %s") %\
(record.id, date_end)
record.with_delay(description=description)._compute_entries(
date_end, check_triggers=check_triggers)
return []
else:
return super(AccountAsset, self)._compute_entries(
date_end, check_triggers=check_triggers)

View File

@ -1,48 +0,0 @@
# -*- coding: utf-8 -*-
# Copyright 2016 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from openerp import api, models, _
import logging
_logger = logging.getLogger(__name__)
try:
from openerp.addons.connector.session import ConnectorSession
from openerp.addons.connector.queue.job import job
except ImportError:
_logger.debug('Can not `import connector`.')
def empty_decorator(func):
return func
job = empty_decorator
class AccountAssetAsset(models.Model):
_inherit = 'account.asset.asset'
@api.multi
def _compute_entries(self, period_id, check_triggers=False):
if self.env.context.get('asset_batch_processing'):
for record in self:
session = ConnectorSession.from_env(self.env)
description =\
_("Creating move for asset with id %s on period %s") %\
(record.id, period_id)
async_compute_entries.delay(
session, record.id, period_id,
check_triggers=check_triggers, description=description)
return []
else:
self.env.context = self.env.context.copy()
return super(AccountAssetAsset, self)._compute_entries(
period_id, check_triggers=check_triggers)
@job(default_channel='root.account_asset_batch_compute')
def async_compute_entries(session, asset_id, period_id,
check_triggers=False):
asset = session.env['account.asset.asset'].browse([asset_id])[0]
asset.with_context(asset_batch_processing=False)\
._compute_entries(period_id, check_triggers=check_triggers)

View File

@ -2,32 +2,50 @@
# Copyright 2016 ACSONE SA/NV # Copyright 2016 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from openerp.tests.common import TransactionCase from odoo import tools
from openerp.addons.connector.tests.common import mock_job_delay_to_direct from odoo.modules.module import get_resource_path
from odoo.tests.common import TransactionCase
from datetime import date from datetime import date
DELAY2 = ('openerp.addons.account_asset_batch_compute.wizards.' from dateutil import relativedelta
from odoo.addons.queue_job.job import Job
DELAY2 = ('odoo.addons.account_asset_batch_compute.wizards.'
'asset_depreciation_confirmation_wizard.async_asset_compute') 'asset_depreciation_confirmation_wizard.async_asset_compute')
DELAY1 = ('openerp.addons.account_asset_batch_compute.models.' DELAY1 = ('odoo.addons.account_asset_batch_compute.models.'
'account_asset_asset.async_compute_entries') 'account_asset_asset.async_compute_entries')
class TestAccountAssetBatchCompute(TransactionCase): class TestAccountAssetBatchCompute(TransactionCase):
def _load(self, module, *args):
tools.convert_file(self.cr, module,
get_resource_path(module, *args),
{}, 'init', False, 'test',
self.registry._assertion_report)
def setUp(self): def setUp(self):
super(TestAccountAssetBatchCompute, self).setUp() super(TestAccountAssetBatchCompute, self).setUp()
self._load('account', 'test', 'account_minimal_test.xml')
self._load('account_asset_management', 'demo',
'account_asset_demo.xml')
self.wiz_obj = self.env['asset.depreciation.confirmation.wizard'] self.wiz_obj = self.env['asset.depreciation.confirmation.wizard']
self.asset01 = self.env.ref( self.asset01 = self.env.ref(
'account_asset_management.account_asset_asset_ict0') 'account_asset_management.account_asset_ict0')
self.asset01.method_period = 'month' self.asset01.method_period = 'month'
today = date.today() today = date.today()
first_day_of_month = date(today.year, today.month, 1) first_day_of_month = date(today.year, today.month, 1)
self.nextmonth =\
first_day_of_month + relativedelta.relativedelta(months=1)
self.nextmonth = first_day_of_month + relativedelta.relativedelta(
months=1)
self.asset01.date_start = first_day_of_month self.asset01.date_start = first_day_of_month
def test_1(self): def test_1(self):
period = self.env['account.period'].find()
wiz = self.wiz_obj.create({'batch_processing': False, wiz = self.wiz_obj.create({'batch_processing': False,
'period_id': period.id}) 'date_end': self.nextmonth})
# I check if this asset is draft # I check if this asset is draft
self.assertEqual(self.asset01.state, 'draft') self.assertEqual(self.asset01.state, 'draft')
# I confirm this asset # I confirm this asset
@ -45,9 +63,8 @@ class TestAccountAssetBatchCompute(TransactionCase):
self.assertTrue(len(depreciation_line) == 1) self.assertTrue(len(depreciation_line) == 1)
def test_2(self): def test_2(self):
period = self.env['account.period'].find()
wiz = self.wiz_obj.create({'batch_processing': True, wiz = self.wiz_obj.create({'batch_processing': True,
'period_id': period.id}) 'date_end': self.nextmonth})
# I check if this asset is draft # I check if this asset is draft
self.assertEqual(self.asset01.state, 'draft') self.assertEqual(self.asset01.state, 'draft')
# I confirm this asset # I confirm this asset
@ -59,9 +76,23 @@ class TestAccountAssetBatchCompute(TransactionCase):
depreciation_line = self.asset01.depreciation_line_ids\ depreciation_line = self.asset01.depreciation_line_ids\
.filtered(lambda r: r.type == 'depreciate' and r.move_id) .filtered(lambda r: r.type == 'depreciate' and r.move_id)
self.assertTrue(len(depreciation_line) == 0) self.assertTrue(len(depreciation_line) == 0)
with mock_job_delay_to_direct(DELAY1),\ wiz.asset_compute()
mock_job_delay_to_direct(DELAY2): depreciation_line = self.asset01.depreciation_line_ids \
wiz.asset_compute() .filtered(lambda r: r.type == 'depreciate' and r.move_id)
depreciation_line = self.asset01.depreciation_line_ids\ self.assertTrue(len(depreciation_line) == 0)
jobs = self.env['queue.job'].search(
[], order='date_created desc', limit=1)
self.assertTrue(len(jobs) == 1)
job = Job.load(self.env, jobs.uuid)
job.perform()
depreciation_line = self.asset01.depreciation_line_ids \
.filtered(lambda r: r.type == 'depreciate' and r.move_id)
self.assertTrue(len(depreciation_line) == 0)
jobs = self.env['queue.job'].search(
[], order='date_created desc', limit=1)
self.assertTrue(len(jobs) == 1)
job = Job.load(self.env, jobs.uuid)
job.perform()
depreciation_line = self.asset01.depreciation_line_ids \
.filtered(lambda r: r.type == 'depreciate' and r.move_id) .filtered(lambda r: r.type == 'depreciate' and r.move_id)
self.assertTrue(len(depreciation_line) == 1) self.assertTrue(len(depreciation_line) == 1)

View File

@ -1,5 +1,5 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# Copyright 2016 ACSONE SA/NV # Copyright 2016-2017 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from openerp import api, fields, models, _ from openerp import api, fields, models, _
@ -8,10 +8,9 @@ import logging
_logger = logging.getLogger(__name__) _logger = logging.getLogger(__name__)
try: try:
from openerp.addons.connector.session import ConnectorSession from odoo.addons.queue_job.job import job
from openerp.addons.connector.queue.job import job
except ImportError: except ImportError:
_logger.debug('Can not `import connector`.') _logger.debug('Can not `import queue_job`.')
def empty_decorator(func): def empty_decorator(func):
return func return func
@ -25,27 +24,19 @@ class AssetDepreciationConfirmationWizard(models.TransientModel):
batch_processing = fields.Boolean() batch_processing = fields.Boolean()
@api.multi @api.multi
@job(default_channel='root.account_asset_batch_compute')
def asset_compute(self): def asset_compute(self):
self.ensure_one() self.ensure_one()
if not self.batch_processing: if not self.batch_processing:
return super(AssetDepreciationConfirmationWizard, self)\ return super(AssetDepreciationConfirmationWizard, self)\
.asset_compute() .asset_compute()
if self.env.context.get('not_async'): if not self.env.context.get('job_uuid'):
return super(AssetDepreciationConfirmationWizard, description = \
self.with_context(asset_batch_processing=True))\ _("Creating jobs to create moves for assets to %s") % (
.asset_compute() self.date_end,)
job = self.with_delay(description=description).asset_compute()
return u'Job created with uuid %s' % (job.uuid,)
else: else:
session = ConnectorSession.from_env(self.env) self = self.with_context(asset_batch_processing=True)
description =\ return super(AssetDepreciationConfirmationWizard, self)\
_("Creating jobs to create moves for assets period %s") % ( .asset_compute()
self.period_id.id,)
async_asset_compute.delay(session, self.period_id.id,
description=description)
@job(default_channel='root.account_asset_batch_compute')
def async_asset_compute(session, period_id):
model = session.env['asset.depreciation.confirmation.wizard']
obj = model.create({'period_id': period_id,
'batch_processing': True})
obj.with_context(not_async=True).asset_compute()

View File

@ -10,7 +10,7 @@
<field name="model">asset.depreciation.confirmation.wizard</field> <field name="model">asset.depreciation.confirmation.wizard</field>
<field name="inherit_id" ref="account_asset_management.view_asset_depreciation_confirmation_wizard"/> <field name="inherit_id" ref="account_asset_management.view_asset_depreciation_confirmation_wizard"/>
<field name="arch" type="xml"> <field name="arch" type="xml">
<field name="period_id" position="after"> <field name="date_end" position="after">
<field name="batch_processing" /> <field name="batch_processing" />
</field> </field>
</field> </field>