Annotation of embedaddon/rsync/testhelp/maketree.py, revision 1.1
1.1 ! misho 1: #! /usr/bin/python2.2
! 2:
! 3: # Copyright (C) 2002 by Martin Pool <mbp@samba.org>
! 4:
! 5: # This program is free software; you can redistribute it and/or modify
! 6: # it under the terms of the GNU General Public License version
! 7: # 2 as published by the Free Software Foundation.
! 8: #
! 9: # This program is distributed in the hope that it will be useful, but
! 10: # WITHOUT ANY WARRANTY; without even the implied warranty of
! 11: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
! 12: # Lesser General Public License for more details.
! 13: #
! 14: # You should have received a copy of the GNU Lesser General Public
! 15: # License along with this program; if not, write to the Free Software
! 16: # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
! 17:
! 18: # Populate a tree with pseudo-randomly distributed files to test
! 19: # rsync.
! 20:
! 21: from __future__ import generators
! 22: import random, string, os, os.path
! 23:
! 24: nfiles = 10000
! 25: depth = 5
! 26: n_children = 20
! 27: n_files = 20
! 28: n_symlinks = 10
! 29:
! 30: name_chars = string.digits + string.letters
! 31:
! 32: abuffer = 'a' * 1024
! 33:
! 34: def random_name_chars():
! 35: a = ""
! 36: for i in range(10):
! 37: a = a + random.choice(name_chars)
! 38: return a
! 39:
! 40:
! 41: def generate_names():
! 42: n = 0
! 43: while 1:
! 44: yield "%05d_%s" % (n, random_name_chars())
! 45: n += 1
! 46:
! 47:
! 48: class TreeBuilder:
! 49: def __init__(self):
! 50: self.n_children = 20
! 51: self.n_files = 100
! 52: self.total_entries = 100000 # long(1e8)
! 53: self.actual_size = 0
! 54: self.name_gen = generate_names()
! 55: self.all_files = []
! 56: self.all_dirs = []
! 57: self.all_symlinks = []
! 58:
! 59:
! 60: def random_size(self):
! 61: return random.lognormvariate(4, 4)
! 62:
! 63:
! 64: def random_symlink_target(self):
! 65: what = random.choice(['directory', 'file', 'symlink', 'none'])
! 66: try:
! 67: if what == 'directory':
! 68: return random.choice(self.all_dirs)
! 69: elif what == 'file':
! 70: return random.choice(self.all_files)
! 71: elif what == 'symlink':
! 72: return random.choice(self.all_symlinks)
! 73: elif what == 'none':
! 74: return self.name_gen.next()
! 75: except IndexError:
! 76: return self.name_gen.next()
! 77:
! 78:
! 79: def can_continue(self):
! 80: self.total_entries -= 1
! 81: return self.total_entries > 0
! 82:
! 83:
! 84: def build_tree(self, prefix, depth):
! 85: """Generate a breadth-first tree"""
! 86: for count, function in [[n_files, self.make_file],
! 87: [n_children, self.make_child_recurse],
! 88: [n_symlinks, self.make_symlink]]:
! 89: for i in range(count):
! 90: if not self.can_continue():
! 91: return
! 92: name = os.path.join(prefix, self.name_gen.next())
! 93: function(name, depth)
! 94:
! 95:
! 96: def print_summary(self):
! 97: print "total bytes: %d" % self.actual_size
! 98:
! 99:
! 100: def make_child_recurse(self, dname, depth):
! 101: if depth > 1:
! 102: self.make_dir(dname)
! 103: self.build_tree(dname, depth-1)
! 104:
! 105:
! 106: def make_dir(self, dname, depth='ignore'):
! 107: print "%s/" % (dname)
! 108: os.mkdir(dname)
! 109: self.all_dirs.append(dname)
! 110:
! 111:
! 112: def make_symlink(self, lname, depth='ignore'):
! 113: print "%s -> %s" % (lname, self.random_symlink_target())
! 114:
! 115:
! 116: def make_file(self, fname, depth='ignore'):
! 117: size = long(self.random_size())
! 118: print "%-70s %d" % (fname, size)
! 119: f = open(fname, 'w')
! 120: f.truncate(size)
! 121: self.fill_file(f, size)
! 122: self.all_files.append(fname)
! 123: self.actual_size += size
! 124:
! 125: def fill_file(self, f, size):
! 126: while size > 0:
! 127: f.write(abuffer[:size])
! 128: size -= len(abuffer)
! 129:
! 130:
! 131: tb = TreeBuilder()
! 132: tb.build_tree('/tmp/foo', 3)
! 133: tb.print_summary()
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>