[Zope3-checkins] CVS: Zope3/src/zope/app/apidoc/classmodule -
ftests.py:1.1 tests.py:1.1
Stephan Richter
srichter at cosmos.phy.tufts.edu
Sun Mar 28 18:40:13 EST 2004
Update of /cvs-repository/Zope3/src/zope/app/apidoc/classmodule
In directory cvs.zope.org:/tmp/cvs-serv22484/src/zope/app/apidoc/classmodule
Added Files:
ftests.py tests.py
Log Message:
Added tests.
=== Added File Zope3/src/zope/app/apidoc/classmodule/ftests.py ===
##############################################################################
#
# Copyright (c) 2003, 2004 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (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.
#
##############################################################################
"""Functional Tests for Class Documentation Module.
$Id: ftests.py,v 1.1 2004/03/28 23:40:12 srichter Exp $
"""
import unittest
from zope.testing.functional import BrowserTestCase
class ClassModuleTests(BrowserTestCase):
"""Just a couple of tests ensuring that the templates render."""
def testMenu(self):
response = self.publish('/++apidoc++/Class/menu.html',
basic='mgr:mgrpw')
self.assertEqual(response.getStatus(), 200)
body = response.getBody()
self.assert_(body.find('Browse Zope Source') > 0)
self.checkForBrokenLinks(body, '/++apidoc++/Class/menu.html',
basic='mgr:mgrpw')
def testMenuClassFinder(self):
response = self.publish('/++apidoc++/Class/menu.html',
basic='mgr:mgrpw',
form={'path': 'Class', 'SUBMIT': 'Find'})
self.assertEqual(response.getStatus(), 200)
body = response.getBody()
self.assert_(body.find('zope.app.apidoc.classmodule.ClassModule') > 0)
self.checkForBrokenLinks(body, '/++apidoc++/Class/menu.html',
basic='mgr:mgrpw')
def testModuleDetailsView(self):
response = self.publish('/++apidoc++/Class/zope/app/apidoc/',
basic='mgr:mgrpw')
self.assertEqual(response.getStatus(), 200)
body = response.getBody()
self.assert_(body.find('Zope 3 API Documentation') > 0)
self.checkForBrokenLinks(body, '/++apidoc++/Class/zope/app/apidoc/',
basic='mgr:mgrpw')
def testClassDetailsView(self):
response = self.publish(
'/++apidoc++/Class/zope/app/apidoc/APIDocumentation',
basic='mgr:mgrpw')
self.assertEqual(response.getStatus(), 200)
body = response.getBody()
self.assert_(body.find('Represent the complete API Documentation.') > 0)
self.checkForBrokenLinks(
body, '/++apidoc++/Class/zope/app/apidoc/APIDocumentation',
basic='mgr:mgrpw')
def test_suite():
return unittest.TestSuite((
unittest.makeSuite(ClassModuleTests),
))
if __name__ == '__main__':
unittest.main(defaultTest='test_suite')
=== Added File Zope3/src/zope/app/apidoc/classmodule/tests.py ===
##############################################################################
#
# Copyright (c) 2004 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (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.
#
##############################################################################
"""Tests for the Class Documentation Module
$Id: tests.py,v 1.1 2004/03/28 23:40:12 srichter Exp $
"""
import unittest
from zope.interface import Interface, directlyProvides
from zope.publisher.browser import TestRequest
from zope.testing.doctestunit import DocTestSuite
from zope.app import zapi
from zope.app.tests import ztapi
from zope.app.tests.placelesssetup import setUp, tearDown
from zope.app.traversing.browser import AbsoluteURL, SiteAbsoluteURL
from zope.app.traversing.interfaces import ITraversable, ITraverser
from zope.app.traversing.interfaces import IPhysicallyLocatable
from zope.app.traversing.interfaces import IContainmentRoot
from zope.app.traversing.adapters import DefaultTraversable
from zope.app.location import LocationPhysicallyLocatable
from zope.app.traversing.adapters import RootPhysicallyLocatable
from zope.app.traversing.adapters import Traverser
from zope.app.apidoc.classmodule import ClassModule
from zope.app.apidoc.classmodule.browser import ClassDetails, ModuleDetails
from zope.app.apidoc.interfaces import IDocumentationModule
def browserSetUp():
setUp()
module = ClassModule()
module.__name__ = ''
directlyProvides(module, IContainmentRoot)
ztapi.provideUtility(IDocumentationModule, module, "Class")
ztapi.provideAdapter(
None, ITraverser, Traverser)
ztapi.provideAdapter(
None, ITraversable, DefaultTraversable)
ztapi.provideAdapter(
None, IPhysicallyLocatable, LocationPhysicallyLocatable)
ztapi.provideAdapter(
IContainmentRoot, IPhysicallyLocatable, RootPhysicallyLocatable)
ztapi.browserView(Interface, "absolute_url", AbsoluteURL)
ztapi.browserView(IContainmentRoot, "absolute_url", SiteAbsoluteURL)
def browserTearDown():
tearDown()
def getClassDetailsView():
cm = zapi.getUtility(None, IDocumentationModule, 'Class')
view = ClassDetails()
view.context = zapi.traverse(cm, 'zope/app/apidoc/classmodule/ClassModule')
view.request = TestRequest()
return view
def getModuleDetailsView():
cm = zapi.getUtility(None, IDocumentationModule, 'Class')
view = ModuleDetails()
view.context = zapi.traverse(cm, 'zope/app/apidoc/classmodule')
view.request = TestRequest()
return view
def test_suite():
return unittest.TestSuite((
DocTestSuite('zope.app.apidoc.classmodule.browser',
setUp=browserSetUp, tearDown=browserTearDown),
DocTestSuite('zope.app.apidoc.classmodule'),
))
if __name__ == '__main__':
unittest.main()
More information about the Zope3-Checkins
mailing list