1
0
forked from clan/clan-core

new-clan: update template and add test

This commit is contained in:
DavHau 2023-09-02 16:12:37 +02:00
parent 1eed74c94f
commit 414033392e
2 changed files with 32 additions and 5 deletions

View File

@ -1,5 +1,5 @@
{ self, ... }: {
perSystem = { pkgs, lib, ... }:
perSystem = { pkgs, lib, self', ... }:
let
impureChecks = {
check-clan-template = pkgs.writeShellScriptBin "check-clan-template" ''
@ -9,6 +9,8 @@
trap "${pkgs.coreutils}/bin/chmod -R +w '$TMPDIR'; ${pkgs.coreutils}/bin/rm -rf '$TMPDIR'" EXIT
export PATH="${lib.makeBinPath [
pkgs.gitMinimal
pkgs.gnugrep
pkgs.jq
pkgs.openssh
pkgs.nix
]}"
@ -18,8 +20,21 @@
echo initialize new clan
nix flake init -t ${self}#new-clan
echo override clan input to the current version
nix flake lock --override-input clan-core ${self}
nix flake lock --override-input nixpkgs ${self.inputs.nixpkgs}
echo ensure flake outputs can be listed
nix flake show
echo create a machine
${self'.packages.clan-cli}/bin/clan machines create machine1
echo check machine1 exists
${self'.packages.clan-cli}/bin/clan machines list | grep -q machine1
echo check machine1 appears in nixosConfigurations
nix flake show --json | jq '.nixosConfigurations' | grep -q machine1
'';
};
in

View File

@ -3,9 +3,21 @@
inputs.clan-core.url = "git+https://git.clan.lol/clan/clan-core";
outputs = { clan-core, ... }: {
nixosConfigurations = clan-core.lib.buildClan {
directory = ./.;
outputs = { clan-core, nixpkgs, ... }:
let
system = "x86_64-linux";
pkgs = nixpkgs.legacyPackages.x86_64-linux;
in
{
# all machines managed by cLAN
nixosConfigurations = clan-core.lib.buildClan {
directory = ./.;
};
# add the cLAN cli tool to the dev shell
devShells.${system}.default = pkgs.mkShell {
packages = [
clan-core.packages.${system}.clan-cli
];
};
};
};
}