Commit 7374a625 authored by Chris McDonough's avatar Chris McDonough

Make output a little more informative and emulate Zope better by opening

and closing a connection between each request.
parent f41ed0b5
...@@ -116,10 +116,10 @@ class TestMultiThread(TestCase): ...@@ -116,10 +116,10 @@ class TestMultiThread(TestCase):
def go(self, token): def go(self, token):
readers = [] readers = []
writers = [] writers = []
valuers = []
readiters = 3 readiters = 3
writeiters = 3 writeiters = 3
readout = [] valueiters = 3
writeout = []
numreaders = 2 numreaders = 2
numwriters = 4 numwriters = 4
numvaluers = 1 numvaluers = 1
...@@ -128,8 +128,8 @@ class TestMultiThread(TestCase): ...@@ -128,8 +128,8 @@ class TestMultiThread(TestCase):
thread = ReaderThread(db, readiters, token) thread = ReaderThread(db, readiters, token)
readers.append(thread) readers.append(thread)
for i in range(numvaluers): for i in range(numvaluers):
thread = ValuesGetterThread(db, readiters, token) thread = ValuesGetterThread(db, valueiters, token)
readers.append(thread) valuers.append(thread)
for i in range(numwriters): for i in range(numwriters):
thread = WriterThread(db, writeiters, token) thread = WriterThread(db, writeiters, token)
writers.append(thread) writers.append(thread)
...@@ -139,32 +139,52 @@ class TestMultiThread(TestCase): ...@@ -139,32 +139,52 @@ class TestMultiThread(TestCase):
for thread in writers: for thread in writers:
thread.start() thread.start()
time.sleep(0.1) time.sleep(0.1)
for thread in valuers:
thread.start()
time.sleep(0.1)
active = threading.activeCount() active = threading.activeCount()
while active > 1: while active > 0:
active = threading.activeCount() active = threading.activeCount()-1
print 'waiting for %s threads' % active print 'waiting for %s threads' % active
print "readers: ", numActive(readers),
print "writers: ", numActive(writers),
print "valuers: ", numActive(valuers)
time.sleep(5) time.sleep(5)
def numActive(threads):
i = 0
for thread in threads:
if not thread.isFinished():
i+=1
return i
class BaseReaderWriter(threading.Thread): class BaseReaderWriter(threading.Thread):
def __init__(self, db, iters, token=None): 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 self.iters = iters
self.sdm_name = sdm_name self.sdm_name = sdm_name
self.finished = 0
self.db = db
self.token = token
threading.Thread.__init__(self) threading.Thread.__init__(self)
def run(self): def run(self):
i = 0 i = 0
try: try:
while 1: while 1:
self.conn = self.db.open()
self.app = self.conn.root()['Application']
self.app = makerequest.makerequest(self.app)
if self.token is None:
token = getNewBrowserId()
else:
token = self.token
self.app.REQUEST.browser_id_ = token
try: try:
self.run1() self.run1()
return return
except ReadConflictError: except ReadConflictError:
#traceback.print_exc()
print "R", print "R",
except BTreesConflictError: except BTreesConflictError:
print "B", print "B",
...@@ -178,13 +198,19 @@ class BaseReaderWriter(threading.Thread): ...@@ -178,13 +198,19 @@ class BaseReaderWriter(threading.Thread):
i = i + 1 i = i + 1
get_transaction().abort() get_transaction().abort()
self.conn.sync() self.conn.close()
time.sleep(random.randrange(5) * .1) time.sleep(random.randrange(10) * .1)
finally: finally:
get_transaction().abort()
self.conn.close() self.conn.close()
del self.app del self.app
self.finished = 1
print '%s finished' % self.__class__ print '%s finished' % self.__class__
def isFinished(self):
return self.finished
class ReaderThread(BaseReaderWriter): class ReaderThread(BaseReaderWriter):
def run1(self): def run1(self):
session_data_manager = getattr(self.app, self.sdm_name) session_data_manager = getattr(self.app, self.sdm_name)
......
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