[Zope-Checkins] SVN: Zope/trunk/ - reverted r122056 and merged test improvements from 2.13 branch
Yvo Schubbe
y.2011 at wcm-solutions.de
Thu Feb 16 10:57:44 UTC 2012
Log message for revision 124417:
- reverted r122056 and merged test improvements from 2.13 branch
(see https://mail.zope.org/pipermail/zope-dev/2011-November/043733.html)
Changed:
U Zope/trunk/doc/CHANGES.rst
UU Zope/trunk/src/Products/Five/browser/tests/pages.py
A Zope/trunk/src/Products/Five/browser/tests/skin.py
A Zope/trunk/src/Products/Five/browser/tests/skin.txt
A Zope/trunk/src/Products/Five/browser/tests/skin.zcml
A Zope/trunk/src/Products/Five/browser/tests/test_skin.py
U Zope/trunk/src/Zope2/App/traversing.zcml
-=-
Modified: Zope/trunk/doc/CHANGES.rst
===================================================================
--- Zope/trunk/doc/CHANGES.rst 2012-02-16 10:33:21 UTC (rev 124416)
+++ Zope/trunk/doc/CHANGES.rst 2012-02-16 10:57:43 UTC (rev 124417)
@@ -136,15 +136,6 @@
`lib/python` and `Products` from the default. You can continue to manually
add these back.
-- Removed the rarely used support for the `++skin++` traverser. You can enable
- it in your own applications by defining::
-
- <adapter
- name="skin"
- for="* zope.publisher.interfaces.IRequest"
- provides="zope.traversing.interfaces.ITraversable"
- factory="zope.traversing.namespace.skin" />
-
- Five.browser: Marked `processInputs` and `setPageEncoding` as deprecated.
`processInputs` was replaced by the `postProcessInputs` request method and
the charset negotiation done by `setPageEncoding` was never fully supported.
Modified: Zope/trunk/src/Products/Five/browser/tests/pages.py
===================================================================
--- Zope/trunk/src/Products/Five/browser/tests/pages.py 2012-02-16 10:33:21 UTC (rev 124416)
+++ Zope/trunk/src/Products/Five/browser/tests/pages.py 2012-02-16 10:57:43 UTC (rev 124417)
@@ -18,45 +18,59 @@
from Products.Five.browser.pagetemplatefile import ViewPageTemplateFile
from OFS.SimpleItem import SimpleItem
+
class SimpleView(BrowserView):
+
"""More docstring. Please Zope"""
def eagle(self):
"""Docstring"""
return u"The eagle has landed"
+ def eagle2(self):
+ """Docstring"""
+ return u"The eagle has landed:\n%s" % self.context.absolute_url()
+
def mouse(self):
"""Docstring"""
return u"The mouse has been eaten by the eagle"
+
class FancyView(BrowserView):
+
"""Fancy, fancy stuff"""
def view(self):
return u"Fancy, fancy"
+
class CallView(BrowserView):
def __call__(self):
return u"I was __call__()'ed"
+
class PermissionView(BrowserView, SimpleItem):
-
+
def __call__(self):
return u"I was __call__()'ed"
+
class CallTemplate(BrowserView):
__call__ = ViewPageTemplateFile('falcon.pt')
+
class CallableNoDocstring:
def __call__(self):
return u"No docstring"
+
def function_no_docstring(self):
return u"No docstring"
+
class NoDocstringView(BrowserView):
def method(self):
@@ -66,7 +80,9 @@
object = CallableNoDocstring()
+
class NewStyleClass(object):
+
"""
This is a testclass to verify that new style classes work
in browser:page
Property changes on: Zope/trunk/src/Products/Five/browser/tests/pages.py
___________________________________________________________________
Deleted: svn:keywords
- Id
Copied: Zope/trunk/src/Products/Five/browser/tests/skin.py (from rev 124416, Zope/branches/2.13/src/Products/Five/browser/tests/skin.py)
===================================================================
--- Zope/trunk/src/Products/Five/browser/tests/skin.py (rev 0)
+++ Zope/trunk/src/Products/Five/browser/tests/skin.py 2012-02-16 10:57:43 UTC (rev 124417)
@@ -0,0 +1,20 @@
+##############################################################################
+#
+# Copyright (c) 2006 Zope Foundation and Contributors.
+# All Rights Reserved.
+#
+# This software is subject to the provisions of the Zope Public License,
+# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
+# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
+# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
+# FOR A PARTICULAR PURPOSE.
+#
+##############################################################################
+"""Test skins
+"""
+
+from zope.publisher.interfaces.browser import IDefaultBrowserLayer
+
+class ITestSkin(IDefaultBrowserLayer):
+ pass
Property changes on: Zope/trunk/src/Products/Five/browser/tests/skin.py
___________________________________________________________________
Added: svn:eol-style
+ native
Copied: Zope/trunk/src/Products/Five/browser/tests/skin.txt (from rev 124416, Zope/branches/2.13/src/Products/Five/browser/tests/skin.txt)
===================================================================
--- Zope/trunk/src/Products/Five/browser/tests/skin.txt (rev 0)
+++ Zope/trunk/src/Products/Five/browser/tests/skin.txt 2012-02-16 10:57:43 UTC (rev 124417)
@@ -0,0 +1,56 @@
+Test layer and skin support
+===========================
+
+Let's register a test layer and test skin:
+
+ >>> import Products.Five.browser.tests
+ >>> from Zope2.App import zcml
+ >>> zcml.load_config("configure.zcml", Products.Five)
+ >>> zcml.load_config("skin.zcml", package=Products.Five.browser.tests)
+
+Let's add a test object that we'll access the test page from:
+
+ >>> from Products.Five.tests.testing.simplecontent import manage_addSimpleContent
+ >>> manage_addSimpleContent(self.folder, 'testoid', 'Testoid')
+
+The view was registered on a different layer than 'default', that's
+why we can't access it straight away:
+
+ >>> print http(r"""
+ ... GET /test_folder_1_/testoid/eagle.html HTTP/1.1
+ ... """)
+ HTTP/1.1 404 Not Found
+ ...
+
+It works when we explicitly use the skin that includes that layer:
+
+ >>> print http(r"""
+ ... GET /++skin++TestSkin/test_folder_1_/testoid/eagle.html HTTP/1.1
+ ... """)
+ HTTP/1.1 200 OK
+ ...
+ The eagle has landed:
+ http://localhost/++skin++TestSkin/test_folder_1_/testoid
+
+Or when we make that skin the default skin:
+
+ >>> zcml.load_string('''
+ ... <browser:defaultSkin
+ ... xmlns:browser="http://namespaces.zope.org/browser"
+ ... name="TestSkin" />
+ ... ''')
+
+ >>> print http(r"""
+ ... GET /test_folder_1_/testoid/eagle.html HTTP/1.1
+ ... """)
+ HTTP/1.1 200 OK
+ ...
+ The eagle has landed:
+ http://localhost/test_folder_1_/testoid
+
+
+Clean up
+--------
+
+ >>> from zope.component.testing import tearDown
+ >>> tearDown()
Copied: Zope/trunk/src/Products/Five/browser/tests/skin.zcml (from rev 124416, Zope/branches/2.13/src/Products/Five/browser/tests/skin.zcml)
===================================================================
--- Zope/trunk/src/Products/Five/browser/tests/skin.zcml (rev 0)
+++ Zope/trunk/src/Products/Five/browser/tests/skin.zcml 2012-02-16 10:57:43 UTC (rev 124417)
@@ -0,0 +1,23 @@
+<configure xmlns="http://namespaces.zope.org/zope"
+ xmlns:meta="http://namespaces.zope.org/meta"
+ xmlns:browser="http://namespaces.zope.org/browser">
+
+ <!-- make the zope2.Public permission work -->
+ <meta:redefinePermission from="zope2.Public" to="zope.Public" />
+
+ <interface
+ interface=".skin.ITestSkin"
+ type="zope.publisher.interfaces.browser.IBrowserSkinType"
+ name="TestSkin"
+ />
+
+ <browser:page
+ for="Products.Five.tests.testing.simplecontent.ISimpleContent"
+ class=".pages.SimpleView"
+ attribute="eagle2"
+ name="eagle.html"
+ permission="zope2.Public"
+ layer=".skin.ITestSkin"
+ />
+
+</configure>
Copied: Zope/trunk/src/Products/Five/browser/tests/test_skin.py (from rev 124416, Zope/branches/2.13/src/Products/Five/browser/tests/test_skin.py)
===================================================================
--- Zope/trunk/src/Products/Five/browser/tests/test_skin.py (rev 0)
+++ Zope/trunk/src/Products/Five/browser/tests/test_skin.py 2012-02-16 10:57:43 UTC (rev 124417)
@@ -0,0 +1,20 @@
+##############################################################################
+#
+# Copyright (c) 2005 Zope Foundation and Contributors.
+# All Rights Reserved.
+#
+# This software is subject to the provisions of the Zope Public License,
+# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
+# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
+# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
+# FOR A PARTICULAR PURPOSE.
+#
+##############################################################################
+"""Test browser pages
+"""
+
+def test_suite():
+ from Testing.ZopeTestCase import FunctionalDocFileSuite
+ return FunctionalDocFileSuite('skin.txt',
+ package='Products.Five.browser.tests')
Property changes on: Zope/trunk/src/Products/Five/browser/tests/test_skin.py
___________________________________________________________________
Added: svn:eol-style
+ native
Modified: Zope/trunk/src/Zope2/App/traversing.zcml
===================================================================
--- Zope/trunk/src/Zope2/App/traversing.zcml 2012-02-16 10:33:21 UTC (rev 124416)
+++ Zope/trunk/src/Zope2/App/traversing.zcml 2012-02-16 10:57:43 UTC (rev 124417)
@@ -38,6 +38,13 @@
/>
<adapter
+ name="skin"
+ for="* zope.publisher.interfaces.IRequest"
+ provides="zope.traversing.interfaces.ITraversable"
+ factory="zope.traversing.namespace.skin"
+ />
+
+ <adapter
name="resource"
for="* zope.publisher.interfaces.IRequest"
provides="zope.traversing.interfaces.ITraversable"
More information about the Zope-Checkins
mailing list