1
0
mirror of https://github.com/moparisthebest/pacman synced 2025-01-09 21:08:11 -05:00

* Rewrote pactest with an OptionParser so we can have helpful help text, and

bumped the version to 0.4. Still a work in progress.
* Changed some linewraps in rankmirrors to keep everything under 80 chars.
This commit is contained in:
Dan McGee 2007-02-22 08:06:54 +00:00
parent cd2309eb73
commit 3cda6f4f6b
2 changed files with 71 additions and 48 deletions

View File

@ -1,5 +1,7 @@
#! /usr/bin/python #! /usr/bin/python
# #
# pactest : run automated testing on the pacman binary
#
# Copyright (c) 2006 by Aurelien Foret <orelien@chez.com> # Copyright (c) 2006 by Aurelien Foret <orelien@chez.com>
# #
# This program is free software; you can redistribute it and/or modify # This program is free software; you can redistribute it and/or modify
@ -17,58 +19,75 @@
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
# USA. # USA.
import os, sys, glob
import getopt from optparse import OptionParser
import sys
import glob
import os
import pmenv import pmenv
import util import util
__author__ = "Aurelien FORET" __author__ = "Aurelien FORET"
__version__ = "0.3" __version__ = "0.4"
def resolveBinPath(option, opt_str, value, parser):
setattr(parser.values, option.dest, os.path.abspath(value))
def globTests(option, opt_str, value, parser):
globlist = []
globlist.extend(glob.glob(value))
setattr(parser.values, option.dest, globlist)
def createOptParser():
testcases = []
usage = "usage: %prog [options] [[--test=<path/to/testfile.py>] ...]"
description = "Runs automated tests on the pacman binary. Tests are " \
"described using an easy python syntax, and several can be " \
"ran at once."
parser = OptionParser(usage = usage, description = description)
parser.add_option("-v", "--verbose", action = "count",
dest = "verbose", default = 0,
help = "print verbose output")
parser.add_option("-d", "--debug", type = "int",
dest = "debug", default = 0,
help = "set debug level for pacman")
parser.add_option("-p", "--pacman", action = "callback",
callback = resolveBinPath, type = "string",
dest = "bin", default = "pacman",
help = "specify location of the pacman binary")
parser.add_option("-t", "--test", action = "callback",
callback = globTests, type = "string",
dest = "testcases",
help = "specify test case(s)")
parser.add_option("--nolog", action = "store_true",
dest = "nolog", default = False,
help = "do not log pacman messages")
parser.add_option("--gdb", action = "store_true",
dest = "gdb", default = False,
help = "use gdb while calling pacman")
parser.add_option("--valgrind", action = "store_true",
dest = "valgrind", default = False,
help = "use valgrind while calling pacman")
return parser
def usage(retcode):
"""
"""
print "Usage: %s [options] [[--test=<path/to/testfile.py>] ...]\n\n" % __file__
sys.exit(retcode)
if __name__ == "__main__": if __name__ == "__main__":
# instantiate env and parser objects
env = pmenv.pmenv() env = pmenv.pmenv()
testcases = [] parser = createOptParser()
(opts, args) = parser.parse_args()
try: # add parsed options to env object
opts, args = getopt.getopt(sys.argv[1:], util.verbose = opts.verbose
"d:hp:t:v", env.pacman["debug"] = opts.debug
["debug=", "gdb", "help", "pacman=", "test=", "valgrind", "verbose", "nolog"]) env.pacman["bin"] = opts.bin
except getopt.GetoptError: env.pacman["nolog"] = opts.nolog
usage(1) env.pacman["gdb"] = opts.gdb
env.pacman["valgrind"] = opts.valgrind
for (cmd, param) in opts: for i in opts.testcases:
if cmd == "-v" or cmd == "--verbose":
util.verbose += 1
elif cmd == "-d" or cmd == "--debug":
env.pacman["debug"] = int(param)
elif cmd == "-t" or cmd == "--test":
testcases.extend(glob.glob(param))
elif cmd == "-p" or cmd == "--pacman":
env.pacman["bin"] = os.path.abspath(param)
elif cmd == "-h" or cmd == "--help":
usage(0)
elif cmd == "--nolog":
env.pacman["nolog"] = 1
elif cmd == "--gdb":
env.pacman["gdb"] = 1
elif cmd == "--valgrind":
env.pacman["valgrind"] = 1
for i in testcases:
env.addtest(i) env.addtest(i)
# run tests and print overall results
env.run() env.run()
env.results() env.results()
# vim: set ts=4 sw=4 et: # vim: set ts=4 sw=4 et:

View File

@ -25,16 +25,19 @@ from optparse import OptionParser
def createOptParser(): def createOptParser():
usage = "usage: %prog [options] MIRRORFILE | URL" usage = "usage: %prog [options] MIRRORFILE | URL"
description = "Ranks pacman mirrors by their connection and opening speed. Pacman mirror files are located in /etc/pacman.d/. It can also rank one mirror if the URL is provided." description = "Ranks pacman mirrors by their connection and opening " \
parser = OptionParser(usage=usage,description=description) "speed. Pacman mirror files are located in /etc/pacman.d/. It " \
parser.add_option("-f", "--formatted", action="store_true", "can also rank one mirror if the URL is provided."
dest = "formatted", default=False, help="output in mirror file format") parser = OptionParser(usage = usage, description = description)
parser.add_option("-n", dest="num", default=0, parser.add_option("-f", "--formatted", action = "store_true",
help="number of servers to output, 0 for all") dest = "formatted", default = False,
parser.add_option("-u", "--url", action="store_true", dest="url", help = "output in mirror file format")
parser.add_option("-n", type = "int", dest = "num", default = 0,
help = "number of servers to output, 0 for all")
parser.add_option("-u", "--url", action = "store_true", dest = "url",
default=False, help="test a specific url") default=False, help="test a specific url")
parser.add_option("-v", "--verbose", action="store_true", dest="verbose", parser.add_option("-v", "--verbose", action = "store_true",
default=False, help="be verbose in output") dest = "verbose", default = False, help ="be verbose in output")
return parser return parser
def timeCmd(cmd): def timeCmd(cmd):
@ -86,7 +89,8 @@ if __name__ == "__main__":
fl = open(args[0], 'r') fl = open(args[0], 'r')
serverToTime = {} serverToTime = {}
if options.formatted: if options.formatted:
print "# Server list generated by rankmirrors on", datetime.date.today() print "# Server list generated by rankmirrors on",
print datetime.date.today()
else: else:
print 'Querying servers, this may take some time...' print 'Querying servers, this may take some time...'
for ln in fl.readlines(): for ln in fl.readlines():