Date: Sun, 11 Dec 2011 21:30:18 +0000 (UTC) From: Mark Linimon <linimon@FreeBSD.org> To: src-committers@freebsd.org, svn-src-projects@freebsd.org Subject: svn commit: r228428 - projects/portbuild/qmanager Message-ID: <201112112130.pBBLUIAf069991@svn.freebsd.org>
index | next in thread | raw e-mail
Author: linimon (doc,ports committer) Date: Sun Dec 11 21:30:17 2011 New Revision: 228428 URL: http://svn.freebsd.org/changeset/base/228428 Log: Add a way to defeat the runaway-build check by passing a parameter -unlimited-errors. (To do this, add code for parameter checking in the first place.) This parameter is primarily useful for -restart or -trybroken runs where you are expecting a lot of errors. Modified: projects/portbuild/qmanager/packagebuild Modified: projects/portbuild/qmanager/packagebuild ============================================================================== --- projects/portbuild/qmanager/packagebuild Sun Dec 11 21:26:49 2011 (r228427) +++ projects/portbuild/qmanager/packagebuild Sun Dec 11 21:30:17 2011 (r228428) @@ -65,14 +65,22 @@ QMANAGER_RUNAWAY_PERCENTAGE = float( \ QMANAGER_RUNAWAY_THRESHOLD = int( \ config.get( 'QMANAGER_RUNAWAY_THRESHOLD' ) ) +# debug controls DEBUG_PACKAGEBUILD = False DEBUG_RETCODE = False +# argument handling +ARG_UNLIMITED_ERRORS = "unlimited-errors" + +# global variables + categories = {} ports = {} pkg_sufx = None +unlimited_errors = False + # When a build fails we requeue it with a lower priority such that it # will never preempt a phase 1 build but will build when spare # capacity is available. @@ -538,13 +546,24 @@ def main(arch, branch, buildid, args): print "error: pkg_sufx not defined in portbuild.conf" sys.exit(1) - print "[MASTER] parseindex..." + print "[MASTER] Parsing INDEX..." index = Index(indexfile) index.parse() print "[MASTER] length = %s" % len(ports) + print "[MASTER] Parsing arguments..." + targets = [] + for arg in args: + if arg.find( "-" ) == 0: + if ( arg[ 1 : ] == ARG_UNLIMITED_ERRORS): + unlimited_errors = True + else: + print "[MASTER] arg %s not recognized, ignoring." % arg[ 1 : ] + else: + targets = targets.append( arg ) + print "[MASTER] Finding targets..." - targets = gettargets(args) + targets = gettargets(targets) print "[MASTER] Calculating depth..." depthindex(targets) @@ -593,13 +612,13 @@ def main(arch, branch, buildid, args): job.failure() continue else: - # XXX MCL 20110421 completed_jobs = completed_jobs + 1 failed_jobs = failed_jobs + 1 if DEBUG_PACKAGEBUILD: print "[MASTER] jobs: %d failed jobs out of %d:" % \ ( failed_jobs, completed_jobs ) - if completed_jobs > QMANAGER_RUNAWAY_THRESHOLD and \ + if not unlimited_errors and \ + completed_jobs > QMANAGER_RUNAWAY_THRESHOLD and \ float( failed_jobs ) / completed_jobs > QMANAGER_RUNAWAY_PERCENTAGE: print "[MASTER] ERROR: runaway build detected: %d failed jobs out of %d:" % \ ( failed_jobs, completed_jobs )help
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201112112130.pBBLUIAf069991>
