openerp-india team mailing list archive
-
openerp-india team
-
Mailing list archive
-
Message #08823
[Bug 951722] Re: [6.x][account] account.move.line _query_get method should not return all periods when period.start_date = fiscalyear.start_date AND context= {'fiscalyear':integer, 'periods':[only_integer], 'initial_bal':True}
This bug is critical affects all versions of v.6, 6.0, 6.1, trunk
thanks a lot for your attention
Hbto
** Summary changed:
- [account] account.move.line _query_get method should not return all periods when period.start_date = fiscalyear.start_date AND context= {'fiscalyear':integer, 'periods':[only_integer], 'initial_bal':True}
+ [6.x][account] account.move.line _query_get method should not return all periods when period.start_date = fiscalyear.start_date AND context= {'fiscalyear':integer, 'periods':[only_integer], 'initial_bal':True}
--
You received this bug notification because you are a member of OpenERP
Indian Team, which is subscribed to OpenERP Addons.
https://bugs.launchpad.net/bugs/951722
Title:
[6.x][account] account.move.line _query_get method should not return
all periods when period.start_date = fiscalyear.start_date AND
context= {'fiscalyear':integer, 'periods':[only_integer],
'initial_bal':True}
Status in OpenERP Addons (modules):
New
Bug description:
account.move.line _query_get method should not return all periods when
period.start_date = fiscalyear.start_date AND context=
{'fiscalyear':integer, 'periods':[only_integer], 'initial_bal':True}
When passing context like this
ctx = {'fiscalyear':integer, 'periods':[integer], 'initial_bal':True}
and ctx['periods'] is a list of only one integer, being that integer the first period
of the given ctx['fiscalyear'],
_query_get in account.move.line returns
QUERY l.state <> 'draft' AND l.period_id IN (SELECT id FROM
account_period WHERE fiscalyear_id IN (1))
Which is wrong, For a fiscalyear in the first period
the initial-balance is not the whole year
a) I would approach this way
I think that line 86 instead of:
periods = fiscalperiod_obj.search(cr, uid, [('date_start', '<',
first_period.date_start)])
should be:
periods = fiscalperiod_obj.search(cr, uid, [('date_start', '<',
first_period.date_start),('fiscalyear_id','in',fiscalyear_ids)])
because those periods should not be out of the fiscalyear_ids being
asked
b) Given that there are special periods that could overlap in the same
date:
NAME----------START----------END------------FY------SPECIAL
AP/2012-------01/01/2012-----01-01-2012-----2012----True
01/2012-------01/01/2012-----01-31-2012-----2012----False
02/2012-------02/01/2012-----01-28-2012-----2012----False
03/2012-------03/01/2012-----03-31-2012-----2012----False
AP/2012 holds the opening entries
quote line 24 "... because the best practice is to
generate the FY opening entries", and
01/2012 holds regular accounting transactions.
if
ctx = {'fiscalyear':2012, 'periods':[01/2012], 'initial_bal':True}
is passed line 86 will return [] withoud taking account AP/2012
there should be a else clause
if not periods:
#~ Looking for special periods at the beginning of FY
periods = fiscalperiod_obj.search(cr, uid, [('date_start', '>=', first_period.date_start),('date_stop', '<=', first_period.date_stop),('fiscalyear_id','in',fiscalyear_ids),('special','=',True)])
and finally if all fails not periods at all,
there should be a else clause where:
query = False
That should not return a thing
To manage notifications about this bug go to:
https://bugs.launchpad.net/openobject-addons/+bug/951722/+subscriptions
References