summaryrefslogtreecommitdiffstats
path: root/func/forkbomb.py
diff options
context:
space:
mode:
authorMichael DeHaan <mdehaan@redhat.com>2008-06-10 14:17:38 -0400
committerMichael DeHaan <mdehaan@redhat.com>2008-06-10 14:17:38 -0400
commit76996c8ac3016389fdafb47e7791f2c636e2a4ed (patch)
treed244b1655283d498d5228565eea98e32d6d06355 /func/forkbomb.py
parent59fb48805b4a9e1ebe088d0b8d5853dd3af8d5b1 (diff)
parent3750980ea547c73a63cb456a85be0b14cc36c30c (diff)
downloadthird_party-func-76996c8ac3016389fdafb47e7791f2c636e2a4ed.tar.gz
third_party-func-76996c8ac3016389fdafb47e7791f2c636e2a4ed.tar.xz
third_party-func-76996c8ac3016389fdafb47e7791f2c636e2a4ed.zip
Merge branch 'kadamski-async2'
Conflicts: func/jobthing.py
Diffstat (limited to 'func/forkbomb.py')
-rw-r--r--func/forkbomb.py17
1 files changed, 12 insertions, 5 deletions
diff --git a/func/forkbomb.py b/func/forkbomb.py
index 7cc9df3..ef0817a 100644
--- a/func/forkbomb.py
+++ b/func/forkbomb.py
@@ -16,7 +16,7 @@ import os
import random # for testing only
import time # for testing only
import shelve
-import bsddb
+import dbm
import sys
import tempfile
import fcntl
@@ -39,10 +39,10 @@ def __access_buckets(filename,clear,new_key=None,new_value=None):
modifying it as required.
"""
- internal_db = bsddb.btopen(filename, 'c', 0644 )
- handle = open(filename,"r")
+ handle = open(filename,"w")
fcntl.flock(handle.fileno(), fcntl.LOCK_EX)
- storage = shelve.BsdDbShelf(internal_db)
+ internal_db = dbm.open(filename, 'c', 0644 )
+ storage = shelve.Shelf(internal_db)
if clear:
storage.clear()
@@ -138,7 +138,14 @@ def batch_run(pool,callback,nforks=DEFAULT_FORKS,cachedir=DEFAULT_CACHE_DIR):
buckets = __bucketize(pool, nforks)
__forkbomb(0,buckets,callback,shelf_file)
rc = __access_buckets(shelf_file,False,None)
- os.remove(shelf_file)
+
+ try: #it's only cleanup so don't care if the files disapeared
+ os.remove(shelf_file)
+ os.remove(shelf_file+".pag")
+ os.remove(shelf_file+".dir")
+ except OSError:
+ pass
+
return rc
def __test(nforks=4,sample_size=20):