Commit 47b8ebdc authored by Chris McDonough's avatar Chris McDonough

Stresstest now calls values on TOC.

parent 8ac97850
......@@ -18,36 +18,47 @@ from Testing import makerequest
import ZODB # in order to get Persistence.Persistent working
import Acquisition
from Acquisition import aq_base
from Products.Sessions.BrowserIdManager import BrowserIdManager, getNewBrowserId
from Products.Sessions.BrowserIdManager import BrowserIdManager, \
getNewBrowserId
from Products.Sessions.SessionDataManager import \
SessionDataManager, SessionDataManagerErr
from Products.Transience.Transience import \
TransientObjectContainer, TransientObject
from Products.TemporaryFolder.TemporaryFolder import MountedTemporaryFolder
from Products.TemporaryFolder.LowConflictConnection import LowConflictConnection
from Products.TemporaryFolder.LowConflictConnection import \
LowConflictConnection
from ZODB.Connection import Connection
from ZODB.POSException import InvalidObjectReference, ConflictError, ReadConflictError, BTreesConflictError
from ZODB.POSException import InvalidObjectReference, ConflictError, \
ReadConflictError, BTreesConflictError
from DateTime import DateTime
from unittest import TestCase, TestSuite, TextTestRunner, makeSuite
import time, threading, random
from cPickle import UnpickleableError
from ZODB.DemoStorage import DemoStorage
from Products.TemporaryFolder.TemporaryStorage import TemporaryStorage
from OFS.Application import Application
import sys
from zLOG import log_time
sys.setcheckinterval(200)
import fauxtime
import Products.Transience.Transience
import Products.Transience.TransientObject
Products.Transience.Transience.time = fauxtime
Products.Transience.TransientObject.time = fauxtime
tf_name = 'temp_folder'
idmgr_name = 'browser_id_manager'
toc_name = 'temp_transient_container'
sdm_name = 'session_data_manager'
stuff = {}
def _getDB():
db = stuff.get('db')
if not db:
ds = DemoStorage(quota=(1<<20))
db = ZODB.DB(ds, pool_size=60)
ds = DemoStorage()
db = ZODB.DB(ds)
conn = db.open()
root = conn.root()
app = Application()
......@@ -69,7 +80,7 @@ def _populate(app):
tf = MountedTemporaryFolder(tf_name, title="Temporary Folder")
toc = TransientObjectContainer(toc_name, title='Temporary '
'Transient Object Container', timeout_mins=1)
session_data_manager=SessionDataManager(id='session_data_manager',
session_data_manager=SessionDataManager(id=sdm_name,
path='/'+tf_name+'/'+toc_name, title='Session Data Manager')
try: app._delObject(idmgr_name)
......@@ -78,12 +89,12 @@ def _populate(app):
try: app._delObject(tf_name)
except AttributeError: pass
try: app._delObject('session_data_manager')
try: app._delObject(sdm_name)
except AttributeError: pass
app._setObject(idmgr_name, bidmgr)
app._setObject('session_data_manager', session_data_manager)
app._setObject(sdm_name, session_data_manager)
app._setObject(tf_name, tf)
get_transaction().commit()
......@@ -93,47 +104,32 @@ def _populate(app):
class TestMultiThread(TestCase):
def testOverlappingBrowserIds(self):
readers = []
writers = []
readiters = 20
writeiters = 5
readout = []
writeout = []
numreaders = 20
numwriters = 5
sdm_name = 'session_data_manager'
db = _getDB()
for i in range(numreaders):
thread = ReaderThread(db, readiters, sdm_name)
readers.append(thread)
for i in range(numwriters):
thread = WriterThread(db, writeiters, sdm_name)
writers.append(thread)
for thread in readers:
thread.start()
time.sleep(0.1)
for thread in writers:
thread.start()
time.sleep(0.1)
while threading.activeCount() > 1:
time.sleep(1)
token = getNewBrowserId()
self.go(token)
def testNonOverlappingBrowserIds(self):
token = None
self.go(token)
def go(self, token):
readers = []
writers = []
readiters = 20
writeiters = 5
readiters = 100
writeiters = 100
readout = []
writeout = []
numreaders = 20
numwriters = 5
sdm_name = 'session_data_manager'
numreaders = 4
numwriters = 2
numvaluers = 1
db = _getDB()
for i in range(numreaders):
thread = ReaderThread(db, readiters, sdm_name)
thread = ReaderThread(db, readiters, token)
readers.append(thread)
for i in range(numvaluers):
thread = ValuesGetterThread(db, readiters, token)
readers.append(thread)
for i in range(numwriters):
thread = WriterThread(db, writeiters, sdm_name)
thread = WriterThread(db, writeiters, token)
writers.append(thread)
for thread in readers:
thread.start()
......@@ -141,14 +137,18 @@ class TestMultiThread(TestCase):
for thread in writers:
thread.start()
time.sleep(0.1)
while threading.activeCount() > 1:
active = 2
while active > 1:
active = threading.activeCount()
print 'waiting for %s threads' % active
time.sleep(1)
class BaseReaderWriter(threading.Thread):
def __init__(self, db, iters, sdm_name):
def __init__(self, db, iters, token=None):
self.conn = db.open()
self.app = self.conn.root()['Application']
self.app = makerequest.makerequest(self.app)
if token is None:
token = getNewBrowserId()
self.app.REQUEST.browser_id_ = token
self.iters = iters
......@@ -208,6 +208,20 @@ class WriterThread(BaseReaderWriter):
else:
get_transaction().abort()
class ValuesGetterThread(BaseReaderWriter):
def run1(self):
tf = getattr(self.app, tf_name)
toc = getattr(tf, toc_name)
for i in range(self.iters):
print '%s values in toc' % len(toc.values())
n = random.choice(range(3))
time.sleep(n)
if n % 2 == 0:
get_transaction().commit()
else:
get_transaction().abort()
def test_suite():
test_multithread = makeSuite(TestMultiThread, 'test')
suite = TestSuite((test_multithread,))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment