1
0
mirror of https://github.com/moparisthebest/pacman synced 2025-01-10 21:38:19 -05:00

* corrected (IMO) --debug usage with pactest. --debug is now passed straight

through to pacman, whereas --verbose affects the pactest output - this cleans
  up the standard test output significantly
* sorted tests a bit better, sectioning off failed tests AFTER successful tests,
  to make it easier to see what failed at a glance
* added a 'testname' member to pmtest, which strips path info (cleaner output)
This commit is contained in:
Aaron Griffin 2007-02-26 08:19:02 +00:00
parent 4a75e42f12
commit 25223d6790
6 changed files with 38 additions and 34 deletions

View File

@ -344,8 +344,8 @@ class pmdb:
if not oldpkg: if not oldpkg:
return 0 return 0
#dbg("oldpkg.checksum : %s" % oldpkg.checksum) vprint("\toldpkg.checksum : %s" % oldpkg.checksum)
#dbg("oldpkg.mtime : %s" % oldpkg.mtime) vprint("\toldpkg.mtime : %s" % oldpkg.mtime)
for key in pkg.mtime.keys(): for key in pkg.mtime.keys():
if key == "install" \ if key == "install" \

View File

@ -19,6 +19,7 @@
import os import os
import os.path
import time import time
import pmtest import pmtest
@ -59,7 +60,7 @@ class pmenv:
for t in self.testcases: for t in self.testcases:
print "=========="*8 print "=========="*8
print "Running '%s'" % t.name.replace(".py", "") print "Running '%s'" % t.testname
t.load() t.load()
print t.description print t.description
@ -88,33 +89,42 @@ class pmenv:
""" """
""" """
passed = 0 passed = 0
print "=========="*8 tpassed = []
print "Results" tfailed = []
print "----------"*8
for test in self.testcases: for test in self.testcases:
fail = test.result["fail"]
if fail == 0:
passed += 1
tpassed.append(test)
else:
tfailed.append(test)
def _printtest(t):
success = test.result["success"] success = test.result["success"]
fail = test.result["fail"] fail = test.result["fail"]
rules = len(test.rules) rules = len(test.rules)
if fail == 0: if fail == 0:
print "[PASSED]", print "[PASSED]",
passed += 1
else: else:
print "[FAILED]", print "[FAILED]",
print test.name.replace(".py", "").ljust(33), print "%s Rules:OK = %2u FAIL = %2u SKIP = %2u" \
print "Rules:", % (test.testname.ljust(32), success, fail, rules - (success + fail))
print "OK = %2u FAIL = %2u SKIP = %2u" % \
(success, fail, rules - (success + fail)) print "=========="*8
print "Results"
print "----------"*8 print "----------"*8
for test in tpassed: _printtest(test)
print "----------"*8
for test in tfailed: _printtest(test)
print "----------"*8
total = len(self.testcases) total = len(self.testcases)
failed = total - passed failed = total - passed
print "TOTAL = %3u" % total print "TOTAL = %3u" % total
if total: if total:
print "PASSED = %3u (%6.2f%%)" % \ print "PASSED = %3u (%6.2f%%)" % (passed, float(passed) * 100 / total)
(passed, float(passed) * 100 / total) print "FAILED = %3u (%6.2f%%)" % (failed, float(failed) * 100 / total)
print "FAILED = %3u (%6.2f%%)" % \ print ""
(failed, float(failed) * 100 / total)
print
if __name__ == "__main__": if __name__ == "__main__":
env = pmenv("/tmp") env = pmenv("/tmp")

View File

@ -48,10 +48,9 @@ class pmfile:
checksum = getmd5sum(filename) checksum = getmd5sum(filename)
mtime = getmtime(filename) mtime = getmtime(filename)
if debug: vprint("\tismodified(%s)" % self.name)
print "ismodified(%s)" % self.name vprint("\t\told: %s / %s" % (self.checksum, self.mtime))
print "old: %s / %s" % (self.checksum, self.mtime) vprint("\t\tnew: %s / %s" % (checksum, mtime))
print "new: %s / %s" % (checksum, mtime)
if not self.checksum == checksum \ if not self.checksum == checksum \
or not (self.mtime[1], self.mtime[2]) == (mtime[1], mtime[2]): or not (self.mtime[1], self.mtime[2]) == (mtime[1], mtime[2]):

View File

@ -63,8 +63,8 @@ class pmrule:
if not newpkg: if not newpkg:
success = 0 success = 0
else: else:
#dbg("newpkg.checksum : %s" % newpkg.checksum) vprint("\tnewpkg.checksum : %s" % newpkg.checksum)
#dbg("newpkg.mtime : %s" % newpkg.mtime) vprint("\tnewpkg.mtime : %s" % newpkg.mtime)
if case == "EXIST": if case == "EXIST":
success = 1 success = 1
elif case == "MODIFIED": elif case == "MODIFIED":

View File

@ -19,6 +19,7 @@
import os import os
import os.path
import shutil import shutil
import time import time
@ -35,11 +36,13 @@ class pmtest:
def __init__(self, name, root): def __init__(self, name, root):
self.name = name self.name = name
self.testname = os.path.basename(name).replace('.py', '')
self.root = root self.root = root
def __str__(self): def __str__(self):
return "name = %s\n" \ return "name = %s\n" \
"root = %s" % (self.name, self.root) "testname = %s\n" \
"root = %s" % (self.name, self.testname, self.root)
def addpkg2db(self, treename, pkg): def addpkg2db(self, treename, pkg):
""" """
@ -197,7 +200,7 @@ class pmtest:
cmd.append("%s" % self.args) cmd.append("%s" % self.args)
if not pacman["gdb"] and not pacman["valgrind"] and not pacman["nolog"]: if not pacman["gdb"] and not pacman["valgrind"] and not pacman["nolog"]:
cmd.append(">%s 2>&1" % os.path.join(self.root, LOGFILE)) cmd.append(">%s 2>&1" % os.path.join(self.root, LOGFILE))
dbg(" ".join(cmd)) vprint("\trunning: %s" % " ".join(cmd))
# Change to the tmp dir before running pacman, so that local package # Change to the tmp dir before running pacman, so that local package
# archives are made available more easily. # archives are made available more easily.
@ -214,7 +217,7 @@ class pmtest:
self.retcode = 0 self.retcode = 0
else: else:
self.retcode /= 256 self.retcode /= 256
dbg("retcode = %s" % self.retcode) vprint("\tretcode = %s" % self.retcode)
os.chdir(curdir) os.chdir(curdir)
# Check if pacman failed because of bad permissions # Check if pacman failed because of bad permissions

View File

@ -43,10 +43,7 @@ TMPDIR = "tmp"
SYNCREPO = "var/pub" SYNCREPO = "var/pub"
LOGFILE = "var/log/pactest.log" LOGFILE = "var/log/pactest.log"
verbose = 0 verbose = 0
debug = 1
def err(msg): def err(msg):
print "error: " + msg print "error: " + msg
@ -56,11 +53,6 @@ def vprint(msg):
if verbose: if verbose:
print msg print msg
def dbg(msg):
if debug:
print msg
# #
# Methods to generate files # Methods to generate files
# #