Skip to content

Commit

Permalink
Replace 'import doctest' with 'from zope.testing import doctest'.
Browse files Browse the repository at this point in the history
  • Loading branch information
baijum committed Jul 20, 2006
0 parents commit 728f4d8
Showing 1 changed file with 92 additions and 0 deletions.
92 changes: 92 additions & 0 deletions tests.py
@@ -0,0 +1,92 @@
##############################################################################
#
# Copyright (c) 2001, 2002 Zope Corporation 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.
#
##############################################################################
"""Principal Annotation Tests
$Id$
"""
from zope.testing import doctest
from unittest import TestCase, TestLoader, TextTestRunner

import zope.component
from zope.interface import implements
from zope.annotation.interfaces import IAnnotations
from zope.security.interfaces import IPrincipal

from zope.app.principalannotation import PrincipalAnnotationUtility
from zope.app.component.testing import PlacefulSetup
from zope.app.testing import setup
from zope.app.principalannotation.interfaces import IPrincipalAnnotationUtility

class Principal(object):
implements(IPrincipal)

def __init__(self, id):
self.id = id


class PrincipalAnnotationTests(PlacefulSetup, TestCase):

def setUp(self):
PlacefulSetup.setUp(self)
sm = self.buildFolders(site='/')
self.util = PrincipalAnnotationUtility()
zope.component.provideUtility(self.util, IPrincipalAnnotationUtility)

def testGetSimple(self):
prince = Principal('somebody')
self.assert_(not self.util.hasAnnotations(prince))

princeAnnotation = self.util.getAnnotations(prince)
# Just getting doesn't actualy store. We don't want to store unless
# we make a change.
self.assert_(not self.util.hasAnnotations(prince))

princeAnnotation['something'] = 'whatever'

# But now we should have the annotation:
self.assert_(self.util.hasAnnotations(prince))

def testGetFromLayered(self):
princeSomebody = Principal('somebody')
sm1 = self.makeSite('folder1')
subUtil = setup.addUtility(sm1, '', IPrincipalAnnotationUtility,
PrincipalAnnotationUtility())

parentAnnotation = self.util.getAnnotations(princeSomebody)

# Just getting doesn't actualy store. We don't want to store unless
# we make a change.
self.assert_(not subUtil.hasAnnotations(princeSomebody))

parentAnnotation['hair_color'] = 'blue'

# But now we should have the annotation:
self.assert_(self.util.hasAnnotations(princeSomebody))

subAnnotation = subUtil.getAnnotations(princeSomebody)
self.assertEquals(subAnnotation['hair_color'], 'blue')

subAnnotation['foo'] = 'bar'

self.assertEquals(parentAnnotation.get("foo"), None)

def test_suite():
loader=TestLoader()
tests = loader.loadTestsFromTestCase(PrincipalAnnotationTests)
import zope.app.principalannotation
tests.addTest(doctest.DocTestSuite(zope.app.principalannotation))
return tests

if __name__=='__main__':
TextTestRunner().run(test_suite())

0 comments on commit 728f4d8

Please sign in to comment.