← Back to team overview

c2c-oerpscenario team mailing list archive

[Bug 704051] Re: [6.0] critical regression: inheriting ir_model_data will now destroy your database!

 

A few comments:

The issue occurs because in bin/addons/base/ir/ir_model.py,
the self.loads collection doesn't contain everything it should.
Here is the instrumentation of the code I'm using:

@@ -723,9 +725,22 @@
         module_in = ",".join(["%s"] * len(modules))
         cr.execute('select id,name,model,res_id,module from ir_model_data where module IN (' + module_in + ') and noupdate=%s', modules + [False])
         wkf_todo = []
+#       print "*********** loads", self.loads
+        for item in self.loads:
+            if (item[0] == unicode('base') or item[0] == 'base'):
+                print "**** in loads:", item
+
         for (id, name, model, res_id,module) in cr.fetchall():
             if (module,name) not in self.loads:
-                self.unlink_mark[(model,res_id)] = id
+#                self.unlink_mark[(model,res_id)] = id
+#               print "module", module
+                if module != 'base':
+                    #print "****", (module,name)
+                    self.unlink_mark[(model,res_id)] = id
+                else:
+                    self.unlink_mark[(model,res_id)] = id
+                    print "not in loads: :(module,name)", (module,name)


And then it will print (with kaboom installed):
**** in loads: ('base', 'user_root')
not in loads: :(module,name) (u'base', u'menu_administration_shortcut')
not in loads: :(module,name) (u'base', u'menu_custom')
not in loads: :(module,name) (u'base', u'next_id_4')
not in loads: :(module,name) (u'base', u'menu_low_workflow')
not in loads: :(module,name) (u'base', u'menu_custom_action')
not in loads: :(module,name) (u'base', u'menu_config')
not in loads: :(module,name) (u'base', u'menu_translation')
not in loads: :(module,name) (u'base', u'menu_translation_app')
not in loads: :(module,name) (u'base', u'menu_translation_export')
not in loads: :(module,name) (u'base', u'menu_users')
not in loads: :(module,name) (u'base', u'menu_security')
not in loads: :(module,name) (u'base', u'menu_management')
not in loads: :(module,name) (u'base', u'reporting_menu')
...


Whereas, without the 'kaboom' module installed, there are dozens of entries in the self.loads collection instead:
**** in loads: ('base', 'values_view_form_action')
**** in loads: ('base', 'bw')
**** in loads: ('base', 'JPY')
**** in loads: ('base', 'ratePLN')
**** in loads: ('base', 'CRC')
**** in loads: ('base', u'access_res_widget')
**** in loads: ('base', 'res_partner_event-wopartner-view_tree')
**** in loads: ('base', 'action_view_base_module_upgrade_window')
**** in loads: ('base', 'config_wizard_simple_view')
**** in loads: ('base', 'action_res_users')
**** in loads: ('base', 'view_translation_form')
**** in loads: ('base', u'access_res_widget_user_group_user')
**** in loads: ('base', 'ir_cron_act')
**** in loads: ('base', 'vi')
**** in loads: ('base', u'access_res_log_all')
**** in loads: ('base', 'RON')
**** in loads: ('base', 'sa')
and nothing that is not in self.loads.

I've still not been able to track why this self.loads is empty at update
with kaboom installed.

Other remark: if you flag the module kaboom as 'uninstalled' using SQL,
your update seems able to restore the menus but this is no long term
solution.

-- 
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/704051

Title:
   [6.0] critical regression: inheriting ir_model_data will now destroy
  your database!

Status in OpenObject Server:
  In Progress

Bug description:
  Hello,

  sorry to shout that one loudly, but I know that v6 "stable" is about
  to be release, so I want to make sure you take a look to it:

  A change introduced recently in the server (after rev #3224 I think),
  will now destroy important database records in the update process if
  you have any object inheriting the ir.model.data object.

  Simple code like this one will trigger the bug, it's attached as a
  "kaboom" module so you can test:

  class ir_model_data(osv.osv):
      _inherit = "ir.model.data"

  ir_model_data()

  After loading such code, if you restart the server with option --update=all --database=your_base,
  your database will be broken, for instance all your menu will be broken at the next login. You can also see that in the console with logs such as:
  [2011-01-17 15:24:43,983][magento] INFO:addons.base.ir.model.data:Deleting 23@ir.actions.act_window
  [2011-01-17 15:24:43,991][magento] INFO:addons.base.ir.model.data:Deleting 13@ir.model.access
  [2011-01-17 15:24:43,997][magento] INFO:addons.base.ir.model.data:Deleting 21@xxxxxxxxxx
  [2011-01-17 15:24:44,004][magento] INFO:addons.base.ir.model.data:Deleting 5@ir.actions.wizard
  [2011-01-17 15:24:44,009][magento] INFO:addons.base.ir.model.data:Deleting 43@ir.model.access
  [2011-01-17 15:24:44,015][magento] INFO:addons.base.ir.model.data:Deleting 127@xxxxxxxxxx
  [2011-01-17 15:24:44,022][magento] INFO:addons.base.ir.model.data:Deleting 11@xxxxxxxxxx
  [2011-01-17 15:24:44,028][magento] INFO:addons.base.ir.model.data:Deleting 2@res.groups
  ...

  
  An important consequence of that bug is that the magentoerpconnect certified module is now broken:
  https://bugs.launchpad.net/magentoerpconnect/+bug/701644
  We really need to override or_model_data in the base_external_referentials module, if you don't fix what triggers this behavior in the server, it would be pretty hard to make base_external_referentials and dependent connectors work again without patch...





References