nixos/tests/kubo: various improvements

Add new test to check if kubo.passthru.repoVersion is set correctly.
Also split the existing NixOS VM test into two independent parts. The test already used two independent VMs but just one testScript. This made experimenting with just one of the two VMs slower than it needed to be. It should also increase parallelism slightly since both test scripts can now run at the same time.

Luflosi cf8aa486 b8eebcad

Changed files
+66 -34
nixos
pkgs
applications
+1 -1
nixos/tests/all-tests.nix
···
ksm = handleTest ./ksm.nix {};
kthxbye = handleTest ./kthxbye.nix {};
kubernetes = handleTestOn ["x86_64-linux"] ./kubernetes {};
-
kubo = runTest ./kubo.nix;
+
kubo = import ./kubo { inherit recurseIntoAttrs runTest; };
ladybird = handleTest ./ladybird.nix {};
languagetool = handleTest ./languagetool.nix {};
latestKernel.login = handleTest ./login.nix { latestKernel = true; };
-32
nixos/tests/kubo.nix nixos/tests/kubo/kubo.nix
···
};
};
-
nodes.fuse = { config, ... }: {
-
services.kubo = {
-
enable = true;
-
autoMount = true;
-
};
-
users.users.alice = {
-
isNormalUser = true;
-
extraGroups = [ config.services.kubo.group ];
-
};
-
users.users.bob = {
-
isNormalUser = true;
-
};
-
};
-
testScript = ''
start_all()
···
with subtest("Setting dataDir works properly with the hardened systemd unit"):
machine.succeed("test -e /mnt/ipfs/config")
machine.succeed("test ! -e /var/lib/ipfs/")
-
-
with subtest("FUSE mountpoint"):
-
fuse.fail("echo a | su bob -l -c 'ipfs add --quieter'")
-
# The FUSE mount functionality is broken as of v0.13.0 and v0.17.0.
-
# See https://github.com/ipfs/kubo/issues/9044.
-
# Workaround: using CID Version 1 avoids that.
-
ipfs_hash = fuse.succeed(
-
"echo fnord3 | su alice -l -c 'ipfs add --quieter --cid-version=1'"
-
).strip()
-
-
fuse.succeed(f"cat /ipfs/{ipfs_hash} | grep fnord3")
-
-
with subtest("Unmounting of /ipns and /ipfs"):
-
# Force Kubo to crash and wait for it to restart
-
fuse.systemctl("kill --signal=SIGKILL ipfs.service")
-
fuse.wait_for_unit("ipfs.service", timeout = 30)
-
-
fuse.succeed(f"cat /ipfs/{ipfs_hash} | grep fnord3")
'';
}
+5
nixos/tests/kubo/default.nix
···
+
{ recurseIntoAttrs, runTest }:
+
recurseIntoAttrs {
+
kubo = runTest ./kubo.nix;
+
kubo-fuse = runTest ./kubo-fuse.nix;
+
}
+42
nixos/tests/kubo/kubo-fuse.nix
···
+
{ lib, ...} : {
+
name = "kubo-fuse";
+
meta = with lib.maintainers; {
+
maintainers = [ mguentner Luflosi ];
+
};
+
+
nodes.machine = { config, ... }: {
+
services.kubo = {
+
enable = true;
+
autoMount = true;
+
};
+
users.users.alice = {
+
isNormalUser = true;
+
extraGroups = [ config.services.kubo.group ];
+
};
+
users.users.bob = {
+
isNormalUser = true;
+
};
+
};
+
+
testScript = ''
+
start_all()
+
+
with subtest("FUSE mountpoint"):
+
machine.fail("echo a | su bob -l -c 'ipfs add --quieter'")
+
# The FUSE mount functionality is broken as of v0.13.0 and v0.17.0.
+
# See https://github.com/ipfs/kubo/issues/9044.
+
# Workaround: using CID Version 1 avoids that.
+
ipfs_hash = machine.succeed(
+
"echo fnord3 | su alice -l -c 'ipfs add --quieter --cid-version=1'"
+
).strip()
+
+
machine.succeed(f"cat /ipfs/{ipfs_hash} | grep fnord3")
+
+
with subtest("Unmounting of /ipns and /ipfs"):
+
# Force Kubo to crash and wait for it to restart
+
machine.systemctl("kill --signal=SIGKILL ipfs.service")
+
machine.wait_for_unit("ipfs.service", timeout = 30)
+
+
machine.succeed(f"cat /ipfs/{ipfs_hash} | grep fnord3")
+
'';
+
}
+5 -1
pkgs/applications/networking/kubo/default.nix
···
, buildGoModule
, fetchurl
, nixosTests
+
, callPackage
}:
buildGoModule rec {
···
subPackages = [ "cmd/ipfs" ];
-
passthru.tests.kubo = nixosTests.kubo;
+
passthru.tests = {
+
inherit (nixosTests) kubo;
+
repoVersion = callPackage ./test-repoVersion.nix {};
+
};
vendorHash = null;
+13
pkgs/applications/networking/kubo/test-repoVersion.nix
···
+
{ runCommand, kubo }:
+
+
runCommand "kubo-test-repoVersion" { } ''
+
export IPFS_PATH="$TMPDIR"
+
"${kubo}/bin/ipfs" init --empty-repo
+
declared_repo_version='${kubo.repoVersion}'
+
actual_repo_version="$(cat "$IPFS_PATH/version")"
+
if [ "$declared_repo_version" != "$actual_repo_version" ]; then
+
echo "kubo.repoVersion is not set correctly. It should be $actual_repo_version but is $declared_repo_version."
+
exit 1
+
fi
+
touch "$out"
+
''