forked from fediversity/fediversity
add data model test: plain nixos
Signed-off-by: Kiara Grouwstra <kiara@procolix.eu>
This commit is contained in:
parent
1c87dd0986
commit
b987f8251f
5 changed files with 135 additions and 40 deletions
12
deployment/check/data-model-basic/constants.nix
Normal file
12
deployment/check/data-model-basic/constants.nix
Normal file
|
|
@ -0,0 +1,12 @@
|
||||||
|
{
|
||||||
|
targetMachines = [
|
||||||
|
# FIXME removing caused error: expected an indented block after 'with'
|
||||||
|
"ssh"
|
||||||
|
];
|
||||||
|
# stablize path, as just the path would yield distinct paths when applied multiple times
|
||||||
|
pathToRoot = builtins.path {
|
||||||
|
path = ../../..;
|
||||||
|
name = "root";
|
||||||
|
};
|
||||||
|
pathFromRoot = "/deployment/check/data-model-basic";
|
||||||
|
}
|
||||||
22
deployment/check/data-model-basic/default.nix
Normal file
22
deployment/check/data-model-basic/default.nix
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
runNixOSTest,
|
||||||
|
inputs,
|
||||||
|
sources,
|
||||||
|
}:
|
||||||
|
|
||||||
|
runNixOSTest {
|
||||||
|
imports = [
|
||||||
|
../common/nixosTest.nix
|
||||||
|
./nixosTest.nix
|
||||||
|
];
|
||||||
|
_module.args = {
|
||||||
|
inherit inputs sources;
|
||||||
|
modulesPath = "${builtins.toString pkgs.path}/nixos/modules";
|
||||||
|
};
|
||||||
|
inherit (import ./constants.nix)
|
||||||
|
targetMachines
|
||||||
|
pathToRoot
|
||||||
|
pathFromRoot
|
||||||
|
;
|
||||||
|
}
|
||||||
59
deployment/check/data-model-basic/nixosTest.nix
Normal file
59
deployment/check/data-model-basic/nixosTest.nix
Normal file
|
|
@ -0,0 +1,59 @@
|
||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
modulesPath,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
inherit (lib) mkOption;
|
||||||
|
inherit (pkgs.callPackage ../common/utils.nix { inherit modulesPath; }) mkNixosConfiguration;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
_class = "nixosTest";
|
||||||
|
name = "deployment-model";
|
||||||
|
|
||||||
|
nodes.deployer =
|
||||||
|
((pkgs.callPackage ../../utils.nix { }).evalModel (
|
||||||
|
{ config, ... }:
|
||||||
|
{
|
||||||
|
imports = [ ../common/model.nix ];
|
||||||
|
options = {
|
||||||
|
default =
|
||||||
|
let
|
||||||
|
env = config.environments.default;
|
||||||
|
in
|
||||||
|
mkOption {
|
||||||
|
type = env.resource-mapping.output-type;
|
||||||
|
default = env.deployment {
|
||||||
|
deployment-name = "default";
|
||||||
|
configuration = config."example-configuration";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
deploy = mkOption {
|
||||||
|
default = config.default.ssh-host.run;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
config = {
|
||||||
|
environments.default = environment: {
|
||||||
|
resources."operator-environment".login-shell.username = "operator";
|
||||||
|
implementation =
|
||||||
|
{ required-resources, ... }:
|
||||||
|
{
|
||||||
|
nixos-configuration = {
|
||||||
|
imports = [
|
||||||
|
(mkNixosConfiguration environment required-resources)
|
||||||
|
"${modulesPath}/../lib/testing/nixos-test-base.nix"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
)).default.nixos-configuration;
|
||||||
|
|
||||||
|
extraTestScript = ''
|
||||||
|
with subtest("Check the data model"):
|
||||||
|
deployer.wait_for_unit("multi-user.target")
|
||||||
|
deployer.succeed("su - operator -c hello 1>&2")
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
|
@ -27,6 +27,11 @@
|
||||||
inherit pkgs inputs sources;
|
inherit pkgs inputs sources;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
deployment-model-basic = import ./check/data-model-basic {
|
||||||
|
inherit (pkgs.testers) runNixOSTest;
|
||||||
|
inherit pkgs inputs sources;
|
||||||
|
};
|
||||||
|
|
||||||
deployment-model-ssh = import ./check/data-model-ssh {
|
deployment-model-ssh = import ./check/data-model-ssh {
|
||||||
inherit (pkgs.testers) runNixOSTest;
|
inherit (pkgs.testers) runNixOSTest;
|
||||||
inherit pkgs inputs sources;
|
inherit pkgs inputs sources;
|
||||||
|
|
|
||||||
|
|
@ -38,6 +38,8 @@ let
|
||||||
# which would otherwise not be serializable, while nix also makes it hard to
|
# which would otherwise not be serializable, while nix also makes it hard to
|
||||||
# produce its derivation to pass thru without a `nix-instantiate` call,
|
# produce its derivation to pass thru without a `nix-instantiate` call,
|
||||||
# which in turn would need to be passed the (unserializable) nixos config.
|
# which in turn would need to be passed the (unserializable) nixos config.
|
||||||
|
# FIXME find a way to serialize nixos configurations without needing recursion
|
||||||
|
# c.f. inability to serialize functions: https://github.com/NixOS/nix/issues/4000
|
||||||
builtins.toString (
|
builtins.toString (
|
||||||
pkgs.writers.writeText "configuration.nix" ''
|
pkgs.writers.writeText "configuration.nix" ''
|
||||||
import ${root-path}/deployment/nixos.nix {
|
import ${root-path}/deployment/nixos.nix {
|
||||||
|
|
@ -65,6 +67,20 @@ let
|
||||||
description = "A NixOS configuration.";
|
description = "A NixOS configuration.";
|
||||||
type = raw;
|
type = raw;
|
||||||
};
|
};
|
||||||
|
# FIXME ensure this works from outside this repo too
|
||||||
|
caller = mkOption {
|
||||||
|
description = "The calling module to obtain the NixOS configuration from.";
|
||||||
|
type = types.str;
|
||||||
|
};
|
||||||
|
args = mkOption {
|
||||||
|
description = "The arguments with which to call the module to obtain the NixOS configuration.";
|
||||||
|
type = types.attrs;
|
||||||
|
};
|
||||||
|
deployment-name = mkOption {
|
||||||
|
description = "The name of the deployment for which to obtain the NixOS configuration.";
|
||||||
|
type = types.str;
|
||||||
|
default = "default";
|
||||||
|
};
|
||||||
httpBackend = mkOption {
|
httpBackend = mkOption {
|
||||||
description = "environment variables to configure the TF HTTP back-end, see <https://developer.hashicorp.com/terraform/language/backend/http#configuration-variables>";
|
description = "environment variables to configure the TF HTTP back-end, see <https://developer.hashicorp.com/terraform/language/backend/http#configuration-variables>";
|
||||||
# type = types.attrsOf (types.either types.str types.int);
|
# type = types.attrsOf (types.either types.str types.int);
|
||||||
|
|
@ -182,6 +198,7 @@ let
|
||||||
};
|
};
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
inherit nixos-configuration;
|
||||||
ssh-host = mkOption {
|
ssh-host = mkOption {
|
||||||
description = "A deployment by SSH to update a single existing NixOS host.";
|
description = "A deployment by SSH to update a single existing NixOS host.";
|
||||||
type = submodule (
|
type = submodule (
|
||||||
|
|
@ -192,21 +209,13 @@ in
|
||||||
description = "The architecture of the system to deploy to.";
|
description = "The architecture of the system to deploy to.";
|
||||||
type = types.str;
|
type = types.str;
|
||||||
};
|
};
|
||||||
inherit nixos-configuration;
|
inherit
|
||||||
|
caller
|
||||||
|
args
|
||||||
|
deployment-name
|
||||||
|
nixos-configuration
|
||||||
|
;
|
||||||
ssh = host-ssh;
|
ssh = host-ssh;
|
||||||
caller = mkOption {
|
|
||||||
description = "The calling module to obtain the NixOS configuration from.";
|
|
||||||
type = types.str;
|
|
||||||
};
|
|
||||||
args = mkOption {
|
|
||||||
description = "The arguments with which to call the module to obtain the NixOS configuration.";
|
|
||||||
type = types.attrs;
|
|
||||||
};
|
|
||||||
deployment-name = mkOption {
|
|
||||||
description = "The name of the deployment for which to obtain the NixOS configuration.";
|
|
||||||
type = types.str;
|
|
||||||
default = "default";
|
|
||||||
};
|
|
||||||
root-path = mkOption {
|
root-path = mkOption {
|
||||||
description = "The path to the root of the repository.";
|
description = "The path to the root of the repository.";
|
||||||
type = types.path;
|
type = types.path;
|
||||||
|
|
@ -274,20 +283,14 @@ in
|
||||||
description = "The architecture of the system to deploy to.";
|
description = "The architecture of the system to deploy to.";
|
||||||
type = types.str;
|
type = types.str;
|
||||||
};
|
};
|
||||||
inherit httpBackend nixos-configuration;
|
inherit
|
||||||
|
caller
|
||||||
|
args
|
||||||
|
deployment-name
|
||||||
|
httpBackend
|
||||||
|
nixos-configuration
|
||||||
|
;
|
||||||
ssh = host-ssh;
|
ssh = host-ssh;
|
||||||
caller = mkOption {
|
|
||||||
description = "The calling module to obtain the NixOS configuration from.";
|
|
||||||
type = types.str;
|
|
||||||
};
|
|
||||||
args = mkOption {
|
|
||||||
description = "The arguments with which to call the module to obtain the NixOS configuration.";
|
|
||||||
type = types.attrs;
|
|
||||||
};
|
|
||||||
deployment-name = mkOption {
|
|
||||||
description = "The name of the deployment for which to obtain the NixOS configuration.";
|
|
||||||
type = types.str;
|
|
||||||
};
|
|
||||||
root-path = mkOption {
|
root-path = mkOption {
|
||||||
description = "The path to the root of the repository.";
|
description = "The path to the root of the repository.";
|
||||||
type = types.path;
|
type = types.path;
|
||||||
|
|
@ -439,20 +442,14 @@ in
|
||||||
description = "The architecture of the system to deploy to.";
|
description = "The architecture of the system to deploy to.";
|
||||||
type = types.str;
|
type = types.str;
|
||||||
};
|
};
|
||||||
inherit httpBackend nixos-configuration;
|
inherit
|
||||||
|
caller
|
||||||
|
args
|
||||||
|
deployment-name
|
||||||
|
httpBackend
|
||||||
|
nixos-configuration
|
||||||
|
;
|
||||||
ssh = host-ssh;
|
ssh = host-ssh;
|
||||||
caller = mkOption {
|
|
||||||
description = "The calling module to obtain the NixOS configuration from.";
|
|
||||||
type = types.str;
|
|
||||||
};
|
|
||||||
args = mkOption {
|
|
||||||
description = "The arguments with which to call the module to obtain the NixOS configuration.";
|
|
||||||
type = types.attrs;
|
|
||||||
};
|
|
||||||
deployment-name = mkOption {
|
|
||||||
description = "The name of the deployment for which to obtain the NixOS configuration.";
|
|
||||||
type = types.str;
|
|
||||||
};
|
|
||||||
root-path = mkOption {
|
root-path = mkOption {
|
||||||
description = "The path to the root of the repository.";
|
description = "The path to the root of the repository.";
|
||||||
type = types.path;
|
type = types.path;
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue