{ nixpkgs ? ../nixpkgs-wc }: let makeIso = { module, description, maintainers ? ["eelco"]}: { nixosSrc ? {outPath = ./.; rev = 1234;} , officialRelease ? false , system ? "i686-linux" }: with import nixpkgs {inherit system;}; let version = builtins.readFile ./VERSION + (if officialRelease then "" else "pre${toString nixosSrc.rev}"); versionModule = { system.nixosVersion = version; }; config = (import lib/eval-config.nix { inherit system nixpkgs; modules = [ module versionModule ]; }).config; iso = config.system.build.isoImage; in # Declare the ISO as a build product so that it shows up in Hydra. runCommand "nixos-iso-${version}" { meta = { description = "NixOS installation CD (${description}) - ISO image for ${system}"; maintainers = map (x: lib.getAttr x lib.maintainers) maintainers; }; inherit iso; passthru = { inherit config; }; } '' ensureDir $out/nix-support echo "file iso" $iso/iso/*.iso* >> $out/nix-support/hydra-build-products ''; # */ makeSystemTarball = { module, maintainers ? ["viric"]}: { nixosSrc ? {outPath = ./.; rev = 1234;} , officialRelease ? false , system ? "i686-linux" }: with import nixpkgs {inherit system;}; let version = builtins.readFile ./VERSION + (if officialRelease then "" else "pre${toString nixosSrc.rev}"); versionModule = { system.nixosVersion = version; }; config = (import lib/eval-config.nix { inherit system nixpkgs; modules = [ module versionModule ]; }).config; tarball = config.system.build.tarball; in tarball // { meta = { description = "NixOS system tarball for ${system} - ${stdenv.platform.name}"; maintainers = map (x: lib.getAttr x lib.maintainers) maintainers; }; inherit config; }; jobs = rec { tarball = { nixosSrc ? {outPath = ./.; rev = 1234;} , officialRelease ? false }: with import nixpkgs {}; releaseTools.makeSourceTarball { name = "nixos-tarball"; version = builtins.readFile ./VERSION; src = nixosSrc; inherit officialRelease; distPhase = '' releaseName=nixos-$VERSION$VERSION_SUFFIX ensureDir "$out/tarballs" mkdir ../$releaseName cp -prd . ../$releaseName cd .. tar cfvj $out/tarballs/$releaseName.tar.bz2 $releaseName ''; # */ }; manual = { nixosSrc ? {outPath = ./.; rev = 1234;} , officialRelease ? false }: (import "${nixosSrc}/doc/manual" { pkgs = import nixpkgs {}; options = (import lib/eval-config.nix { inherit nixpkgs; modules = [ { fileSystems = []; } ]; }).options; revision = if nixosSrc.rev == 1234 then "HEAD" else toString nixosSrc.rev; }).manual; iso_minimal = makeIso { module = ./modules/installer/cd-dvd/installation-cd-minimal.nix; description = "minimal"; }; iso_graphical = makeIso { module = ./modules/installer/cd-dvd/installation-cd-graphical.nix; description = "graphical"; }; # Provide a tarball that can be unpacked into an SD card, and easily # boot that system from uboot (like for the sheevaplug). # The pc variant helps preparing the expression for the system tarball # in a machine faster than the sheevpalug system_tarball_pc = makeSystemTarball { module = ./modules/installer/cd-dvd/system-tarball-pc.nix; }; system_tarball_fuloong2f = assert builtins.currentSystem == "mips64-linux"; makeSystemTarball { module = ./modules/installer/cd-dvd/system-tarball-fuloong2f.nix; } { system = "mips64-linux"; }; system_tarball_sheevaplug = assert builtins.currentSystem == "armv5tel-linux"; makeSystemTarball { module = ./modules/installer/cd-dvd/system-tarball-sheevaplug.nix; } { system = "armv5tel-linux"; }; # Hacky: doesn't depend on configuration. Yet configuration is evaluated (TODO) minimal_install_archive = {system ? "i686-linux"}: (iso_minimal {inherit system;}) .config.system.build.minimalInstallArchive; tests = { services ? ../services }: let t = import ./tests { inherit nixpkgs services; system = "i686-linux"; }; in { avahi = t.avahi.test; bittorrent = t.bittorrent.test; firefox = t.firefox.test; installer.lvm = t.installer.lvm.test; installer.separateBoot = t.installer.separateBoot.test; installer.simple = t.installer.simple.test; installer.swraid = t.installer.swraid.test; installer.rebuildCD = t.installer.rebuildCD.test; ipv6 = t.ipv6.test; kde4 = t.kde4.test; login = t.login.test; nat = t.nat.test; nfs = t.nfs.test; openssh = t.openssh.test; proxy = t.proxy.test; quake3 = t.quake3.report; remote_builds = t.remote_builds.test; subversion = t.subversion.report; trac = t.trac.test; }; }; in jobs