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
43368b57
Commit
43368b57
authored
Aug 18, 2006
by
Sidnei da Silva
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- Fix #2155: Wrong parameters being passed to logger's error().
parent
037c5569
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
159 additions
and
5 deletions
+159
-5
doc/CHANGES.txt
doc/CHANGES.txt
+3
-0
lib/python/ZPublisher/BeforeTraverse.py
lib/python/ZPublisher/BeforeTraverse.py
+3
-5
lib/python/ZPublisher/tests/testBeforeTraverse.py
lib/python/ZPublisher/tests/testBeforeTraverse.py
+153
-0
No files found.
doc/CHANGES.txt
View file @
43368b57
...
...
@@ -16,6 +16,9 @@ Zope Changes
- Usage of 'urljoin' in 'webdav.davcmds' could lead to wrongly
constructed urls.
- Collector #2155: Fix wrong parameter being passed to
logger's error() method, with tests.
Zope 2.9.4 (2006/07/21)
Bugs fixed
...
...
lib/python/ZPublisher/BeforeTraverse.py
View file @
43368b57
...
...
@@ -13,10 +13,9 @@
__version__
=
'$Revision: 1.12 $'
[
11
:
-
2
]
"""BeforeTraverse interface and helper classes"""
import
logging
import
logging
from
Acquisition
import
aq_base
import
sys
# Interface
...
...
@@ -105,7 +104,7 @@ class MultiHook:
cob
(
container
,
request
)
except
TypeError
:
self
.
logger
.
error
(
'%s call %s failed.'
%
(
`self._hookname`
,
`cob`
),
e
rror
=
sys
.
exc_info
()
)
`self._hookname`
,
`cob`
),
e
xc_info
=
True
)
def
add
(
self
,
cob
):
self
.
_list
.
append
(
cob
)
...
...
@@ -151,6 +150,5 @@ class NameCaller:
# Only catch exceptions that are likely to be logic errors.
# We shouldn't catch Redirects, Unauthorizeds, etc. since
# the programmer may want to raise them deliberately.
import
sys
self
.
logger
.
error
(
'Error while invoking hook: "%s"'
%
self
.
name
,
e
rror
=
sys
.
exc_info
()
)
%
self
.
name
,
e
xc_info
=
True
)
lib/python/ZPublisher/tests/testBeforeTraverse.py
0 → 100644
View file @
43368b57
import
sys
import
logging
from
Acquisition
import
Implicit
from
ZPublisher
import
BeforeTraverse
from
ZPublisher.BaseRequest
import
BaseRequest
from
ZPublisher.HTTPResponse
import
HTTPResponse
def
makeBaseRequest
(
root
):
response
=
HTTPResponse
()
environment
=
{
'URL'
:
''
,
'PARENTS'
:
[
root
],
'steps'
:
[],
'_hacked_path'
:
0
,
'_test_counter'
:
0
,
'response'
:
response
}
return
BaseRequest
(
environment
)
class
DummyObjectBasic
(
Implicit
):
""" Dummy class with docstring.
"""
pass
class
BrokenHook
:
def
__call__
(
self
,
*
args
):
print
self
.
__class__
.
__name__
,
'called'
raise
TypeError
,
self
.
__class__
.
__name__
def
testBeforeTraverse
(
self
):
"""
Zope supports a 'before traverse' hook that is used for several
features, including 'Site Access Rules'. It is implemented using a
special API for registering hooks, and the hooks themselves are
called during traversal by ZPublisher.
>>> root = DummyObjectBasic()
>>> request = makeBaseRequest(root)
>>> container = DummyObjectBasic()
>>> root.container = container
>>> obj = DummyObjectBasic()
>>> container.obj = obj
Setup a broken hook as the before traverse hook for the
container. That will create a 'MultiHook' object:
>>> BeforeTraverse.registerBeforeTraverse(container, BrokenHook(),
... 'broken_hook')
>>> container.__before_publishing_traverse__
<ZPublisher.BeforeTraverse.MultiHook instance at ...>
>>> container.__before_traverse__
{(99, 'broken_hook'): <ZPublisher.tests.testBeforeTraverse.BrokenHook ...>}
Setup logging so we can see the actual exception being logged:
>>> logger = logging.getLogger('MultiHook')
>>> level = logger.level
>>> handlers = logger.handlers[:]
>>> logger.addHandler(logging.StreamHandler(sys.stdout))
>>> logger.setLevel(logging.ERROR)
Now do the actual traversal:
>>> _ = request.traverse('container/obj')
BrokenHook called
'__before_publishing_traverse__' call ... failed.
Traceback (most recent call last):
...
TypeError: BrokenHook
Unregister the borken hook:
>>> _ = BeforeTraverse.unregisterBeforeTraverse(container, 'broken_hook')
The list of 'before traverse' hooks is empty:
>>> container.__before_traverse__
{}
But the 'MultiHook' is not removed:
>>> container.__before_publishing_traverse__
<ZPublisher.BeforeTraverse.MultiHook instance at ...>
If you have an object in the same container that you want to call
during traversal you can register a 'NameCaller' as the hook
instead, and it will delegate to the callable by looking it up as
an attribute of the container:
>>> container.broken_callable = BrokenHook()
>>> BeforeTraverse.registerBeforeTraverse(container,
... BeforeTraverse.NameCaller('broken_callable'),
... 'broken_callable')
>>> container.__before_traverse__
{(99, 'broken_callable'): <ZPublisher.BeforeTraverse.NameCaller ...>}
Setup logging so we can see the actual exception being logged:
>>> bt_logger = logging.getLogger('BeforeTraverse')
>>> bt_level = logger.level
>>> bt_handlers = logger.handlers[:]
>>> bt_logger.addHandler(logging.StreamHandler(sys.stdout))
>>> bt_logger.setLevel(logging.ERROR)
Now do the actual traversal:
>>> _ = request.traverse('container/obj')
BrokenHook called
Error while invoking hook: "broken_callable"
Traceback (most recent call last):
...
TypeError: BrokenHook
Unregister the borken hook:
>>> _ = BeforeTraverse.unregisterBeforeTraverse(container, 'broken_callable')
And restore the logger state:
>>> bt_logger.setLevel(bt_level)
>>> bt_logger.handlers = handlers[:]
The list of 'before traverse' hooks is empty:
>>> container.__before_traverse__
{}
But the 'MultiHook' is not removed:
>>> container.__before_publishing_traverse__
<ZPublisher.BeforeTraverse.MultiHook instance at ...>
Finally, restore the logger state:
>>> logger.setLevel(level)
>>> logger.handlers = handlers[:]
"""
pass
from
zope.testing
import
doctest
def
test_suite
():
return
doctest
.
DocTestSuite
(
optionflags
=
doctest
.
ELLIPSIS
)
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