← Back to team overview

c2c-oerpscenario team mailing list archive

[Bug 711919] Re: [TRUNK 3330] Search on mixed conditions including one2many and active=False is wrongly interpreted

 

Hello,

Thanks for reporting and Thanks for  patch.

It has been fixed in lp:~openerp-dev/openobject-server/trunk-bug-711919-ysa.
Revision No :- 3445
Revision ID : ysa@xxxxxxxxxxx-20110603095526-s26wgkahwc1d6zfd and It will be merge soon
in trunk server.

Thanks,


** Changed in: openobject-server
       Status: In Progress => Fix Committed

-- 
You received this bug notification because you are a member of C2C
OERPScenario, which is subscribed to the OpenERP Project Group.
https://bugs.launchpad.net/bugs/711919

Title:
  [TRUNK 3330] Search on mixed conditions including one2many and
  active=False is wrongly interpreted

Status in OpenERP Server:
  Fix Committed

Bug description:
  sample of condition

  [('category_id.code','=','PATIENT'),('active',=,False)]

  Description

  When server parse

  1 = search all partner with category code = patient , and add active =
  True

  2= search all partner active = False

  Result = Found nothing, because  active condiction not used in
  one2many search

  
  My solution (not the optimal solution, no time to do it)

  
  before line 111   (i = -1)

  add

      active = False
      for exp in self.__exp:
          if exp[0] == 'active':
              active = exp

  replace line 153 (right1 = table.search(cr, uid, [(fargs[0],'in',
  right)], context=context))

  by

                  if active:                        
                      right1 = table.search(cr, uid, [(fargs[0],'in', right),active], context=context)
                  else:
                      right1 = table.search(cr, uid, [(fargs[0],'in', right)], context=context)


  Note: in my example, Code is a field added in res.partner.category, so
  to test it, bmaybe use field name.


References