Files
rosenpass/tests/packaging/deb.nix
2025-02-09 21:39:24 +07:00

45 lines
1.5 KiB
Nix

{ pkgs, rosenpass-deb }:
let
wg-deb = pkgs.fetchurl {
url = "http://ftp.de.debian.org/debian/pool/main/w/wireguard/wireguard-tools_1.0.20210914-1.1_amd64.deb";
hash = "sha256-s/hCUisQLR19kEbV6d8JXzzTAWUPM+NV0APgHizRGA4=";
};
pkgsDir = pkgs.runCommand "packages" {} ''
mkdir $out
cp ${rosenpass-deb} $out/rosenpass.deb
cp ${wg-deb} $out/wireguard.deb
cp ${./prepare-test.sh} $out/prepare-test.sh
'';
testAttrs = {
sharedDirs.share = {
source = pkgsDir;
target = "/mnt/share";
};
testScript = ''
vm.wait_for_unit("multi-user.target")
vm.succeed("dpkg --install /mnt/share/wireguard.deb")
vm.succeed("dpkg --install /mnt/share/rosenpass.deb")
vm.succeed("bash /mnt/share/prepare-test.sh")
vm.succeed(f"systemctl start rp@server")
vm.succeed(f"systemctl start rp@client")
vm.wait_for_unit("rp@server.service")
vm.wait_for_unit("rp@client.service")
vm.wait_until_succeeds("wg show all preshared-keys | grep --invert-match none", timeout=5);
psk_server = vm.succeed("wg show rp-server preshared-keys").strip().split()[-1]
psk_client = vm.succeed("wg show rp-client preshared-keys").strip().split()[-1]
assert psk_server == psk_client, "preshared-key exchange must be successful"
'';
};
in
{
debian-13 = (pkgs.testers.legacyDistros.debian."13" testAttrs).sandboxed;
ubuntu-23_10 = (pkgs.testers.legacyDistros.ubuntu."23_10" testAttrs).sandboxed;
}