From a51b6912bd28489a784edbd8bd1f7e11437ab7e1 Mon Sep 17 00:00:00 2001 From: Vo Minh Thu Date: Wed, 20 Mar 2013 14:22:38 +0100 Subject: [PATCH] [FIX] safe_eval: better exception handling: - the re-raising of exceptions ignored the "legal" exceptions (the one used to early abort RPC calls and generate pop-ups) - re-raising the exception was attempting to re-use the original exception type but it does not always take only one argument so it was breaking. lp bug: https://launchpad.net/bugs/1146256 fixed bzr revid: vmt@openerp.com-20130320132238-qzo3jptww59ndlch --- openerp/addons/base/test/base_test.yml | 2 +- .../tests/addons/test_exceptions/models.py | 30 +++++++++++++ openerp/tests/addons/test_exceptions/view.xml | 42 ++++++++++++++++++- openerp/tools/safe_eval.py | 14 ++++++- 4 files changed, 84 insertions(+), 4 deletions(-) diff --git a/openerp/addons/base/test/base_test.yml b/openerp/addons/base/test/base_test.yml index b7f7e0058b1..baf8aa88815 100644 --- a/openerp/addons/base/test/base_test.yml +++ b/openerp/addons/base/test/base_test.yml @@ -47,7 +47,7 @@ with mute_logger('openerp.tools.safe_eval'): safe_eval('open("/etc/passwd","r")') assert False, "safe_eval should not allow calling open() builtin" - except NameError: + except ValueError: pass - diff --git a/openerp/tests/addons/test_exceptions/models.py b/openerp/tests/addons/test_exceptions/models.py index 7a91d147256..a22c6ea7d77 100644 --- a/openerp/tests/addons/test_exceptions/models.py +++ b/openerp/tests/addons/test_exceptions/models.py @@ -35,4 +35,34 @@ class m(openerp.osv.osv.Model): def generate_undefined(self, cr, uid, ids, context=None): self.surely_undefined_symbol + + def generate_except_osv_safe_eval(self, cr, uid, ids, context=None): + self.generate_safe_eval(cr, uid, ids, self.generate_except_osv, context) + + def generate_except_orm_safe_eval(self, cr, uid, ids, context=None): + self.generate_safe_eval(cr, uid, ids, self.generate_except_orm, context) + + def generate_warning_safe_eval(self, cr, uid, ids, context=None): + self.generate_safe_eval(cr, uid, ids, self.generate_warning, context) + + def generate_redirect_warning_safe_eval(self, cr, uid, ids, context=None): + self.generate_safe_eval(cr, uid, ids, self.generate_redirect_warning, context) + + def generate_access_denied_safe_eval(self, cr, uid, ids, context=None): + self.generate_safe_eval(cr, uid, ids, self.generate_access_denied, context) + + def generate_access_error_safe_eval(self, cr, uid, ids, context=None): + self.generate_safe_eval(cr, uid, ids, self.generate_access_error, context) + + def generate_exc_access_denied_safe_eval(self, cr, uid, ids, context=None): + self.generate_safe_eval(cr, uid, ids, self.generate_exc_access_denied, context) + + def generate_undefined_safe_eval(self, cr, uid, ids, context=None): + self.generate_safe_eval(cr, uid, ids, self.generate_undefined, context) + + + def generate_safe_eval(self, cr, uid, ids, f, context): + globals_dict = { 'generate': lambda *args: f(cr, uid, ids, context) } + openerp.tools.safe_eval.safe_eval("generate()", mode='exec', globals_dict=globals_dict) + # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: diff --git a/openerp/tests/addons/test_exceptions/view.xml b/openerp/tests/addons/test_exceptions/view.xml index 0c8e373a278..4d8e820d456 100644 --- a/openerp/tests/addons/test_exceptions/view.xml +++ b/openerp/tests/addons/test_exceptions/view.xml @@ -7,9 +7,11 @@ test.exceptions.model
-