Commit c12e8be3 authored by Andreas Jung's avatar Andreas Jung

     - Collector #1436: applied patch to fix a memory leak in 
       cAccessControl. 
parent 92c77a7d
...@@ -129,6 +129,9 @@ Zope Changes ...@@ -129,6 +129,9 @@ Zope Changes
Bugs fixed Bugs fixed
- Collector #1436: applied patch to fix a memory leak in
cAccessControl.
- Collector #1431: fixed NetBSD support in initgroups.c - Collector #1431: fixed NetBSD support in initgroups.c
- Collector #1406: fixed segmentation fault by acquisition - Collector #1406: fixed segmentation fault by acquisition
......
...@@ -1228,8 +1228,10 @@ static PyObject *ZopeSecurityPolicy_validate(PyObject *self, PyObject *args) { ...@@ -1228,8 +1228,10 @@ static PyObject *ZopeSecurityPolicy_validate(PyObject *self, PyObject *args) {
} }
goto err; goto err;
} }
else else {
Py_DECREF(eo);
Py_DECREF(proxy_roles); Py_DECREF(proxy_roles);
}
} /* End of stack check */ } /* End of stack check */
/*| try: /*| try:
......
...@@ -221,6 +221,17 @@ class ZopeSecurityPolicyTests (unittest.TestCase): ...@@ -221,6 +221,17 @@ class ZopeSecurityPolicyTests (unittest.TestCase):
self.assertPolicyAllows(item, 'setuid_m') self.assertPolicyAllows(item, 'setuid_m')
self.assertPolicyAllows(item, 'dangerous_m') self.assertPolicyAllows(item, 'dangerous_m')
def testIdentityProxy(self):
eo = ImplictAcqObject()
eo.getOwner = lambda: None
self.context.stack.append(eo)
rc = sys.getrefcount(eo)
self.testUserAccess()
self.assertEqual(rc, sys.getrefcount(eo))
eo._proxy_roles = ()
self.testUserAccess()
self.assertEqual(rc, sys.getrefcount(eo))
def testAccessToUnprotectedSubobjects(self): def testAccessToUnprotectedSubobjects(self):
item = self.item item = self.item
r_item = self.a.r_item r_item = self.a.r_item
......
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