[Zope-Checkins] SVN: Zope/branches/2.12/ - LP #142750 and LP #142481: To prevent confusion when choosing an Id and
Jens Vagelpohl
jens at dataflake.org
Wed May 19 08:08:33 EDT 2010
Log message for revision 112530:
- LP #142750 and LP #142481: To prevent confusion when choosing an Id and
to avoid issues when creating two VirtualHostMonsters in the same
container the VirtualHostMoster now has a default Id. It can no longer
be selected, and the intermediary Add view is gone.
Changed:
U Zope/branches/2.12/doc/CHANGES.rst
U Zope/branches/2.12/src/Products/SiteAccess/VirtualHostMonster.py
U Zope/branches/2.12/src/Products/SiteAccess/tests/testVirtualHostMonster.py
D Zope/branches/2.12/src/Products/SiteAccess/www/VirtualHostMonsterAdd.dtml
-=-
Modified: Zope/branches/2.12/doc/CHANGES.rst
===================================================================
--- Zope/branches/2.12/doc/CHANGES.rst 2010-05-19 12:07:55 UTC (rev 112529)
+++ Zope/branches/2.12/doc/CHANGES.rst 2010-05-19 12:08:33 UTC (rev 112530)
@@ -14,6 +14,11 @@
- LP #142451: If non-recursive ownership changes are made using
``changeOwnership``, do not touch any children.
+- LP #142750 and LP #142481: To prevent confusion when choosing an Id and
+ to avoid issues when creating two VirtualHostMonsters in the same
+ container the VirtualHostMoster now has a default Id. It can no longer
+ be selected, and the intermediary Add view is gone.
+
Features Added
++++++++++++++
Modified: Zope/branches/2.12/src/Products/SiteAccess/VirtualHostMonster.py
===================================================================
--- Zope/branches/2.12/src/Products/SiteAccess/VirtualHostMonster.py 2010-05-19 12:07:55 UTC (rev 112529)
+++ Zope/branches/2.12/src/Products/SiteAccess/VirtualHostMonster.py 2010-05-19 12:08:33 UTC (rev 112530)
@@ -30,6 +30,7 @@
meta_type='Virtual Host Monster'
priority = 25
+ id = 'VHM'
title = ''
lines = ()
have_map = 0
@@ -255,17 +256,17 @@
InitializeClass(VirtualHostMonster)
-def manage_addVirtualHostMonster(self, id, REQUEST=None, **ignored):
+def manage_addVirtualHostMonster(self, REQUEST=None, **ignored):
""" """
+ container = self.this()
vhm = VirtualHostMonster()
- vhm.id = str(id)
- if REQUEST:
- return vhm.manage_addToContainer(self.this(),
- '%s/manage_main' % REQUEST['URL1'])
- else:
- vhm.addToContainer(self.this())
+ container._setObject(vhm.getId(), vhm)
+ if REQUEST is not None:
+ goto = '%s/manage_main' % self.absolute_url()
+ qs = 'manage_tabs_message=Virtual+Host+Monster+added.'
+ REQUEST['RESPONSE'].redirect('%s?%s' % (goto, qs))
+
constructors = (
- ('manage_addVirtualHostMonsterForm', DTMLFile('www/VirtualHostMonsterAdd', globals())),
('manage_addVirtualHostMonster', manage_addVirtualHostMonster),
)
Modified: Zope/branches/2.12/src/Products/SiteAccess/tests/testVirtualHostMonster.py
===================================================================
--- Zope/branches/2.12/src/Products/SiteAccess/tests/testVirtualHostMonster.py 2010-05-19 12:07:55 UTC (rev 112529)
+++ Zope/branches/2.12/src/Products/SiteAccess/tests/testVirtualHostMonster.py 2010-05-19 12:08:33 UTC (rev 112530)
@@ -111,9 +111,68 @@
setattr(VHMRegressions, 'testTraverse%s' % i, test)
+class VHMAddingTests(unittest.TestCase):
+
+ def setUp(self):
+ from OFS.Folder import Folder
+ super(VHMAddingTests, self).setUp()
+ self.root = Folder('root')
+
+ def _makeOne(self):
+ from Products.SiteAccess.VirtualHostMonster import VirtualHostMonster
+ return VirtualHostMonster()
+
+ def test_add_with_existing_vhm(self):
+ from Products.SiteAccess.VirtualHostMonster import \
+ manage_addVirtualHostMonster
+ from zExceptions import BadRequest
+ vhm1 = self._makeOne()
+ vhm1.manage_addToContainer(self.root)
+
+ vhm2 = self._makeOne()
+ self.assertRaises(BadRequest, vhm2.manage_addToContainer, self.root)
+ self.assertRaises( BadRequest
+ , manage_addVirtualHostMonster
+ , self.root
+ )
+
+ def test_add_id_collision(self):
+ from OFS.Folder import Folder
+ from Products.SiteAccess.VirtualHostMonster import \
+ manage_addVirtualHostMonster
+ from zExceptions import BadRequest
+ self.root._setObject('VHM', Folder('VHM'))
+ vhm1 = self._makeOne()
+
+ self.assertRaises(BadRequest, vhm1.manage_addToContainer, self.root)
+ self.assertRaises( BadRequest
+ , manage_addVirtualHostMonster
+ , self.root
+ )
+
+ def test_add_addToContainer(self):
+ from ZPublisher.BeforeTraverse import queryBeforeTraverse
+ vhm1 = self._makeOne()
+ vhm1.manage_addToContainer(self.root)
+
+ self.failUnless(vhm1.getId() in self.root.objectIds())
+ self.failUnless(queryBeforeTraverse(self.root, vhm1.meta_type))
+
+ def test_add_manage_addVirtualHostMonster(self):
+ from Products.SiteAccess.VirtualHostMonster import \
+ manage_addVirtualHostMonster
+ from Products.SiteAccess.VirtualHostMonster import VirtualHostMonster
+ from ZPublisher.BeforeTraverse import queryBeforeTraverse
+ manage_addVirtualHostMonster(self.root)
+
+ self.failUnless(VirtualHostMonster.id in self.root.objectIds())
+ hook = queryBeforeTraverse(self.root, VirtualHostMonster.meta_type)
+ self.failUnless(hook)
+
def test_suite():
suite = unittest.TestSuite()
suite.addTest(unittest.makeSuite(VHMRegressions))
+ suite.addTest(unittest.makeSuite(VHMAddingTests))
return suite
if __name__ == '__main__':
Deleted: Zope/branches/2.12/src/Products/SiteAccess/www/VirtualHostMonsterAdd.dtml
===================================================================
--- Zope/branches/2.12/src/Products/SiteAccess/www/VirtualHostMonsterAdd.dtml 2010-05-19 12:07:55 UTC (rev 112529)
+++ Zope/branches/2.12/src/Products/SiteAccess/www/VirtualHostMonsterAdd.dtml 2010-05-19 12:08:33 UTC (rev 112530)
@@ -1,61 +0,0 @@
-<dtml-var manage_page_header>
-
-<dtml-let form_title="'Add Virtual Host Monster'">
- <dtml-var manage_form_title>
-</dtml-let>
-
-<p class="form-help">
-A Virtual Host Monster changes the URLs generated by all objects
-within the same Folder, using information passed to it in special URL
-path elements. This is useful if you are using some rewriting tool
-(Apache or an Access Rule, for example) to insert these special
-elements into your URL.
-</p>
-
-<p class="form-help">
-To set the protocol ('http', 'https') and host ('www.foo.com') portion
-of generated URLs, insert "VirtualHostBase", the protocol,
-and the host into the path.
-</p>
-
-<p class="form-help">
-Insert "VirtualHostRoot" directly after the name of the
-Folder that is supposed to be the root of the virtual host.<br><br>
-For example, to publish Folder "/foo" as <b>http://www.foo.com/</b>,
-put a Virtual Host Monster in the root folder and rewrite requests for that
-URL to <b>/VirtualHostBase/http/www.foo.com/foo/VirtualHostRoot/</b>
-</p>
-
-<p class="form-help">
-Values affected include DTML variables starting with URL or BASE, and
-the absolute_url() methods of objects.
-</p>
-
-
-<form action="manage_addVirtualHostMonster" method="post">
-<table cellspacing="0" cellpadding="2" border="0">
- <tr>
- <td align="left" valign="top">
- <div class="form-label">
- Id
- </div>
- </td>
- <td align="left" valign="top">
- <input type="text" name="id" size="40" />
- </td>
- </tr>
- <tr>
- <td align="left" valign="top">
- </td>
- <td align="left" valign="top">
- <div class="form-element">
- <input class="form-element" type="submit" name="submit"
- value=" Add " />
- </div>
- </td>
- </tr>
-</table>
-</form>
-
-<dtml-var manage_page_footer>
-
More information about the Zope-Checkins
mailing list