[Zope-Checkins] CVS: Zope/lib/python/Products/ZCatalog/regressiontests - loadmail.py:1.10
Barry Warsaw
barry@wooz.org
Tue, 12 Nov 2002 11:10:14 -0500
Update of /cvs-repository/Zope/lib/python/Products/ZCatalog/regressiontests
In directory cvs.zope.org:/tmp/cvs-serv17513
Modified Files:
loadmail.py
Log Message:
Committing some old changes.
New `catdel' command which deletes the entire catalog in one
transaction.
Add a new global VERBOSE flag instead of passing around the printstat
argument everywhere. This also lets us use getopt for proper option
parsing, and add a -v/--verbose flag for setting that global.
Added a usage() function.
=== Zope/lib/python/Products/ZCatalog/regressiontests/loadmail.py 1.9 => 1.10 ===
--- Zope/lib/python/Products/ZCatalog/regressiontests/loadmail.py:1.9 Wed Sep 11 15:49:45 2002
+++ Zope/lib/python/Products/ZCatalog/regressiontests/loadmail.py Tue Nov 12 11:10:13 2002
@@ -90,6 +90,11 @@
as described above.
+ catdel
+
+ Delete the entire catalog in one transaction. This is a fun one for
+ storages that do reference counting garbage collection.
+
pdebug command args
Run one of the other commands in the Python debugger.
@@ -102,10 +107,12 @@
python Products/ZCatalog/regressiontests/loadmail.py \
inc ~/python-dev.mbox 0 10 2
python Products/ZCatalog/regressiontests/loadmail.py edit 10 10 10 2
+ python Products/ZCatalog/regressiontests/loadmail.py catdel
"""
+import getopt
import mailbox, time, sys, os, string
sys.path.insert(0, '.')
@@ -115,6 +122,8 @@
from string import strip, find, split, lower, atoi
from urllib import quote
+VERBOSE = 0
+
def do(db, f, args, returnf=None):
"""Do something and measure it's impact"""
t = c = size = mem = r = None
@@ -159,7 +168,7 @@
try: doc.manage_addProperty(name, v, type)
except: pass
-def loadmail(dest, name, mbox, printstat=0, max=-1):
+def loadmail(dest, name, mbox, max=-1):
try:
import Products.BTreeFolder.BTreeFolder
@@ -176,7 +185,7 @@
while message:
if max >= 0 and i > max:
break
- if i%100 == 0 and printstat:
+ if i%100 == 0 and VERBOSE:
fmt = "\t%s\t%s\t\r"
if os.environ.get('TERM') in ('dumb', 'emacs'):
fmt = "\t%s\t%s\t\n"
@@ -194,7 +203,7 @@
print
get_transaction().commit()
-def loadinc(name, mb, f, printstat=0, max=99999999, wait=1):
+def loadinc(name, mb, f, max=99999999, wait=1):
from ZODB.POSException import ConflictError
from time import sleep
from whrandom import uniform
@@ -212,7 +221,7 @@
jar=Zope.DB.open()
app=jar.root()['Application']
mdest=getattr(app, name)
- if i%100 == 0 and printstat:
+ if i%100 == 0 and VERBOSE:
fmt = "\t%s\t%s\t\r"
if os.environ.get('TERM') in ('dumb', 'emacs'):
fmt = "\t%s\t%s\t\n"
@@ -243,7 +252,8 @@
jar.close()
- if printstat: sys.stdout.write("\t%s\t%s\t\n" % (i, f.tell()))
+ if VERBOSE:
+ sys.stdout.write("\t%s\t%s\t\n" % (i, f.tell()))
sys.stdout.flush()
return rconflicts, wconflicts
@@ -256,7 +266,7 @@
max = atoi(sys.argv[3])
else:
max = -1
- print do(Zope.DB, loadmail, (app, 'mail', sys.argv[2], 1, max))
+ print do(Zope.DB, loadmail, (app, 'mail', sys.argv[2], max))
Zope.DB.close()
class RE:
@@ -370,7 +380,7 @@
def returnf(t, c, size, mem, r, lock=lock):
print c, r
lock.release()
- argss.append((lock, (dest, mb, f, 1, count, wait), returnf))
+ argss.append((lock, (dest, mb, f, count, wait), returnf))
for lock, args, returnf in argss:
thread.start_new_thread(do, (Zope.DB, loadinc, args, returnf))
@@ -389,6 +399,25 @@
Zope.DB.close()
+def catdel():
+ import Zope
+ app = Zope.app()
+ db = Zope.DB
+ t = time.time()
+ c = time.clock()
+ size = db.getSize()
+ mem = VmSize()
+
+ del app.cat
+ get_transaction().commit()
+
+ t = time.time() - t
+ c = time.clock() - c
+ size = db.getSize() - size
+ mem = VmSize() - mem
+ print t, c, size, mem
+
+
words=['banishment', 'indirectly', 'imprecise', 'peeks',
'opportunely', 'bribe', 'sufficiently', 'Occidentalized', 'elapsing',
'fermenting', 'listen', 'orphanage', 'younger', 'draperies', 'Ida',
@@ -698,9 +727,28 @@
del sys.argv[1]
pdb.run('globals()[sys.argv[1]]()')
+def usage(code, msg=''):
+ print >> sys.stderr, __doc__
+ if msg:
+ print >> sys.stderr, msg
+ sys.exit(code)
+
if __name__=='__main__':
- try: f=globals()[sys.argv[1]]
+ try:
+ opts, args = getopt.getopt(sys.argv[1:], 'hv', ['help', 'verbose'])
+ except getopt.error, msg:
+ usage(1, msg)
+
+ for opt, arg in opts:
+ if opt in ('-h', '--help'):
+ usage(0)
+ elif opt in ('-v', '--verbose'):
+ VERBOSE = 1
+
+ try:
+ f=globals()[sys.argv[1]]
except:
print __doc__
sys.exit(1)
- else: f()
+ else:
+ f()