Skip to content

Commit

Permalink
nixos/etc.nix: Make independent
Browse files Browse the repository at this point in the history
  • Loading branch information
roberth committed Dec 8, 2021
1 parent 7f129e3 commit 56c283e
Show file tree
Hide file tree
Showing 6 changed files with 88 additions and 4 deletions.
2 changes: 1 addition & 1 deletion nixos/modules/module-list.nix
Original file line number Diff line number Diff line change
Expand Up @@ -1142,7 +1142,7 @@
./system/boot/systemd-nspawn.nix
./system/boot/timesyncd.nix
./system/boot/tmp.nix
./system/etc/etc.nix
./system/etc/etc-activation.nix
./tasks/auto-upgrade.nix
./tasks/bcache.nix
./tasks/cpu-freq.nix
Expand Down
12 changes: 12 additions & 0 deletions nixos/modules/system/etc/etc-activation.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{ config, lib, ... }:
let
inherit (lib) stringAfter;
in {

imports = [ ./etc.nix ];

config = {
system.activationScripts.etc =
stringAfter [ "users" "groups" ] config.system.build.etcActivationCommands;
};
}
6 changes: 3 additions & 3 deletions nixos/modules/system/etc/etc.nix
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ in

{

imports = [ ../build.nix ];

###### interface

options = {
Expand Down Expand Up @@ -188,14 +190,12 @@ in
config = {

system.build.etc = etc;

system.activationScripts.etc = stringAfter [ "users" "groups" ]
system.build.etcActivationCommands =
''
# Set up the statically computed bits of /etc.
echo "setting up /etc..."
${pkgs.perl.withPackages (p: [ p.FileSlurp ])}/bin/perl ${./setup-etc.pl} ${etc}/etc
'';

};

}
69 changes: 69 additions & 0 deletions nixos/modules/system/etc/test.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
{ lib
, coreutils
, fakechroot
, fakeroot
, nixosModule
, runCommand
, util-linux
, vmTools
, writeText
}:
let
node = lib.nixos.core ({ config, modules, ... }: {
imports = [ nixosModule modules.etc ];
environment.etc."passwd" = {
text = passwdText;
};
environment.etc."hosts" = {
text = hostsText;
mode = "0751";
};
});
passwdText = ''
root:x:0:0:System administrator:/root:/run/current-system/sw/bin/bash
'';
hostsText = ''
127.0.0.1 localhost
::1 localhost
# testing...
'';
in
lib.recurseIntoAttrs {
test-etc-vm =
vmTools.runInLinuxVM (runCommand "test-etc-vm" { } ''
mkdir -p /etc
${node.config.system.build.etcActivationCommands}
set -x
[[ -L /etc/passwd ]]
diff /etc/passwd ${writeText "expected-passwd" passwdText}
[[ 751 = $(stat --format %a /etc/hosts) ]]
diff /etc/hosts ${writeText "expected-hosts" hostsText}
set +x
touch $out
'');

# fakeroot is behaving weird
test-etc-fakeroot =
runCommand "test-etc"
{
nativeBuildInputs = [
fakeroot
fakechroot
# for chroot
coreutils
# fakechroot needs getopt, which is provided by util-linux
util-linux
];
fakeRootCommands = ''
mkdir -p /etc
${node.config.system.build.etcActivationCommands}
diff /etc/hosts ${writeText "expected-hosts" hostsText}
touch $out
'';
} ''
mkdir fake-root
export FAKECHROOT_EXCLUDE_PATH=/dev:/proc:/sys:${builtins.storeDir}:$out
fakechroot fakeroot chroot $PWD/fake-root bash -c 'source $stdenv/setup; eval "$fakeRootCommands"'
'';

}
2 changes: 2 additions & 0 deletions nixos/nixos-core.nix
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ in {
imports = [ modules.invokeNixpkgs ];
nixpkgs.system = builtins.currentSystem;
};

etc = ./modules/system/etc/etc.nix;
};

evalModules = {
Expand Down
1 change: 1 addition & 0 deletions nixos/tests/all-tests.nix
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,7 @@ in
enlightenment = handleTest ./enlightenment.nix {};
env = handleTest ./env.nix {};
ergo = handleTest ./ergo.nix {};
etc = pkgs.callPackage ../modules/system/etc/test.nix { };
etcd = handleTestOn ["x86_64-linux"] ./etcd.nix {};
etcd-cluster = handleTestOn ["x86_64-linux"] ./etcd-cluster.nix {};
etebase-server = handleTest ./etebase-server.nix {};
Expand Down

0 comments on commit 56c283e

Please sign in to comment.