← Back to team overview

openerp-india team mailing list archive

[Bug 1111340] Re: [7.0] XML replace fails on a new update

 

Well in that case it isn't a single field I want to get ride the inside
form : //field[@name='child_ids']/form

This because I don't need the minimal form for contact in res.partner

-- 
You received this bug notification because you are a member of OpenERP
Indian Team, which is subscribed to OpenERP Server.
https://bugs.launchpad.net/bugs/1111340

Title:
  [7.0] XML replace fails on a new update

Status in OpenERP Server:
  New

Bug description:
  Hello,

  I have a strange issue. I'm currently removing the default contact
  form in res_partner view form.

  Using:

      <record id="view_partner_form_usedefault_form_for_contacts" model="ir.ui.view">
          <field name="name">res.partner.form</field>
          <field name="model">res.partner</field>
          <field eval="1" name="priority"/>
          <field name="inherit_id" ref="base.view_partner_form"/>
          <field name="arch" type="xml">
              <form string="Contact" position="replace">
                  <form string="Contact">
                  </form>
              </form>
          </field>
      </record>

  Fisrt time I update my module everythings go fine.

  However, while I'm developping this module if I do some changes in my
  xml file on other inherit on the res_partner_view, this change fails
  and raise the following error on module update.

  Can't render view test.view_partner_form_usedefault_form_for_contacts for model: res.partner
  Traceback (most recent call last):
    File ".../server/openerp/addons/base/ir/ir_ui_view.py", line 125, in _check_render_view
      fvg = self.pool.get(view.model).fields_view_get(cr, uid, view_id=view.id, view_type=view.type, context=context)
    File ".../server/openerp/addons/base/res/res_partner.py", line 291, in fields_view_get
      res = super(res_partner,self).fields_view_get(cr, user, view_id, view_type, context, toolbar=toolbar, submenu=submenu)
    File ".../server/openerp/osv/orm.py", line 2262, in fields_view_get
      xarch, xfields = self.__view_look_dom_arch(cr, user, result['arch'], view_id, context=ctx)
    File ".../server/openerp/osv/orm.py", line 1934, in __view_look_dom_arch
      model = res[0][1]
  IndexError: list index out of range
  2013-01-31 10:36:11,872 12143 ERROR openerp_test openerp.tools.convert: Parse error in .../specific-addons/test/res_partner_view.xml:149:
  <record id="view_partner_form_usedefault_form_for_contacts" model="ir.ui.view">
              <field name="name">res.partner.form</field>
              <field name="model">res.partner</field>
              <field eval="1" name="priority"/>
              <field name="inherit_id" ref="base.view_partner_form"/>
              <field name="arch" type="xml">
                  <form string="Contact" position="replace">
                      <form string="Contact">
                      </form>
                  </form>
              </field>
          </record>
  Traceback (most recent call last):
    File ".../server/openerp/tools/convert.py", line 847, in parse
      self._tags[rec.tag](self.cr, rec, n)
    File ".../server/openerp/tools/convert.py", line 814, in _tag_record
      id = self.pool.get('ir.model.data')._update(cr, self.uid, rec_model, self.module, res, rec_id or False, not self.isnoupdate(data_node), noupdate=self.isnoupdate(data_node), mode=self.mode, context=rec_context )
    File ".../server/openerp/addons/base/ir/ir_model.py", line 929, in _update
      model_obj.write(cr, uid, [res_id], values, context=context)
    File ".../server/openerp/addons/base/ir/ir_ui_view.py", line 207, in write
      return super(view, self).write(cr, uid, ids, vals, context)
    File ".../server/openerp/osv/orm.py", line 4203, in write
      self._validate(cr, user, ids, context)
    File ".../server/openerp/osv/orm.py", line 1546, in _validate
      raise except_orm('ValidateError', '\n'.join(error_msgs))
  except_orm: ('ValidateError', u'Error occurred while validating the field(s) arch: Invalid XML for View Architecture!')
  2013-01-31 10:36:11,873 12143 ERROR openerp_test openerp: Failed to initialize database `openerp_test`.
  Traceback (most recent call last):
    File ".../server/openerp/cli/server.py", line 98, in preload_registry
      db, registry = openerp.pooler.get_db_and_pool(dbname,update_module=update_module)
    File ".../server/openerp/pooler.py", line 33, in get_db_and_pool
      registry = RegistryManager.get(db_name, force_demo, status, update_module)
    File ".../server/openerp/modules/registry.py", line 192, in get
      update_module)
    File ".../server/openerp/modules/registry.py", line 214, in new
      openerp.modules.load_modules(registry.db, force_demo, status, update_module)
    File ".../server/openerp/modules/loading.py", line 343, in load_modules
      processed = load_marked_modules(cr, graph, states_to_load, force, status, report, loaded_modules, update_module)
    File ".../server/openerp/modules/loading.py", line 258, in load_marked_modules
      loaded, processed = load_module_graph(cr, graph, progressdict, report=report, skip_modules=loaded_modules, perform_checks=perform_checks)
    File ".../server/openerp/modules/loading.py", line 189, in load_module_graph
      load_update_xml(module_name, idref, mode)
    File ".../server/openerp/modules/loading.py", line 73, in <lambda>
      load_update_xml = lambda *args: _load_data(cr, *args, kind='update_xml')
    File ".../server/openerp/modules/loading.py", line 126, in _load_data
      tools.convert_xml_import(cr, module_name, fp, idref, mode, noupdate, report)
    File ".../server/openerp/tools/convert.py", line 954, in convert_xml_import
      obj.parse(doc.getroot())
    File ".../server/openerp/tools/convert.py", line 847, in parse
      self._tags[rec.tag](self.cr, rec, n)
    File ".../server/openerp/tools/convert.py", line 814, in _tag_record
      id = self.pool.get('ir.model.data')._update(cr, self.uid, rec_model, self.module, res, rec_id or False, not self.isnoupdate(data_node), noupdate=self.isnoupdate(data_node), mode=self.mode, context=rec_context )
    File ".../server/openerp/addons/base/ir/ir_model.py", line 929, in _update
      model_obj.write(cr, uid, [res_id], values, context=context)
    File ".../server/openerp/addons/base/ir/ir_ui_view.py", line 207, in write
      return super(view, self).write(cr, uid, ids, vals, context)
    File ".../server/openerp/osv/orm.py", line 4203, in write
      self._validate(cr, user, ids, context)
    File ".../server/openerp/osv/orm.py", line 1546, in _validate
      raise except_orm('ValidateError', '\n'.join(error_msgs))
  except_orm: ('ValidateError', u'Error occurred while validating the field(s) arch: Invalid XML for View Architecture!')

  I assume the form string="Contact" is somehow already deleted and it
  tries to delete it a second time...

  To resolve I can
  1. remove view_partner_form_usedefault_form_for_contacts from my from XML file
  2. update the module.
  3. add again view_partner_form_usedefault_form_for_contacts
  4. update the module.

  And there I have what I need. But this is quite anoying...


  revision-ids
  server: odo@xxxxxxxxxxx-20130117175758-yhnflxxazthhp2y9
  webclient: fme@xxxxxxxxxxx-20130107161807-fvzdgayqhf8hx92q
  addons: cha@xxxxxxxxxxx-20121213092815-rqmzeyretyctljq7

To manage notifications about this bug go to:
https://bugs.launchpad.net/openobject-server/+bug/1111340/+subscriptions


References