[Zope-Checkins] SVN: Zope/trunk/lib/python/AccessControl/ - Launchpad #282677: fixed implementation of guarded_map and
Sidnei da Silva
sidnei at enfoldsystems.com
Tue Oct 21 13:30:19 EDT 2008
Log message for revision 92436:
- Launchpad #282677: fixed implementation of guarded_map and
provided tests and implementation for guarded_zip (RestrictedPython).
Changed:
U Zope/trunk/lib/python/AccessControl/ZopeGuards.py
U Zope/trunk/lib/python/AccessControl/tests/testZopeGuards.py
-=-
Modified: Zope/trunk/lib/python/AccessControl/ZopeGuards.py
===================================================================
--- Zope/trunk/lib/python/AccessControl/ZopeGuards.py 2008-10-21 17:07:58 UTC (rev 92435)
+++ Zope/trunk/lib/python/AccessControl/ZopeGuards.py 2008-10-21 17:30:18 UTC (rev 92436)
@@ -255,10 +255,18 @@
safe_seqs = []
for seqno in range(len(seqs)):
seq = guarded_getitem(seqs, seqno)
- safe_seqs.append(seq)
+ safe_seqs.append(guarded_iter(seq))
return map(f, *safe_seqs)
safe_builtins['map'] = guarded_map
+def guarded_zip(*seqs):
+ safe_seqs = []
+ for seqno in range(len(seqs)):
+ seq = guarded_getitem(seqs, seqno)
+ safe_seqs.append(guarded_iter(seq))
+ return zip(*safe_seqs)
+safe_builtins['zip'] = guarded_zip
+
def guarded_import(mname, globals=None, locals=None, fromlist=None):
if fromlist is None:
fromlist = ()
Modified: Zope/trunk/lib/python/AccessControl/tests/testZopeGuards.py
===================================================================
--- Zope/trunk/lib/python/AccessControl/tests/testZopeGuards.py 2008-10-21 17:07:58 UTC (rev 92435)
+++ Zope/trunk/lib/python/AccessControl/tests/testZopeGuards.py 2008-10-21 17:30:18 UTC (rev 92436)
@@ -19,6 +19,7 @@
"""
import os, sys
+import operator
import unittest
from zope.testing import doctest
import ZODB
@@ -28,7 +29,7 @@
from AccessControl.ZopeGuards \
import guarded_getattr, get_dict_get, get_dict_pop, get_list_pop, \
get_iter, guarded_min, guarded_max, safe_builtins, guarded_enumerate, \
- guarded_sum, guarded_apply
+ guarded_sum, guarded_apply, guarded_map, guarded_zip
try:
__file__
@@ -236,6 +237,22 @@
class TestBuiltinFunctionGuards(GuardTestCase):
+ def test_zip_fails(self):
+ sm = SecurityManager(1) # rejects
+ old = self.setSecurityManager(sm)
+ self.assertRaises(Unauthorized, guarded_zip, [1,2,3], [3,2,1])
+ self.assertRaises(Unauthorized, guarded_zip, [1,2,3], [1])
+ self.setSecurityManager(old)
+
+ def test_map_fails(self):
+ sm = SecurityManager(1) # rejects
+ old = self.setSecurityManager(sm)
+ self.assertRaises(Unauthorized, guarded_map, str,
+ [1,2,3])
+ self.assertRaises(Unauthorized, guarded_map, lambda x,y: x+y,
+ [1,2,3], [3,2,1])
+ self.setSecurityManager(old)
+
def test_min_fails(self):
sm = SecurityManager(1) # rejects
old = self.setSecurityManager(sm)
@@ -263,6 +280,21 @@
self.assertRaises(Unauthorized, guarded_sum, [1,2,3])
self.setSecurityManager(old)
+ def test_zip_succeeds(self):
+ sm = SecurityManager() # accepts
+ old = self.setSecurityManager(sm)
+ self.assertEqual(guarded_zip([1,2,3], [3,2,1]), [(1,3),(2,2),(3,1)])
+ self.assertEqual(guarded_zip([1,2,3], [1]), [(1,1)])
+ self.setSecurityManager(old)
+
+ def test_map_succeeds(self):
+ sm = SecurityManager() # accepts
+ old = self.setSecurityManager(sm)
+ self.assertEqual(guarded_map(str, [1,2,3]), ['1','2','3'])
+ self.assertEqual(guarded_map(lambda x,y: x+y, [1,2,3], [3,2,1]),
+ [4,4,4])
+ self.setSecurityManager(old)
+
def test_min_succeeds(self):
sm = SecurityManager() # accepts
old = self.setSecurityManager(sm)
More information about the Zope-Checkins
mailing list