* Delete some obsolete installation tests.
svn path=/nixos/trunk/; revision=26272
This commit is contained in:
parent
ab0ce6734b
commit
416c60550e
|
@ -1,26 +0,0 @@
|
|||
# configuration used to build ISO used to install NixOS when running NixOS kvm installation test
|
||||
|
||||
# The configuration is prebuild before starting the vm because starting the vm
|
||||
# causes some overhead.
|
||||
{pkgs, config, ...}:
|
||||
|
||||
let
|
||||
doOverride = pkgs.lib.mkOverrideTemplate 0 {};
|
||||
in
|
||||
|
||||
{
|
||||
|
||||
# make system boot and accessible:
|
||||
require = [ ./module-insecure.nix
|
||||
../../modules/installer/cd-dvd/installation-cd-minimal.nix
|
||||
];
|
||||
|
||||
fonts = {
|
||||
enableFontConfig = false;
|
||||
};
|
||||
|
||||
boot.loader.grub.timeout = doOverride 0;
|
||||
boot.loader.grub.default = 2;
|
||||
boot.loader.grub.version = doOverride 2;
|
||||
|
||||
}
|
|
@ -1,28 +0,0 @@
|
|||
# configuration being installed by NixOS kvm installation test
|
||||
{pkgs, config, ...}: {
|
||||
|
||||
# make system boot and accessible:
|
||||
require = [
|
||||
./module-insecure.nix
|
||||
];
|
||||
|
||||
boot.loader.grub = {
|
||||
device = "/dev/sda";
|
||||
copyKernels = false;
|
||||
bootDevice = "(hd0,0)";
|
||||
};
|
||||
|
||||
fileSystems = [
|
||||
{ mountPoint = "/";
|
||||
device = "/dev/sda1";
|
||||
neededForBoot = true;
|
||||
}
|
||||
];
|
||||
|
||||
swapDevices = [ { device = "/dev/sda2"; } ];
|
||||
|
||||
fonts = {
|
||||
enableFontConfig = false;
|
||||
};
|
||||
|
||||
}
|
|
@ -1,50 +0,0 @@
|
|||
# this allows logging in as root without password.
|
||||
|
||||
# This module is shared by the iso configuration and the system configuration
|
||||
# which is build by the test
|
||||
|
||||
{pkgs, config, ...}:
|
||||
|
||||
let
|
||||
doOverride = pkgs.lib.mkOverrideTemplate 0 {};
|
||||
in
|
||||
|
||||
{
|
||||
|
||||
services.openssh = {
|
||||
enable = true;
|
||||
permitRootLogin = "yes";
|
||||
};
|
||||
jobs.sshd = {
|
||||
startOn = doOverride "started network-interfaces";
|
||||
};
|
||||
|
||||
boot.initrd.kernelModules =
|
||||
["cifs" "virtio_net" "virtio_pci" "virtio_blk" "virtio_balloon" "nls_utf8"];
|
||||
|
||||
environment.systemPackages = [ pkgs.vim_configurable ];
|
||||
|
||||
# FIXME: rewrite pam.services the to be an attr list
|
||||
# I only want to override sshd
|
||||
security.pam.services = doOverride
|
||||
# Most of these should be moved to specific modules.
|
||||
[ { name = "cups"; }
|
||||
{ name = "ejabberd"; }
|
||||
{ name = "ftp"; }
|
||||
{ name = "lshd"; rootOK =true; allowNullPassword =true; }
|
||||
{ name = "passwd"; }
|
||||
{ name = "samba"; }
|
||||
{ name = "sshd"; rootOK = true; allowNullPassword =true; }
|
||||
{ name = "xlock"; }
|
||||
{ name = "chsh"; rootOK = true; }
|
||||
{ name = "su"; rootOK = true; forwardXAuth = true; }
|
||||
# Note: useradd, groupadd etc. aren't setuid root, so it
|
||||
# doesn't really matter what the PAM config says as long as it
|
||||
# lets root in.
|
||||
{ name = "useradd"; rootOK = true; }
|
||||
# Used by groupadd etc.
|
||||
{ name = "shadow"; rootOK = true; }
|
||||
{ name = "login"; ownDevices = true; allowNullPassword = true; }
|
||||
];
|
||||
|
||||
}
|
|
@ -1,250 +0,0 @@
|
|||
{ nixos ? ../..
|
||||
, nixpkgs ? ../../../nixpkgs
|
||||
, services ? ../../../nixos/services
|
||||
, system ? builtins.currentSystem
|
||||
}:
|
||||
|
||||
let
|
||||
|
||||
/*
|
||||
|
||||
test nixos installation automatically using a build job (unfinished)
|
||||
|
||||
run this test this way:
|
||||
nix-build --no-out-link --show-trace tests/test-nixos-install-from-cd.nix
|
||||
|
||||
--no-out-link is important because creating ./result will cause rebuilding of
|
||||
the iso as the nixos repository is included in the iso.
|
||||
|
||||
To prevent this make these paths point to another location:
|
||||
nixosTarball = makeTarball "nixos.tar.bz2" (cleanSource ../../..);
|
||||
nixpkgsTarball = makeTarball "nixpkgs.tar.bz2" (cleanSource pkgs.path);
|
||||
|
||||
*/
|
||||
|
||||
configuration_iso = ./configuration-iso.nix;
|
||||
configuration_install = ./configuration.nix;
|
||||
|
||||
release = (import ../../release.nix) { inherit nixpkgs; };
|
||||
|
||||
isoFile = (
|
||||
release.makeIso
|
||||
{
|
||||
module = configuration_iso;
|
||||
description = "minimal-testing-only";
|
||||
maintainers = ["MarcWeber"];
|
||||
}
|
||||
{ inherit system; }
|
||||
).iso;
|
||||
|
||||
eval = import ../../lib/eval-config.nix {
|
||||
inherit system nixpkgs;
|
||||
modules = [ configuration_install ];
|
||||
};
|
||||
|
||||
inherit (eval) pkgs config;
|
||||
|
||||
inherit (pkgs) qemu_kvm;
|
||||
|
||||
# prebuild system which will be installed for two reasons:
|
||||
# build derivations are in store and can be reused
|
||||
# the iso is only build when this suceeds (?)
|
||||
systemDerivation = builtins.addErrorContext "while building system" config.system.build.toplevel;
|
||||
|
||||
# TODO test both: copyKernels = true and false. true doesn't work ?
|
||||
|
||||
debug = if false then ''
|
||||
export DISPLAY=localhost:0.0
|
||||
''
|
||||
else
|
||||
# That's crazy: You see nothing but your computer is doing a *lot* of work :-)
|
||||
''
|
||||
KVM_OPTIONS="-nographic"
|
||||
'';
|
||||
|
||||
in
|
||||
|
||||
rec {
|
||||
|
||||
test =
|
||||
# FIXME: support i686 as well
|
||||
# FIXME: X shouldn't be required
|
||||
# Is there a way to use kvm when not running as root?
|
||||
# Would using uml provide any advantages?
|
||||
|
||||
|
||||
# TODO: Run installation withoun networking support ?
|
||||
# This can be done by using either firewalls or building system by .drv path?
|
||||
pkgs.runCommand "nixos-installation-test" { inherit systemDerivation; } ''
|
||||
|
||||
set -e
|
||||
|
||||
INFO(){ echo "INFO: " $@; }
|
||||
|
||||
die(){ echo $@; exit 1; }
|
||||
|
||||
if ${pkgs.procps}/bin/ps aux | grep -v grep | grep sbin/nmbd ; then
|
||||
die "!! aborting: -smb won't work when host is running samba!"
|
||||
fi
|
||||
|
||||
[ -e /dev/kvm ] || die "modprobe a kvm-* module /dev/kvm not present. You want it for speed reasons!"
|
||||
|
||||
for path in ${pkgs.socat} ${pkgs.openssh} ${qemu_kvm}; do
|
||||
PATH=$path/bin:$PATH
|
||||
done
|
||||
|
||||
# without samba -smb doesn't work
|
||||
PATH=${pkgs.samba}/sbin:$PATH
|
||||
|
||||
# install the system
|
||||
${debug}
|
||||
|
||||
SOCKET_NAME=65535.socket
|
||||
|
||||
# creating shell script for debugging purposes
|
||||
cat >> run-kvm.sh << EOF
|
||||
#!/bin/sh -e
|
||||
|
||||
exec qemu-system-x86_64 -m 512 \
|
||||
-no-kvm-irqchip \
|
||||
-net nic,model=virtio -net user -smb /nix \
|
||||
-hda image \
|
||||
-redir tcp:''${SOCKET_NAME/.socket/}::22 \
|
||||
$KVM_OPTIONS \
|
||||
"\$@"
|
||||
EOF
|
||||
chmod +x run-kvm.sh
|
||||
|
||||
RUN_KVM(){
|
||||
INFO "launching qemu-kvm in a background process"
|
||||
{ ./run-kvm.sh "$@" \
|
||||
|| { echo "starting kvm failed, exiting" 1>&2; kill -9 $$; }
|
||||
} &
|
||||
}
|
||||
|
||||
waitTill(){
|
||||
echo $1
|
||||
eval "while ! $2; do sleep 1; done"
|
||||
}
|
||||
|
||||
SSH(){
|
||||
# if timout occurs ssh command will be retried.
|
||||
# Waiting forever doesn't seem to work because
|
||||
# there seems to be a race condition where
|
||||
# SSH connects but sshd doesn't notice it.
|
||||
# Thus fail and retry
|
||||
ssh -o UserKnownHostsFile=/dev/null \
|
||||
-o StrictHostKeyChecking=no \
|
||||
-o ProxyCommand="socat stdio ./$SOCKET_NAME" \
|
||||
-o ConnectTimeout=1 \
|
||||
root@127.0.0.1 \
|
||||
"$@";
|
||||
}
|
||||
SSH_STDIN_E(){ { echo "set -e;"; cat; } | SSH; }
|
||||
|
||||
SHUTDOWN_VM(){
|
||||
SSH 'shutdown -h now';
|
||||
INFO "waiting for kvm to shutown"
|
||||
wait
|
||||
}
|
||||
|
||||
# wait for socket
|
||||
|
||||
waitForSSHD(){
|
||||
waitTill "waiting for sshd job" "SSH 'echo Hello > /dev/tty1' &> /dev/null"
|
||||
}
|
||||
|
||||
nixBuildTest(){
|
||||
INFO "verifying that nix-env -i works"
|
||||
|
||||
SSH_STDIN_E << EOF
|
||||
|
||||
cat >> test.nix << EOF_TEST
|
||||
let pkgs = import /etc/nixos/nixpkgs/pkgs/top-level/all-packages.nix {};
|
||||
in pkgs.stdenv.mkDerivation {
|
||||
name = "test";
|
||||
phases = "create_out";
|
||||
create_out = "mkdir -p \\\$out/ok";
|
||||
}
|
||||
EOF_TEST
|
||||
|
||||
nix-build test.nix
|
||||
[ -e result/ok ]
|
||||
EOF
|
||||
|
||||
}
|
||||
|
||||
### test installting NixOS: install system then reboot
|
||||
|
||||
|
||||
INFO "creating image file"
|
||||
# 2GB = data; 1GB=swap
|
||||
# Maybe using 1GB swap is much. But qcow2 doesn't fill holes so it only
|
||||
# used when required (?)
|
||||
qemu-img create -f qcow2 image 3G
|
||||
|
||||
RUN_KVM -boot d -cdrom $(echo ${isoFile}/iso/*.iso)
|
||||
|
||||
waitForSSHD
|
||||
|
||||
nixBuildTest
|
||||
|
||||
# INSTALLATION
|
||||
INFO "creating filesystem .."
|
||||
SSH_STDIN_E << EOF
|
||||
parted /dev/sda mklabel msdos
|
||||
parted /dev/sda mkpart primary 0 2G
|
||||
parted /dev/sda mkpart primary 1G 3G
|
||||
waitFor(){
|
||||
while [ ! -e "\$1" ]; do
|
||||
echo "waiting for \$1 to appear"; sleep 1;
|
||||
done
|
||||
}
|
||||
waitFor /dev/sda2
|
||||
mkswap /dev/sda2
|
||||
swapon /dev/sda2
|
||||
|
||||
waitFor /dev/sda1
|
||||
mkfs.ext3 /dev/sda1
|
||||
|
||||
mount /dev/sda1 /mnt
|
||||
mkdir -p /mnt/nix-on-host
|
||||
mount //10.0.2.4/qemu -oguest,username=nobody,noperm -tcifs /mnt/nix-on-host
|
||||
EOF
|
||||
|
||||
|
||||
SSH_STDIN_E << EOF
|
||||
# simple nixos-hardware-scan syntax check:
|
||||
nixos-hardware-scan > /tmp/test.nix
|
||||
EOF
|
||||
|
||||
INFO "copying sources and Nix, starting installation"
|
||||
SSH_STDIN_E << EOF
|
||||
|
||||
nixos-prepare-install
|
||||
|
||||
# has the generated configuration.nix file syntax errors?
|
||||
nix-instantiate --eval-only /tmp/test.nix
|
||||
|
||||
mkdir /mnt/root
|
||||
echo 'export NIXOS_CONFIG=/etc/nixos/nixos/tests/test-nixos-install-from-cd/configuration.nix' >> /mnt/root/.bashrc
|
||||
. /mnt/root/.bashrc
|
||||
export NIX_OTHER_STORES=/nix-on-host
|
||||
|
||||
run-in-chroot "/nix/store/nixos-bootstrap --install --no-pull"
|
||||
#nixos-install
|
||||
EOF
|
||||
|
||||
SHUTDOWN_VM
|
||||
|
||||
INFO "booting installed system"
|
||||
RUN_KVM -boot c
|
||||
waitForSSHD
|
||||
|
||||
nixBuildTest
|
||||
|
||||
SHUTDOWN_VM
|
||||
|
||||
echo "$(date) success" > $out
|
||||
'';
|
||||
}
|
|
@ -1,71 +0,0 @@
|
|||
# A test script is created testing the installer2 scripts
|
||||
# This can't be a build job because chroot is required - sudo is used
|
||||
#
|
||||
# # build test script:
|
||||
# nix-build tests/test-nixos-installer2.nix -A test
|
||||
#
|
||||
# # run:
|
||||
# sudo result/bin/test
|
||||
|
||||
{ nixos ? ./..
|
||||
, nixpkgs ? ../../nixpkgs
|
||||
, services ? ../../nixos/services
|
||||
, system ? builtins.currentSystem
|
||||
, configPath ? ./test-nixos-install-from-cd.nix
|
||||
}:
|
||||
|
||||
let
|
||||
|
||||
isos = (import ../release.nix) { inherit nixpkgs; };
|
||||
|
||||
# using same configuration as used by kvm test.
|
||||
configuration = ./test-nixos-install-from-cd/configuration.nix;
|
||||
|
||||
eval = import ../lib/eval-config.nix {
|
||||
inherit system nixpkgs;
|
||||
modules = [ configuration ];
|
||||
};
|
||||
|
||||
|
||||
inherit (eval) pkgs config;
|
||||
|
||||
inherit (pkgs) qemu_kvm;
|
||||
|
||||
# prebuild system which will be installed for two reasons:
|
||||
# build derivations are in store and can be reused
|
||||
# the iso is only build when this suceeds (?)
|
||||
systemDerivation = builtins.addErrorContext "while building system" config.system.build.toplevel;
|
||||
|
||||
|
||||
tools = config.system.build;
|
||||
|
||||
in
|
||||
|
||||
rec {
|
||||
|
||||
test = pkgs.writeScriptBin "test" ''
|
||||
#!/bin/sh -e
|
||||
# DEBUG can be set to --debug to force set -x in scripts
|
||||
|
||||
export mountPoint=''${mountPoint:-`pwd`/mountPoint}
|
||||
if [ -e "$mountPoint" ]; then
|
||||
echo "mountPoint $mountPoint exists, delete? [y] | other key: continue"
|
||||
read -n1 delete
|
||||
if [ "$delete" == "y" ]; then
|
||||
rm -fr $mountPoint
|
||||
fi
|
||||
fi
|
||||
mkdir -p $mountPoint
|
||||
|
||||
set -x
|
||||
|
||||
${tools.nixosPrepareInstall}/bin/nixos-prepare-install $DEBUG --dir-ok copy-nixos-bootstrap copy-nix copy-sources
|
||||
|
||||
cp ${configuration} $mountPoint/etc/nixos/configuration.nix
|
||||
|
||||
# at least one of those files is referenced. So copy all - they don't hurt
|
||||
cp -r ${builtins.dirOf (builtins.toString configuration)}/* $mountPoint/etc/nixos
|
||||
|
||||
${tools.runInChroot}/bin/run-in-chroot $DEBUG "/nix/store/nixos-bootstrap $DEBUG --install --no-grub"
|
||||
'';
|
||||
}
|
Loading…
Reference in New Issue