* Boost the priority of some jobs (like stdenv).

svn path=/nixpkgs/trunk/; revision=14780
This commit is contained in:
Eelco Dolstra 2009-03-30 13:24:46 +00:00
parent 5e294459e3
commit 9ad89c5b56

View File

@ -4,6 +4,16 @@ let
pkgs = allPackages {}; pkgs = allPackages {};
/* Set the Hydra scheduling priority for a job. The default
priority (100) should be used for most jobs. A different
priority should only be used for a few particularly interesting
jobs (in terms of giving feedback to developers), such as stdenv.
*/
prio = level: job: toJob job // { schedulingPriority = level; };
toJob = x: if builtins.isAttrs x then x else
{ type = "job"; systems = x; schedulingPriority = 100; };
/* Perform a job on the given set of platforms. The function `f' is /* Perform a job on the given set of platforms. The function `f' is
called by Hydra for each platform, and should return some job called by Hydra for each platform, and should return some job
to build on that platform. `f' is passed the Nixpkgs collection to build on that platform. `f' is passed the Nixpkgs collection
@ -13,8 +23,15 @@ let
/* Map an attribute of the form `foo = [platforms...]' to `testOn /* Map an attribute of the form `foo = [platforms...]' to `testOn
[platforms...] (pkgs: pkgs.foo)'. */ [platforms...] (pkgs: pkgs.foo)'. */
mapTestOn = pkgs.lib.mapAttrsRecursive mapTestOn = pkgs.lib.mapAttrsRecursiveCond
(path: value: testOn value (pkgs: pkgs.lib.getAttrFromPath path pkgs)); (as: !(as ? type && as.type == "job"))
(path: value:
let
job = toJob value;
getPkg = pkgs:
pkgs.lib.addMetaAttrs { schedulingPriority = toString job.schedulingPriority; }
(pkgs.lib.getAttrFromPath path pkgs);
in testOn job.systems getPkg);
/* Common platform groups on which to test packages. */ /* Common platform groups on which to test packages. */
linux = ["i686-linux" "x86_64-linux"]; linux = ["i686-linux" "x86_64-linux"];
@ -93,7 +110,7 @@ in {
file = all; file = all;
findutils = all; findutils = all;
firefox2 = linux; firefox2 = linux;
firefox3 = linux; firefox3 = prio 150 linux;
flex = all; flex = all;
flex2535 = all; flex2535 = all;
gawk = all; gawk = all;
@ -228,6 +245,7 @@ in {
splashutils_15 = linux; splashutils_15 = linux;
sqlite = allBut "i686-cygwin"; sqlite = allBut "i686-cygwin";
ssmtp = linux; ssmtp = linux;
stdenv = prio 175 all;
strace = linux; strace = linux;
su = linux; su = linux;
subversion = all; subversion = all;