Commit b1417dd9 authored by 's avatar

- fixed ObjectManagerNameChooser: BTreeFolder2 raises KeyError, not AttributeError

parent 304d5622
...@@ -19,6 +19,8 @@ Features Added ...@@ -19,6 +19,8 @@ Features Added
Bugs Fixed Bugs Fixed
++++++++++ ++++++++++
- ObjectManagerNameChooser now also works with BTreeFolder2.
- Correctly handle unauthorized exceptions in the ZPublisherExceptionHook. - Correctly handle unauthorized exceptions in the ZPublisherExceptionHook.
Zope 2.12.0 b2 (2009/05/27) Zope 2.12.0 b2 (2009/05/27)
......
...@@ -206,9 +206,9 @@ class ContentAdding(Adding, SimpleItem): ...@@ -206,9 +206,9 @@ class ContentAdding(Adding, SimpleItem):
class ObjectManagerNameChooser: class ObjectManagerNameChooser:
"""A name chooser for a Zope object manager. """A name chooser for a Zope object manager.
""" """
implements(INameChooser) implements(INameChooser)
def __init__(self, context): def __init__(self, context):
self.context = context self.context = context
...@@ -248,10 +248,10 @@ class ObjectManagerNameChooser: ...@@ -248,10 +248,10 @@ class ObjectManagerNameChooser:
i += 1 i += 1
try: try:
self.context._getOb(n) self.context._getOb(n)
except AttributeError: except (AttributeError, KeyError):
break break
n = name + '-' + str(i) + suffix n = name + '-' + str(i) + suffix
# Make sure the name is valid. We may have started with # Make sure the name is valid. We may have started with
# something bad. # something bad.
self.checkName(n, object) self.checkName(n, object)
......
...@@ -7,12 +7,18 @@ ObjectManagerNameChooser ...@@ -7,12 +7,18 @@ ObjectManagerNameChooser
First we need to import and setup some prerequisites: First we need to import and setup some prerequisites:
>>> from Products.BTreeFolder2.BTreeFolder2 import BTreeFolder2
>>> from Products.Five.tests.testing import manage_addFiveTraversableFolder >>> from Products.Five.tests.testing import manage_addFiveTraversableFolder
>>> from Products.Five.browser.adding import ObjectManagerNameChooser >>> from Products.Five.browser.adding import ObjectManagerNameChooser
>>> manage_addFiveTraversableFolder(self.folder, 'testoid', 'Testoid') >>> manage_addFiveTraversableFolder(self.folder, 'testoid', 'Testoid')
>>> chooser = ObjectManagerNameChooser(self.folder) >>> chooser = ObjectManagerNameChooser(self.folder)
>>> id = self.folder._setObject('btreefolder', BTreeFolder2('btreefolder'))
>>> btreefolder = self.folder[id]
>>> manage_addFiveTraversableFolder(btreefolder, 'testoid', 'Testoid')
>>> chooser2 = ObjectManagerNameChooser(btreefolder)
Now we can start. ``INameChooser`` defines a ``checkName()`` method Now we can start. ``INameChooser`` defines a ``checkName()`` method
that checks whether a given name is valid in the container or not. that checks whether a given name is valid in the container or not.
Under the hood, ``ObjectManagerNameChooser`` calls ``_checkId()`` of Under the hood, ``ObjectManagerNameChooser`` calls ``_checkId()`` of
...@@ -20,16 +26,25 @@ the object manager. Valid names/ids are those that aren't in use yet ...@@ -20,16 +26,25 @@ the object manager. Valid names/ids are those that aren't in use yet
and don't contain invalid characters. and don't contain invalid characters.
>>> chooser.checkName('abc', object()) >>> chooser.checkName('abc', object())
>>> chooser2.checkName('abc', object())
>>> chooser.checkName('testoid', object()) >>> chooser.checkName('testoid', object())
Traceback (most recent call last): Traceback (most recent call last):
... ...
UserError: The id "testoid" is invalid - it is already in use. UserError: The id "testoid" is invalid - it is already in use.
>>> chooser2.checkName('testoid', object())
Traceback (most recent call last):
...
UserError: The id "testoid" is invalid - it is already in use.
>>> chooser.checkName('slash/slash', object()) >>> chooser.checkName('slash/slash', object())
Traceback (most recent call last): Traceback (most recent call last):
... ...
UserError: The id "slash/slash" contains characters illegal in URLs. UserError: The id "slash/slash" contains characters illegal in URLs.
>>> chooser2.checkName('slash/slash', object())
Traceback (most recent call last):
...
UserError: The id "slash/slash" contains characters illegal in URLs.
``INameChooser`` also promises us a ``chooseName()`` method that ``INameChooser`` also promises us a ``chooseName()`` method that
chooses a name for us in case we don't have one or that chooses a chooses a name for us in case we don't have one or that chooses a
...@@ -37,12 +52,18 @@ different name in case the one we chose was invalid. ...@@ -37,12 +52,18 @@ different name in case the one we chose was invalid.
>>> chooser.chooseName('', self.folder.testoid) >>> chooser.chooseName('', self.folder.testoid)
'FiveTraversableFolder' 'FiveTraversableFolder'
>>> chooser2.chooseName('', self.folder.testoid)
'FiveTraversableFolder'
>>> chooser.chooseName('abc', self.folder.testoid) >>> chooser.chooseName('abc', self.folder.testoid)
'abc' 'abc'
>>> chooser2.chooseName('abc', self.folder.testoid)
'abc'
>>> chooser.chooseName('testoid', self.folder.testoid) >>> chooser.chooseName('testoid', self.folder.testoid)
'testoid-1' 'testoid-1'
>>> chooser2.chooseName('testoid', self.folder.testoid)
'testoid-1'
Of course, if we start out with something bad, it isn't going to Of course, if we start out with something bad, it isn't going to
become good automagically: become good automagically:
...@@ -51,3 +72,7 @@ become good automagically: ...@@ -51,3 +72,7 @@ become good automagically:
Traceback (most recent call last): Traceback (most recent call last):
... ...
UserError: The id "slash/slash" contains characters illegal in URLs. UserError: The id "slash/slash" contains characters illegal in URLs.
>>> chooser2.chooseName('slash/slash', object())
Traceback (most recent call last):
...
UserError: The id "slash/slash" contains characters illegal in URLs.
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