############################################################################## # # Copyright (c) 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 # ############################################################################## import sys, os, unittest import ZODB from Products.Transience.Transience import TransientObjectContainer from Products.Transience.TransientObject import TransientObject import Products.Transience.TransientObject import Products.Transience.Transience from unittest import TestCase, TestSuite, TextTestRunner, makeSuite import time as oldtime import fauxtime class TestTransientObject(TestCase): def setUp(self): Products.Transience.Transience.time = fauxtime Products.Transience.TransientObject.time = fauxtime Products.Transience.Transience.setStrict(1) self.errmargin = .20 self.timeout = 60 self.t = TransientObjectContainer('sdc', timeout_mins=self.timeout/60) def tearDown(self): Products.Transience.Transience.time = oldtime Products.Transience.TransientObject.time = oldtime Products.Transience.Transience.setStrict(0) self.t = None del self.t def test_id(self): t = self.t.new('xyzzy') self.failIfEqual(t.getId(), 'xyzzy') # dont acquire self.assertEqual(t.getContainerKey(), 'xyzzy') def test_validate(self): t = self.t.new('xyzzy') self.assert_(t.isValid()) t.invalidate() self.failIf(t.isValid()) def test_getLastAccessed(self): t = self.t.new('xyzzy') ft = fauxtime.time() self.assert_(t.getLastAccessed() <= ft) def test_getCreated(self): t = self.t.new('xyzzy') ft = fauxtime.time() self.assert_(t.getCreated() <= ft) def test_getLastModifiedUnset(self): t = self.t.new('xyzzy') self.assertEqual(t.getLastModified(), None) def test_getLastModifiedSet(self): t = self.t.new('xyzzy') t['a'] = 1 self.failIfEqual(t.getLastModified(), None) def testSetLastModified(self): t = self.t.new('xyzzy') ft = fauxtime.time() t.setLastModified() self.failIfEqual(t.getLastModified(), None) def test_setLastAccessed(self): t = self.t.new('xyzzy') ft = fauxtime.time() self.assert_(t.getLastAccessed() <= ft) fauxtime.sleep(self.timeout) # go to sleep past the granuarity ft2 = fauxtime.time() t.setLastAccessed() ft3 = fauxtime.time() self.assert_(t.getLastAccessed() <= ft3) self.assert_(t.getLastAccessed() >= ft2) def _genKeyError(self, t): return t.get('foobie') def _genLenError(self, t): return t.len() def test_dictionaryLike(self): t = self.t.new('keytest') t.update(data) self.assertEqual(t.keys(), data.keys()) self.assertEqual(t.values(), data.values()) self.assertEqual(t.items(), data.items()) for k in data.keys(): self.assertEqual(t.get(k), data.get(k)) self.assertEqual(t.get('foobie'), None) self.assertRaises(AttributeError, self._genLenError, t) self.assertEqual(t.get('foobie',None), None) self.assert_(t.has_key('a')) self.failIf(t.has_key('foobie')) t.clear() self.assertEqual(len(t.keys()), 0) def test_TTWDictionary(self): t = self.t.new('mouthfultest') t.set('foo', 'bar') self.assertEqual(t['foo'], 'bar') self.assertEqual(t.get('foo'), 'bar') t.set('foobie', 'blech') t.delete('foobie') self.assertEqual(t.get('foobie'), None) def test_repr_leaking_information(self): # __repr__ used to show all contents, which could lead to sensitive # information being visible in e.g. the ErrorLog object. t = self.t.new('password-storing-session') t.set('__ac_password__', 'secret') self.failIf( repr(t).find('secret') != -1 , '__repr__ leaks: %s' % repr(t) ) def test_suite(): testsuite = makeSuite(TestTransientObject, 'test') alltests = TestSuite((testsuite,)) return alltests data = { 'a': 'a', 1: 1, 'Mary': 'no little lamb for you today!', 'epoch': 999999999, 'fauxtime': fauxtime } if __name__ == '__main__': runner = TextTestRunner(verbosity=9) runner.run(test_suite())