#!/usr/bin/python
# This script aims to help to run locktests with several clients.
#
# Report bugs to Vincent ROQUETA : vincent.roqueta@ext.bull.net
import encodings
import shutil
import os, sys
import getopt, sys
import string
import socket
from stat import *
from sys import *
from os import *
NFS4_PATH="/mnt/nfsv4"
NFS4_SERVER=""
TEST_HOME="/home/vincent/locks/"
testfile=NFS4_PATH+"/testfile"
app="locktests"
SRC="locktests.tar.gz"
SRC_PATH="deploy"
install="'tar xzf "+SRC+"; cd locks; make `"
user="root"
class Machine:
def mkdir(self,dir):
self.command="mkdir -p "+dir
self.do()
def rmdir(self,dir):
self.command="rm -rf "+dir
self.do()
def printc(self):
print "->"+self.command
print "\n"
class Client(Machine):
def __init__(self, machine):
self.command=""
self.machine=machine
self.mountPath=NFS4_PATH
def do(self):
self.command="ssh "+user+"@"+self.machine+" "+self.command
os.system(self.command)
def isomount(self, dir):
export=NFS4_SERVER
mntpoint=NFS4_PATH
self.command="'mkdir -p "+mntpoint+"; mount -t nfs4 "+export+" "+mntpoint+"'"
self.do()
def umount(self, dir):
mntpoint=self.mountPath+"/"+dir
self.command="umount "+mntpoint
self.do()
def install(self, path):
self.command="'cd "+path+"; tar xzf "+SRC+"; cd locks; make'"
self.do()
def run(self, appli):
self.command=appli
self.do()
def cp(self, fichier, path):
command="scp "+fichier+" "+user+"@"+self.machine+":"+path
os.system(command)
class Serveur(Machine):
def __init__(self, ip, exportPath):
self.SERVEUR=ip
self.exportPath=exportPath
def do(self):
self.command="ssh "+self.SERVEUR+" "+self.command
os.system(self.command)
def configure(self, dir):
exportDir=self.exportPath+'/'+dir
self. mkdir(exportDir)
#self.printc()
self.export(exportDir)
#self.printc()
def clean(self, dir):
unexportDir=self.exportPath+'/'+dir
self.unexport(unexportDir)
self.rmdir(unexportDir)
def usage():
print "\n"
print "usage:"
print "locktests.py <-n process -f testfile ><--setup -s fs_server> -c host1, host2, host3 ... "
print "--setup : setup the configuration, deploy test on other test machines; This option also requires -c and -s"
print "-c <machine> : host list to deploy/run/clean the test"
print "-s <machine> : NFS server to use to setup the test"
print "-n <num> : number of processes each test machine will lauch to perform the test"
print "-f <file> : test file. This must be the same on each machine"
print " "
print "Example :"
print "========="
print "*Setup machines for testing"
print "./locktests.py --setup -c testmachine1 testmachine2 testmachine3 -s my_nfs_server:/"
print "\n"
print "*Run test on testmachine1,testmachine2 with 50 process on each machine using /mnt/nfsv4/testfile"
print "./locktests.py -n 50 -f /mnt/nfsv4/testfile -c testmachine1 testmachine2"
print "\n"
print "_________________________________"
print "Vincent ROQUETA - Bull SA - 2005\n"
return 0
def setup():
path=os.path.abspath(".")
fichier=SRC_PATH+"/"+SRC
commande=""
for i in clients:
print "Setting up machine "+i
c=Client(i)
c.mkdir(path)
c.cp(fichier, path)
c.install(path)
c.isomount(NFS4_PATH)
#Setup localhost
print "Setting up localhost"
commande="make; mkdir -p "+NFS4_PATH+" ; mount -t nfs4 "+NFS4_SERVER+" "+NFS4_PATH+" &"
os.system(commande)
def run():
path=os.path.abspath(".")
nbreClients=len(clients)
hostname=socket.gethostname()
# Lancement du serveur en local
# Launch the server locally
commande=path+"/"+app+" -n "+nbreProcess+" -f "+filename+" -c "+str(nbreClients)+" &"
os.system(commande)
commande=path+"/locks/"+app+" --server "+hostname
for i in clients:
c=Client(i)
c.run(commande)
def clean():
for i in clients:
client.umount(NFS4_PATH)
args=sys.argv[1:]
rge=range(len(args))
a=""
r=True
s=False
nfsServer=False
c=False
f=False
n=False
clients=[]
for i in rge:
if args[i] in ("--install", "-i", "--setup"):
r=False
s=True
continue
if args[i] in ("-s", "--server"):
a="nfsServer"
nfsServer=True
continue
if args[i] in ("-h", "--help"):
usage()
sys.exit(1)
if args[i] in ("--clients", "-c"):
a="clients"
c=True
continue
if args[i] == "-n":
a="nbre"
n=True
continue
if args[i] == "-f":
a="file"
f=True
continue
if a=="clients":
clients.append(args[i])
continue
if a=="file":
filename=args[i]
continue
if a=="nbre":
nbreProcess=args[i]
continue
if a=="nfsServer":
NFS4_SERVER=args[i]
continue
usage()
# For ...
if s:
if (not c) or (not nfsServer):
usage()
sys.exit(1)
print "Setup"
print NFS4_SERVER
setup()
print "Setup complete"
if r:
if (not c) or (not f) or (not n):
usage()
sys.exit(1)
print "Running test"
run()