From: Zooko O'Whielacronx Date: Sat, 4 Jul 2009 22:43:00 +0000 (-0700) Subject: test/benchmark: benchmark the time to pack and unpack dirnodes X-Git-Tag: trac-4000~36 X-Git-Url: https://git.rkrishnan.org/specifications/%5B/%5D%20/uri/provisioning?a=commitdiff_plain;h=859d7ba8b0f70984191be9fadc7fb511b4b4870c;p=tahoe-lafs%2Ftahoe-lafs.git test/benchmark: benchmark the time to pack and unpack dirnodes See also the prof_benchmarks() function in this file which will run the benchmarks under profiling. --- diff --git a/src/allmydata/test/bench_dirnode.py b/src/allmydata/test/bench_dirnode.py new file mode 100644 index 00000000..ae48a550 --- /dev/null +++ b/src/allmydata/test/bench_dirnode.py @@ -0,0 +1,101 @@ +import os, random + +from pyutil import benchutil, randutil # http://allmydata.org/trac/pyutil + +from allmydata import client, dirnode, uri +from allmydata.mutable import filenode as mut_filenode +from allmydata.immutable import filenode as immut_filenode + +class FakeDownloadCache: + def get_file(self, key): + return None + +class FakeClient(client.Client): + # just enough + def __init__(self): + self._node_cache = {} + self.download_cache = FakeDownloadCache() + def getServiceNamed(self, name): + return None + def get_encoding_parameters(self): + return {"k": 3, "n": 10} + def get_writekey(self): + return os.urandom(16) + +class FakeMutableFileNode(mut_filenode.MutableFileNode): + def __init__(self, client): + mut_filenode.MutableFileNode.__init__(self, client) + self._uri = uri.WriteableSSKFileURI(randutil.insecurerandstr(16), randutil.insecurerandstr(32)) + +class FakeDirectoryNode(dirnode.NewDirectoryNode): + def __init__(self, client): + dirnode.NewDirectoryNode.__init__(self, client) + mutfileuri = uri.WriteableSSKFileURI(randutil.insecurerandstr(16), randutil.insecurerandstr(32)) + myuri = uri.NewDirectoryURI(mutfileuri) + self.init_from_uri(myuri) + + +children = [] # tuples of (k, v) (suitable for passing to dict()) +packstr = None +fakeclient = FakeClient() +testdirnode = dirnode.NewDirectoryNode(fakeclient) +testdirnode.init_from_uri(uri.NewDirectoryURI(uri.WriteableSSKFileURI(randutil.insecurerandstr(16), randutil.insecurerandstr(32)))) + +def random_unicode(l): + while True: + try: + return os.urandom(l).decode('utf-8') + except UnicodeDecodeError: + pass + +def random_fsnode(): + coin = random.randrange(0, 3) + if coin == 0: + return immut_filenode.FileNode(uri.CHKFileURI(randutil.insecurerandstr(16), randutil.insecurerandstr(32), random.randrange(1, 5), random.randrange(6, 15), random.randrange(99, 1000000000000)), fakeclient, None) + elif coin == 1: + return FakeMutableFileNode(fakeclient) + else: + assert coin == 2 + return FakeDirectoryNode(fakeclient) + +def random_metadata(): + d = {} + d['ctime'] = random.random() + d['mtime'] = random.random() + d['tahoe'] = {} + d['tahoe']['linkcrtime'] = random.random() + d['tahoe']['linkmotime'] = random.random() + return d + +def random_child(): + return random_fsnode(), random_metadata() + +def init_for_pack(N): + for i in xrange(len(children), N): + children.append((random_unicode(random.randrange(1, 9)), random_child())) + +def init_for_unpack(N): + global packstr + init_for_pack(N) + packstr = pack(N) + +def pack(N): + return testdirnode._pack_contents(dict(children[:N])) + +def unpack(N): + return testdirnode._unpack_contents(packstr) + +def run_benchmarks(): + print "benchmarking %s" % (unpack,) + benchutil.bench(unpack, initfunc=init_for_unpack, TOPXP=12) + print "benchmarking %s" % (pack,) + benchutil.bench(pack, initfunc=init_for_pack, TOPXP=12) + +def prof_benchmarks(): + import hotshot + prof = hotshot.Profile("bench_dirnode.prof") + prof.runcall(run_benchmarks) + prof.close() + +if __name__ == "__main__": + run_benchmarks()