Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
Zope
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
Zope
Commits
3cbd69a8
Commit
3cbd69a8
authored
Nov 01, 2008
by
Tres Seaver
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Clean out module-scope imports, wrap long lines.
parent
e9fce716
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
178 additions
and
152 deletions
+178
-152
lib/python/OFS/tests/testCopySupportEvents.py
lib/python/OFS/tests/testCopySupportEvents.py
+8
-4
lib/python/OFS/tests/testTraverse.py
lib/python/OFS/tests/testTraverse.py
+170
-148
No files found.
lib/python/OFS/tests/testCopySupportEvents.py
View file @
3cbd69a8
...
@@ -156,7 +156,8 @@ class TestCopySupport(EventTest):
...
@@ -156,7 +156,8 @@ class TestCopySupport(EventTest):
# Test webdav COPY
# Test webdav COPY
req
=
self
.
app
.
REQUEST
req
=
self
.
app
.
REQUEST
req
.
environ
[
'HTTP_DEPTH'
]
=
'infinity'
req
.
environ
[
'HTTP_DEPTH'
]
=
'infinity'
req
.
environ
[
'HTTP_DESTINATION'
]
=
'%s/subfolder/mydoc'
%
self
.
folder
.
absolute_url
()
req
.
environ
[
'HTTP_DESTINATION'
]
=
(
'%s/subfolder/mydoc'
%
self
.
folder
.
absolute_url
())
self
.
folder
.
mydoc
.
COPY
(
req
,
req
.
RESPONSE
)
self
.
folder
.
mydoc
.
COPY
(
req
,
req
.
RESPONSE
)
self
.
assertEqual
(
eventlog
.
called
(),
self
.
assertEqual
(
eventlog
.
called
(),
[(
'mydoc'
,
'ObjectCopiedEvent'
),
[(
'mydoc'
,
'ObjectCopiedEvent'
),
...
@@ -170,7 +171,8 @@ class TestCopySupport(EventTest):
...
@@ -170,7 +171,8 @@ class TestCopySupport(EventTest):
# Test webdav MOVE
# Test webdav MOVE
req
=
self
.
app
.
REQUEST
req
=
self
.
app
.
REQUEST
req
.
environ
[
'HTTP_DEPTH'
]
=
'infinity'
req
.
environ
[
'HTTP_DEPTH'
]
=
'infinity'
req
.
environ
[
'HTTP_DESTINATION'
]
=
'%s/subfolder/mydoc'
%
self
.
folder
.
absolute_url
()
req
.
environ
[
'HTTP_DESTINATION'
]
=
(
'%s/subfolder/mydoc'
%
self
.
folder
.
absolute_url
())
self
.
folder
.
mydoc
.
MOVE
(
req
,
req
.
RESPONSE
)
self
.
folder
.
mydoc
.
MOVE
(
req
,
req
.
RESPONSE
)
self
.
assertEqual
(
eventlog
.
called
(),
self
.
assertEqual
(
eventlog
.
called
(),
[(
'mydoc'
,
'ObjectWillBeMovedEvent'
),
[(
'mydoc'
,
'ObjectWillBeMovedEvent'
),
...
@@ -278,7 +280,8 @@ class TestCopySupportSublocation(EventTest):
...
@@ -278,7 +280,8 @@ class TestCopySupportSublocation(EventTest):
# Test webdav COPY
# Test webdav COPY
req
=
self
.
app
.
REQUEST
req
=
self
.
app
.
REQUEST
req
.
environ
[
'HTTP_DEPTH'
]
=
'infinity'
req
.
environ
[
'HTTP_DEPTH'
]
=
'infinity'
req
.
environ
[
'HTTP_DESTINATION'
]
=
'%s/subfolder/myfolder'
%
self
.
folder
.
absolute_url
()
req
.
environ
[
'HTTP_DESTINATION'
]
=
(
'%s/subfolder/myfolder'
%
self
.
folder
.
absolute_url
())
self
.
folder
.
myfolder
.
COPY
(
req
,
req
.
RESPONSE
)
self
.
folder
.
myfolder
.
COPY
(
req
,
req
.
RESPONSE
)
self
.
assertEqual
(
eventlog
.
called
(),
self
.
assertEqual
(
eventlog
.
called
(),
[(
'myfolder'
,
'ObjectCopiedEvent'
),
[(
'myfolder'
,
'ObjectCopiedEvent'
),
...
@@ -296,7 +299,8 @@ class TestCopySupportSublocation(EventTest):
...
@@ -296,7 +299,8 @@ class TestCopySupportSublocation(EventTest):
# Test webdav MOVE
# Test webdav MOVE
req
=
self
.
app
.
REQUEST
req
=
self
.
app
.
REQUEST
req
.
environ
[
'HTTP_DEPTH'
]
=
'infinity'
req
.
environ
[
'HTTP_DEPTH'
]
=
'infinity'
req
.
environ
[
'HTTP_DESTINATION'
]
=
'%s/subfolder/myfolder'
%
self
.
folder
.
absolute_url
()
req
.
environ
[
'HTTP_DESTINATION'
]
=
(
'%s/subfolder/myfolder'
%
self
.
folder
.
absolute_url
())
self
.
folder
.
myfolder
.
MOVE
(
req
,
req
.
RESPONSE
)
self
.
folder
.
myfolder
.
MOVE
(
req
,
req
.
RESPONSE
)
self
.
assertEqual
(
eventlog
.
called
(),
self
.
assertEqual
(
eventlog
.
called
(),
[(
'myfolder'
,
'ObjectWillBeMovedEvent'
),
[(
'myfolder'
,
'ObjectWillBeMovedEvent'
),
...
...
lib/python/OFS/tests/testTraverse.py
View file @
3cbd69a8
...
@@ -17,21 +17,6 @@ $Id$
...
@@ -17,21 +17,6 @@ $Id$
import
unittest
import
unittest
import
cStringIO
import
transaction
import
ZODB
,
Acquisition
,
transaction
from
AccessControl
import
SecurityManager
,
Unauthorized
from
AccessControl.Permissions
import
access_contents_information
from
AccessControl.SecurityManagement
import
newSecurityManager
from
AccessControl.SecurityManagement
import
noSecurityManager
from
Acquisition
import
aq_base
from
OFS.Application
import
Application
from
OFS.Folder
import
manage_addFolder
from
OFS.Image
import
manage_addFile
from
OFS.SimpleItem
import
SimpleItem
from
Testing.makerequest
import
makerequest
class
UnitTestSecurityPolicy
:
class
UnitTestSecurityPolicy
:
"""
"""
...
@@ -62,6 +47,7 @@ class CruelSecurityPolicy:
...
@@ -62,6 +47,7 @@ class CruelSecurityPolicy:
# Standard SecurityPolicy interface
# Standard SecurityPolicy interface
#
#
def
validate
(
self
,
accessed
,
container
,
name
,
value
,
*
args
):
def
validate
(
self
,
accessed
,
container
,
name
,
value
,
*
args
):
from
AccessControl
import
Unauthorized
raise
Unauthorized
,
name
raise
Unauthorized
,
name
def
checkPermission
(
self
,
permission
,
object
,
context
)
:
def
checkPermission
(
self
,
permission
,
object
,
context
)
:
...
@@ -72,6 +58,8 @@ class ProtectedMethodSecurityPolicy:
...
@@ -72,6 +58,8 @@ class ProtectedMethodSecurityPolicy:
"""Check security strictly on bound methods.
"""Check security strictly on bound methods.
"""
"""
def
validate
(
self
,
accessed
,
container
,
name
,
value
,
*
args
):
def
validate
(
self
,
accessed
,
container
,
name
,
value
,
*
args
):
from
Acquisition
import
aq_base
from
AccessControl
import
Unauthorized
if
getattr
(
aq_base
(
value
),
'im_self'
,
None
)
is
None
:
if
getattr
(
aq_base
(
value
),
'im_self'
,
None
)
is
None
:
return
1
return
1
...
@@ -85,81 +73,23 @@ class ProtectedMethodSecurityPolicy:
...
@@ -85,81 +73,23 @@ class ProtectedMethodSecurityPolicy:
raise
Unauthorized
(
name
)
raise
Unauthorized
(
name
)
class
TestTraverse
(
unittest
.
TestCase
):
class
UnitTestUser
(
Acquisition
.
Implicit
):
def
setUp
(
self
):
"""
import
cStringIO
Stubbed out manager for unit testing purposes.
import
transaction
"""
from
AccessControl
import
SecurityManager
def
getId
(
self
):
from
AccessControl.SecurityManagement
import
newSecurityManager
return
'unit_tester'
from
OFS.Application
import
Application
from
OFS.Folder
import
manage_addFolder
getUserName
=
getId
from
OFS.Image
import
manage_addFile
from
Testing.makerequest
import
makerequest
def
allowed
(
self
,
object
,
object_roles
=
None
):
from
ZODB.DB
import
DB
return
1
class
BoboTraversable
(
SimpleItem
):
__allow_access_to_unprotected_subobjects__
=
1
def
__bobo_traverse__
(
self
,
request
,
name
):
if
name
==
'bb_subitem'
:
return
BoboTraversable
().
__of__
(
self
)
elif
name
==
'bb_method'
:
return
self
.
bb_method
elif
name
==
'bb_status'
:
return
self
.
bb_status
elif
name
==
'manufactured'
:
return
42
else
:
raise
KeyError
def
bb_method
(
self
):
"""Test Method"""
pass
bb_status
=
'screechy'
class
Restricted
(
SimpleItem
):
"""Instance we'll check with ProtectedMethodSecurityPolicy
"""
getId__roles__
=
None
# ACCESS_PUBLIC
def
getId
(
self
):
return
self
.
id
private__roles__
=
()
# ACCESS_PRIVATE
def
private
(
self
):
return
'private!'
# not protected
def
ohno
(
self
):
return
'ohno!'
class
BoboTraversableWithAcquisition
(
SimpleItem
):
"""
A BoboTraversable class which may use acquisition to find objects.
This is similar to how the __bobo_traverse__ added by Five behaves).
"""
def
__bobo_traverse__
(
self
,
request
,
name
):
return
Acquisition
.
aq_get
(
self
,
name
)
def
makeConnection
():
import
ZODB
from
ZODB.DemoStorage
import
DemoStorage
from
ZODB.DemoStorage
import
DemoStorage
s
=
DemoStorage
(
quota
=
(
1
<<
20
))
s
=
DemoStorage
(
quota
=
(
1
<<
20
))
return
ZODB
.
DB
(
s
).
open
()
self
.
connection
=
DB
(
s
).
open
()
class
TestTraverse
(
unittest
.
TestCase
):
def
setUp
(
self
):
self
.
connection
=
makeConnection
()
try
:
try
:
r
=
self
.
connection
.
root
()
r
=
self
.
connection
.
root
()
a
=
Application
()
a
=
Application
()
...
@@ -172,7 +102,7 @@ class TestTraverse( unittest.TestCase ):
...
@@ -172,7 +102,7 @@ class TestTraverse( unittest.TestCase ):
setattr
(
folder1
,
'+something'
,
'plus'
)
setattr
(
folder1
,
'+something'
,
'plus'
)
folder1
.
all_meta_types
=
\
folder1
.
all_meta_types
=
\
(
{
'name'
:
'File'
({
'name'
:
'File'
,
'action'
:
'manage_addFile'
,
'action'
:
'manage_addFile'
,
'permission'
:
'Add images and files'
,
'permission'
:
'Add images and files'
}
}
...
@@ -194,11 +124,11 @@ class TestTraverse( unittest.TestCase ):
...
@@ -194,11 +124,11 @@ class TestTraverse( unittest.TestCase ):
self
.
policy
=
UnitTestSecurityPolicy
()
self
.
policy
=
UnitTestSecurityPolicy
()
self
.
oldPolicy
=
SecurityManager
.
setSecurityPolicy
(
self
.
policy
)
self
.
oldPolicy
=
SecurityManager
.
setSecurityPolicy
(
self
.
policy
)
newSecurityManager
(
None
,
UnitTest
User
().
__of__
(
self
.
root
)
)
newSecurityManager
(
None
,
self
.
_make
User
().
__of__
(
self
.
root
)
)
def
tearDown
(
self
):
def
tearDown
(
self
):
noSecurityManager
()
import
transaction
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
self
.
_setupSecurity
(
)
del
self
.
oldPolicy
del
self
.
oldPolicy
del
self
.
policy
del
self
.
policy
del
self
.
folder1
del
self
.
folder1
...
@@ -210,6 +140,90 @@ class TestTraverse( unittest.TestCase ):
...
@@ -210,6 +140,90 @@ class TestTraverse( unittest.TestCase ):
del
self
.
root
del
self
.
root
del
self
.
connection
del
self
.
connection
def
_makeUser
(
self
):
from
Acquisition
import
Implicit
class
UnitTestUser
(
Implicit
):
"""
Stubbed out manager for unit testing purposes.
"""
def
getId
(
self
):
return
'unit_tester'
getUserName
=
getId
def
allowed
(
self
,
object
,
object_roles
=
None
):
return
1
return
UnitTestUser
()
def
_makeBoboTraversable
(
self
):
from
OFS.SimpleItem
import
SimpleItem
class
BoboTraversable
(
SimpleItem
):
__allow_access_to_unprotected_subobjects__
=
1
def
__bobo_traverse__
(
self
,
request
,
name
):
if
name
==
'bb_subitem'
:
return
BoboTraversable
().
__of__
(
self
)
elif
name
==
'bb_method'
:
return
self
.
bb_method
elif
name
==
'bb_status'
:
return
self
.
bb_status
elif
name
==
'manufactured'
:
return
42
else
:
raise
KeyError
def
bb_method
(
self
):
"""Test Method"""
pass
bb_status
=
'screechy'
return
BoboTraversable
()
def
_makeBoboTraversableWithAcquisition
(
self
):
from
OFS.SimpleItem
import
SimpleItem
class
BoboTraversableWithAcquisition
(
SimpleItem
):
""" A BoboTraversable which may use acquisition to find objects.
This is similar to how the __bobo_traverse__ added by Five
behaves).
"""
def
__bobo_traverse__
(
self
,
request
,
name
):
from
Acquisition
import
aq_get
return
aq_get
(
self
,
name
)
return
BoboTraversableWithAcquisition
()
def
_makeRestricted
(
self
,
name
=
'dummy'
):
from
OFS.SimpleItem
import
SimpleItem
class
Restricted
(
SimpleItem
):
"""Instance we'll check with ProtectedMethodSecurityPolicy
"""
getId__roles__
=
None
# ACCESS_PUBLIC
def
getId
(
self
):
return
self
.
id
private__roles__
=
()
# ACCESS_PRIVATE
def
private
(
self
):
return
'private!'
# not protected
def
ohno
(
self
):
return
'ohno!'
return
Restricted
(
name
)
def
_setupSecurity
(
self
,
policy
=
None
):
from
AccessControl
import
SecurityManager
from
AccessControl.SecurityManagement
import
noSecurityManager
if
policy
is
None
:
policy
=
self
.
oldPolicy
noSecurityManager
()
SecurityManager
.
setSecurityPolicy
(
policy
)
def
test_z3interfaces
(
self
):
def
test_z3interfaces
(
self
):
from
OFS.interfaces
import
ITraversable
from
OFS.interfaces
import
ITraversable
from
OFS.Traversable
import
Traversable
from
OFS.Traversable
import
Traversable
...
@@ -232,9 +246,9 @@ class TestTraverse( unittest.TestCase ):
...
@@ -232,9 +246,9 @@ class TestTraverse( unittest.TestCase ):
self
.
folder1
.
unrestrictedTraverse
(
'/folder1'
))
self
.
folder1
.
unrestrictedTraverse
(
'/folder1'
))
def
testTraverseURLSlash
(
self
):
def
testTraverseURLSlash
(
self
):
self
.
failUnless
(
'file'
in
self
.
folder1
.
objectIds
()
)
self
.
failUnless
(
'file'
in
self
.
folder1
.
objectIds
()
)
self
.
failUnless
(
self
.
folder1
.
unrestrictedTraverse
(
'/folder1/file/'
))
self
.
failUnless
(
self
.
folder1
.
unrestrictedTraverse
(
'/folder1/file/'
))
self
.
failUnless
(
self
.
folder1
.
unrestrictedTraverse
(
'/folder1/'
))
self
.
failUnless
(
self
.
folder1
.
unrestrictedTraverse
(
'/folder1/'
))
def
testTraverseToNone
(
self
):
def
testTraverseToNone
(
self
):
self
.
failUnlessRaises
(
self
.
failUnlessRaises
(
...
@@ -246,11 +260,11 @@ class TestTraverse( unittest.TestCase ):
...
@@ -246,11 +260,11 @@ class TestTraverse( unittest.TestCase ):
KeyError
,
self
.
folder1
.
unrestrictedTraverse
,
'/folder1/file2/'
)
KeyError
,
self
.
folder1
.
unrestrictedTraverse
,
'/folder1/file2/'
)
def
testTraverseMethodRestricted
(
self
):
def
testTraverseMethodRestricted
(
self
):
self
.
root
.
my
=
Restricted
(
'my'
)
from
AccessControl
import
Unauthorized
self
.
root
.
my
=
self
.
_makeRestricted
(
'my'
)
my
=
self
.
root
.
my
my
=
self
.
root
.
my
my
.
id
=
'my'
my
.
id
=
'my'
noSecurityManager
()
self
.
_setupSecurity
(
ProtectedMethodSecurityPolicy
())
SecurityManager
.
setSecurityPolicy
(
ProtectedMethodSecurityPolicy
())
r
=
my
.
restrictedTraverse
(
'getId'
)
r
=
my
.
restrictedTraverse
(
'getId'
)
self
.
assertEquals
(
r
(),
'my'
)
self
.
assertEquals
(
r
(),
'my'
)
self
.
assertRaises
(
Unauthorized
,
my
.
restrictedTraverse
,
'private'
)
self
.
assertRaises
(
Unauthorized
,
my
.
restrictedTraverse
,
'private'
)
...
@@ -259,61 +273,58 @@ class TestTraverse( unittest.TestCase ):
...
@@ -259,61 +273,58 @@ class TestTraverse( unittest.TestCase ):
def
testBoboTraverseToWrappedSubObj
(
self
):
def
testBoboTraverseToWrappedSubObj
(
self
):
# Verify it's possible to use __bobo_traverse__ with the
# Verify it's possible to use __bobo_traverse__ with the
# Zope security policy.
# Zope security policy.
noSecurityManager
()
self
.
_setupSecurity
()
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
bb
=
self
.
_makeBoboTraversable
()
bb
=
BoboTraversable
()
self
.
failUnlessRaises
(
KeyError
,
bb
.
restrictedTraverse
,
'notfound'
)
self
.
failUnlessRaises
(
KeyError
,
bb
.
restrictedTraverse
,
'notfound'
)
bb
.
restrictedTraverse
(
'bb_subitem'
)
bb
.
restrictedTraverse
(
'bb_subitem'
)
def
testBoboTraverseToMethod
(
self
):
def
testBoboTraverseToMethod
(
self
):
# Verify it's possible to use __bobo_traverse__ to a method.
# Verify it's possible to use __bobo_traverse__ to a method.
noSecurityManager
()
self
.
_setupSecurity
()
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
bb
=
self
.
_makeBoboTraversable
()
bb
=
BoboTraversable
()
self
.
failUnless
(
self
.
failUnless
(
bb
.
restrictedTraverse
(
'bb_method'
)
is
not
bb
.
bb_method
)
bb
.
restrictedTraverse
(
'bb_method'
)
is
not
bb
.
bb_method
)
def
testBoboTraverseToSimpleAttrValue
(
self
):
def
testBoboTraverseToSimpleAttrValue
(
self
):
# Verify it's possible to use __bobo_traverse__ to a simple
# Verify it's possible to use __bobo_traverse__ to a simple
# python value
# python value
noSecurityManager
()
self
.
_setupSecurity
()
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
bb
=
self
.
_makeBoboTraversable
()
bb
=
BoboTraversable
()
self
.
assertEqual
(
bb
.
restrictedTraverse
(
'bb_status'
),
'screechy'
)
self
.
assertEqual
(
bb
.
restrictedTraverse
(
'bb_status'
),
'screechy'
)
def
testBoboTraverseToNonAttrValue
(
self
):
def
testBoboTraverseToNonAttrValue
(
self
):
# Verify it's possible to use __bobo_traverse__ to an
# Verify it's possible to use __bobo_traverse__ to an
# arbitrary manufactured object
# arbitrary manufactured object
noSecurityManager
()
# Default security policy always seems to deny in this case, which
# Default security policy always seems to deny in this case, which
# is fine, but to test the code branch we sub in the forgiving one
# is fine, but to test the code branch we sub in the forgiving one
SecurityManager
.
setSecurityPolic
y
(
UnitTestSecurityPolicy
())
self
.
_setupSecurit
y
(
UnitTestSecurityPolicy
())
bb
=
BoboTraversable
()
bb
=
self
.
_make
BoboTraversable
()
self
.
failUnless
(
self
.
failUnless
(
bb
.
restrictedTraverse
(
'manufactured'
)
is
42
)
bb
.
restrictedTraverse
(
'manufactured'
)
is
42
)
def
testBoboTraverseToAcquiredObject
(
self
):
def
testBoboTraverseToAcquiredObject
(
self
):
# Verify it's possible to use a __bobo_traverse__ which retrieves
# Verify it's possible to use a __bobo_traverse__ which retrieves
# objects by acquisition
# objects by acquisition
noSecurityManager
()
from
Acquisition
import
aq_inner
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
self
.
_setupSecurity
(
)
bb
=
BoboTraversableWithAcquisition
()
bb
=
self
.
_make
BoboTraversableWithAcquisition
()
bb
=
bb
.
__of__
(
self
.
root
)
bb
=
bb
.
__of__
(
self
.
root
)
self
.
assertEqual
(
self
.
assertEqual
(
bb
.
restrictedTraverse
(
'folder1'
),
bb
.
folder1
)
bb
.
restrictedTraverse
(
'folder1'
),
bb
.
folder1
)
self
.
assertEqual
(
self
.
assertEqual
(
Acquisition
.
aq_inner
(
bb
.
restrictedTraverse
(
'folder1'
)),
aq_inner
(
bb
.
restrictedTraverse
(
'folder1'
)),
self
.
root
.
folder1
)
self
.
root
.
folder1
)
def
testBoboTraverseToAcquiredProtectedObject
(
self
):
def
testBoboTraverseToAcquiredProtectedObject
(
self
):
# Verify it's possible to use a __bobo_traverse__ which retrieves
# Verify it's possible to use a __bobo_traverse__ which retrieves
# objects by acquisition
# objects by acquisition
noSecurityManager
()
from
AccessControl
import
Unauthorized
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
from
AccessControl.Permissions
import
access_contents_information
self
.
_setupSecurity
()
folder
=
self
.
root
.
folder1
folder
=
self
.
root
.
folder1
# restrict the ability to access the retrieved object itself
# restrict the ability to access the retrieved object itself
folder
.
manage_permission
(
access_contents_information
,
[],
0
)
folder
.
manage_permission
(
access_contents_information
,
[],
0
)
bb
=
BoboTraversableWithAcquisition
()
bb
=
self
.
_make
BoboTraversableWithAcquisition
()
bb
=
bb
.
__of__
(
self
.
root
)
bb
=
bb
.
__of__
(
self
.
root
)
self
.
failUnlessRaises
(
Unauthorized
,
self
.
failUnlessRaises
(
Unauthorized
,
bb
.
restrictedTraverse
,
'folder1'
)
bb
.
restrictedTraverse
,
'folder1'
)
...
@@ -321,11 +332,10 @@ class TestTraverse( unittest.TestCase ):
...
@@ -321,11 +332,10 @@ class TestTraverse( unittest.TestCase ):
def
testBoboTraverseToAcquiredAttribute
(
self
):
def
testBoboTraverseToAcquiredAttribute
(
self
):
# Verify it's possible to use __bobo_traverse__ to an acquired
# Verify it's possible to use __bobo_traverse__ to an acquired
# attribute
# attribute
noSecurityManager
()
self
.
_setupSecurity
()
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
folder
=
self
.
root
.
folder1
folder
=
self
.
root
.
folder1
folder
.
stuff
=
'stuff here'
folder
.
stuff
=
'stuff here'
bb
=
BoboTraversableWithAcquisition
()
bb
=
self
.
_make
BoboTraversableWithAcquisition
()
bb
=
bb
.
__of__
(
folder
)
bb
=
bb
.
__of__
(
folder
)
self
.
assertEqual
(
self
.
assertEqual
(
bb
.
restrictedTraverse
(
'stuff'
),
'stuff here'
)
bb
.
restrictedTraverse
(
'stuff'
),
'stuff here'
)
...
@@ -333,13 +343,14 @@ class TestTraverse( unittest.TestCase ):
...
@@ -333,13 +343,14 @@ class TestTraverse( unittest.TestCase ):
def
testBoboTraverseToAcquiredProtectedAttribute
(
self
):
def
testBoboTraverseToAcquiredProtectedAttribute
(
self
):
# Verify that using __bobo_traverse__ to get an acquired but
# Verify that using __bobo_traverse__ to get an acquired but
# protected attribute results in Unauthorized
# protected attribute results in Unauthorized
noSecurityManager
()
from
AccessControl
import
Unauthorized
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
from
AccessControl.Permissions
import
access_contents_information
self
.
_setupSecurity
()
folder
=
self
.
root
.
folder1
folder
=
self
.
root
.
folder1
# We protect the the attribute by restricting access to the parent
# We protect the the attribute by restricting access to the parent
folder
.
manage_permission
(
access_contents_information
,
[],
0
)
folder
.
manage_permission
(
access_contents_information
,
[],
0
)
folder
.
stuff
=
'stuff here'
folder
.
stuff
=
'stuff here'
bb
=
BoboTraversableWithAcquisition
()
bb
=
self
.
_make
BoboTraversableWithAcquisition
()
bb
=
bb
.
__of__
(
folder
)
bb
=
bb
.
__of__
(
folder
)
self
.
failUnlessRaises
(
Unauthorized
,
self
.
failUnlessRaises
(
Unauthorized
,
self
.
root
.
folder1
.
restrictedTraverse
,
'stuff'
)
self
.
root
.
folder1
.
restrictedTraverse
,
'stuff'
)
...
@@ -349,9 +360,10 @@ class TestTraverse( unittest.TestCase ):
...
@@ -349,9 +360,10 @@ class TestTraverse( unittest.TestCase ):
# on denial of access to an acquired attribute. If it raises
# on denial of access to an acquired attribute. If it raises
# AttributeError instead of Unauthorized, the user may never
# AttributeError instead of Unauthorized, the user may never
# be prompted for HTTP credentials.
# be prompted for HTTP credentials.
noSecurityManager
()
from
AccessControl
import
Unauthorized
SecurityManager
.
setSecurityPolicy
(
CruelSecurityPolicy
())
from
AccessControl.SecurityManagement
import
newSecurityManager
newSecurityManager
(
None
,
UnitTestUser
().
__of__
(
self
.
root
)
)
self
.
_setupSecurity
(
CruelSecurityPolicy
())
newSecurityManager
(
None
,
self
.
_makeUser
().
__of__
(
self
.
root
)
)
self
.
root
.
stuff
=
'stuff here'
self
.
root
.
stuff
=
'stuff here'
self
.
failUnlessRaises
(
Unauthorized
,
self
.
failUnlessRaises
(
Unauthorized
,
self
.
app
.
folder1
.
restrictedTraverse
,
'stuff'
)
self
.
app
.
folder1
.
restrictedTraverse
,
'stuff'
)
...
@@ -359,9 +371,9 @@ class TestTraverse( unittest.TestCase ):
...
@@ -359,9 +371,9 @@ class TestTraverse( unittest.TestCase ):
def
testDefaultValueWhenUnathorized
(
self
):
def
testDefaultValueWhenUnathorized
(
self
):
# Test that traversing to an unauthorized object returns
# Test that traversing to an unauthorized object returns
# the default when provided
# the default when provided
noSecurityManager
()
from
AccessControl.SecurityManagement
import
newSecurityManager
SecurityManager
.
setSecurityPolic
y
(
CruelSecurityPolicy
())
self
.
_setupSecurit
y
(
CruelSecurityPolicy
())
newSecurityManager
(
None
,
UnitTest
User
().
__of__
(
self
.
root
)
)
newSecurityManager
(
None
,
self
.
_make
User
().
__of__
(
self
.
root
)
)
self
.
root
.
stuff
=
'stuff here'
self
.
root
.
stuff
=
'stuff here'
self
.
assertEqual
(
self
.
assertEqual
(
self
.
root
.
folder1
.
restrictedTraverse
(
'stuff'
,
42
),
42
)
self
.
root
.
folder1
.
restrictedTraverse
(
'stuff'
,
42
),
42
)
...
@@ -369,13 +381,13 @@ class TestTraverse( unittest.TestCase ):
...
@@ -369,13 +381,13 @@ class TestTraverse( unittest.TestCase ):
def
testDefaultValueWhenNotFound
(
self
):
def
testDefaultValueWhenNotFound
(
self
):
# Test that traversing to a non-existent object returns
# Test that traversing to a non-existent object returns
# the default when provided
# the default when provided
noSecurityManager
()
self
.
_setupSecurity
()
SecurityManager
.
setSecurityPolicy
(
self
.
oldPolicy
)
self
.
assertEqual
(
self
.
assertEqual
(
self
.
root
.
restrictedTraverse
(
'happy/happy'
,
'joy'
),
'joy'
)
self
.
root
.
restrictedTraverse
(
'happy/happy'
,
'joy'
),
'joy'
)
def
testTraverseUp
(
self
):
def
testTraverseUp
(
self
):
# Test that we can traverse upwards
# Test that we can traverse upwards
from
Acquisition
import
aq_base
self
.
failUnless
(
self
.
failUnless
(
aq_base
(
self
.
root
.
folder1
.
file
.
restrictedTraverse
(
'../..'
))
is
aq_base
(
self
.
root
.
folder1
.
file
.
restrictedTraverse
(
'../..'
))
is
aq_base
(
self
.
root
))
aq_base
(
self
.
root
))
...
@@ -396,9 +408,9 @@ class SimpleClass(object):
...
@@ -396,9 +408,9 @@ class SimpleClass(object):
def
test_traversable
():
def
test_traversable
():
"""
"""
Test the behaviour of unrestrictedTraverse and views. The tests are
copies
Test the behaviour of unrestrictedTraverse and views. The tests are
from Five.browser.tests.test_traversable, but instead of publishing they
copies from Five.browser.tests.test_traversable, but instead of
do unrestrictedTraverse.
publishing they
do unrestrictedTraverse.
>>> import Products.Five
>>> import Products.Five
>>> from Products.Five import zcml
>>> from Products.Five import zcml
...
@@ -412,7 +424,8 @@ def test_traversable():
...
@@ -412,7 +424,8 @@ def test_traversable():
the wrong reason: None doesn't have a docstring so BaseRequest
the wrong reason: None doesn't have a docstring so BaseRequest
raises NotFoundError.)
raises NotFoundError.)
>>> from Products.Five.tests.testing.simplecontent import manage_addSimpleContent
>>> from Products.Five.tests.testing.simplecontent
\
... import manage_addSimpleContent
>>> manage_addSimpleContent(self.folder, 'testoid', 'Testoid')
>>> manage_addSimpleContent(self.folder, 'testoid', 'Testoid')
>>> from zExceptions import NotFound
>>> from zExceptions import NotFound
>>> try:
>>> try:
...
@@ -458,13 +471,15 @@ def test_traversable():
...
@@ -458,13 +471,15 @@ def test_traversable():
... </configure>'''
... </configure>'''
>>> zcml.load_string(configure_zcml)
>>> zcml.load_string(configure_zcml)
>>> from Products.Five.tests.testing.fancycontent import manage_addFancyContent
>>> from Products.Five.tests.testing.fancycontent
\
... import manage_addFancyContent
>>> info = manage_addFancyContent(self.folder, 'fancy', '')
>>> info = manage_addFancyContent(self.folder, 'fancy', '')
In the following test we let the original __bobo_traverse__ method
In the following test we let the original __bobo_traverse__ method
kick in:
kick in:
>>> self.folder.fancy.unrestrictedTraverse('something-else').index_html({})
>>> self.folder.fancy.unrestrictedTraverse('something-else'
... ).index_html({})
'something-else'
'something-else'
Once we have a custom __bobo_traverse__ method, though, it always
Once we have a custom __bobo_traverse__ method, though, it always
...
@@ -495,10 +510,13 @@ def test_traversable():
...
@@ -495,10 +510,13 @@ def test_traversable():
the __bobo_traverse__ is the only element used for traversal lookup).
the __bobo_traverse__ is the only element used for traversal lookup).
Let's demonstrate:
Let's demonstrate:
>>> from Products.Five.tests.testing.fancycontent import manage_addNonTraversableFancyContent
>>> from Products.Five.tests.testing.fancycontent
\
>>> info = manage_addNonTraversableFancyContent(self.folder, 'fancy_zope2', '')
... import manage_addNonTraversableFancyContent
>>> info = manage_addNonTraversableFancyContent(self.folder,
... 'fancy_zope2', '')
>>> self.folder.fancy_zope2.an_attribute = 'This is an attribute'
>>> self.folder.fancy_zope2.an_attribute = 'This is an attribute'
>>> self.folder.fancy_zope2.unrestrictedTraverse('an_attribute').index_html({})
>>> self.folder.fancy_zope2.unrestrictedTraverse(
... 'an_attribute').index_html({})
'an_attribute'
'an_attribute'
Without a __bobo_traverse__ method this would have returned the attribute
Without a __bobo_traverse__ method this would have returned the attribute
...
@@ -506,7 +524,8 @@ def test_traversable():
...
@@ -506,7 +524,8 @@ def test_traversable():
an object that has been marked traversable by Five:
an object that has been marked traversable by Five:
>>> self.folder.fancy.an_attribute = 'This is an attribute'
>>> self.folder.fancy.an_attribute = 'This is an attribute'
>>> self.folder.fancy.unrestrictedTraverse('an_attribute').index_html({})
>>> self.folder.fancy.unrestrictedTraverse(
... 'an_attribute').index_html({})
'an_attribute'
'an_attribute'
...
@@ -517,7 +536,8 @@ def test_traversable():
...
@@ -517,7 +536,8 @@ def test_traversable():
Verify that after cleanup, there's no cruft left from five:traversable::
Verify that after cleanup, there's no cruft left from five:traversable::
>>> from Products.Five.browser.tests.test_traversable import SimpleClass
>>> from Products.Five.browser.tests.test_traversable
\
... import SimpleClass
>>> hasattr(SimpleClass, '__bobo_traverse__')
>>> hasattr(SimpleClass, '__bobo_traverse__')
False
False
>>> hasattr(SimpleClass, '__fallback_traverse__')
>>> hasattr(SimpleClass, '__fallback_traverse__')
...
@@ -568,12 +588,14 @@ def test_view_doesnt_shadow_attribute():
...
@@ -568,12 +588,14 @@ def test_view_doesnt_shadow_attribute():
Then we create a traversable folder...
Then we create a traversable folder...
>>> from Products.Five.tests.testing.folder import manage_addFiveTraversableFolder
>>> from Products.Five.tests.testing.folder
\
... import manage_addFiveTraversableFolder
>>> manage_addFiveTraversableFolder(self.folder, 'ftf')
>>> manage_addFiveTraversableFolder(self.folder, 'ftf')
and add an object called ``eagle`` to it:
and add an object called ``eagle`` to it:
>>> from Products.Five.tests.testing.simplecontent import manage_addIndexSimpleContent
>>> from Products.Five.tests.testing.simplecontent
\
... import manage_addIndexSimpleContent
>>> manage_addIndexSimpleContent(self.folder.ftf, 'eagle', 'Eagle')
>>> manage_addIndexSimpleContent(self.folder.ftf, 'eagle', 'Eagle')
When we publish the ``ftf/eagle`` now, we expect the attribute to
When we publish the ``ftf/eagle`` now, we expect the attribute to
...
@@ -602,8 +624,8 @@ def test_view_doesnt_shadow_attribute():
...
@@ -602,8 +624,8 @@ def test_view_doesnt_shadow_attribute():
>>> self.folder.ftf.unrestrictedTraverse('mouse')()
>>> self.folder.ftf.unrestrictedTraverse('mouse')()
u'The mouse has been eaten by the eagle'
u'The mouse has been eaten by the eagle'
Head requests have some unusual behavior in Zope 2, in particular, a
failed
Head requests have some unusual behavior in Zope 2, in particular, a
item lookup on an ObjectManager returns a NullResource, rather
failed
item lookup on an ObjectManager returns a NullResource, rather
than raising a KeyError. We need to make sure that this doesn't
than raising a KeyError. We need to make sure that this doesn't
result in acquired attributes being shadowed by the NullResource,
result in acquired attributes being shadowed by the NullResource,
but that unknown names still give NullResources:
but that unknown names still give NullResources:
...
@@ -626,7 +648,7 @@ def test_suite():
...
@@ -626,7 +648,7 @@ def test_suite():
suite
=
unittest
.
TestSuite
()
suite
=
unittest
.
TestSuite
()
suite
.
addTest
(
unittest
.
makeSuite
(
TestTraverse
)
)
suite
.
addTest
(
unittest
.
makeSuite
(
TestTraverse
)
)
from
Testing.ZopeTestCase
import
FunctionalDocTestSuite
from
Testing.ZopeTestCase
import
FunctionalDocTestSuite
suite
.
addTest
(
FunctionalDocTestSuite
()
)
#
suite.addTest( FunctionalDocTestSuite() )
return
suite
return
suite
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment