Commit 5278c824 authored by Jérome Perrin's avatar Jérome Perrin

some tests for _aq_dynamic behaviour. This is probably not in the best place

for them ...



git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@18080 20353a03-c40f-0410-a6d1-a30d3c3de9de
parent b50cddef
No related merge requests found
...@@ -1807,6 +1807,37 @@ class TestPropertySheet: ...@@ -1807,6 +1807,37 @@ class TestPropertySheet:
# ... other cases should be added here # ... other cases should be added here
# Tests for _aq_dynamic patch. Probably not in the right place.
def test_aq_dynamic(self):
doc = self.portal.person_module.newContent(portal_type='Person')
from Acquisition import Explicit
class Ok(Explicit):
aq_dynamic_calls = []
def _aq_dynamic(self, name):
self.aq_dynamic_calls.append(name)
return 'returned_attr'
ok = Ok().__of__(doc)
self.assertEquals('returned_attr', getattr(ok, 'attr'))
self.assertEquals(ok.aq_dynamic_calls, ['attr'])
def test_aq_dynamic_exception(self):
# if an exception is raised in _aq_dynamic, it should not be hidden
doc = self.portal.person_module.newContent(portal_type='Person')
from Acquisition import Explicit
class NotOk(Explicit):
def _aq_dynamic(self, name):
raise ValueError()
not_ok = NotOk().__of__(doc)
self.assertRaises(ValueError, getattr, not_ok, 'attr')
self.assertFalse(hasattr(not_ok, 'attr'))
def test_suite(): def test_suite():
suite = unittest.TestSuite() suite = unittest.TestSuite()
suite.addTest(unittest.makeSuite(TestERP5Type)) suite.addTest(unittest.makeSuite(TestERP5Type))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment