nixosTests.docker-registry: migrate to runTest

Part of #386873
This commit is contained in:
Piotr Kwiecinski 2025-04-02 14:57:40 +02:00
parent 852f3beab8
commit cc69d51afb
No known key found for this signature in database
GPG key ID: EC0DE1CB9D5258B4
2 changed files with 61 additions and 64 deletions

View file

@ -371,7 +371,7 @@ in
doas = runTest ./doas.nix; doas = runTest ./doas.nix;
docker = runTestOn [ "aarch64-linux" "x86_64-linux" ] ./docker.nix; docker = runTestOn [ "aarch64-linux" "x86_64-linux" ] ./docker.nix;
docker-rootless = runTestOn [ "aarch64-linux" "x86_64-linux" ] ./docker-rootless.nix; docker-rootless = runTestOn [ "aarch64-linux" "x86_64-linux" ] ./docker-rootless.nix;
docker-registry = handleTest ./docker-registry.nix { }; docker-registry = runTest ./docker-registry.nix;
docker-tools = handleTestOn [ "x86_64-linux" ] ./docker-tools.nix { }; docker-tools = handleTestOn [ "x86_64-linux" ] ./docker-tools.nix { };
docker-tools-nix-shell = runTest ./docker-tools-nix-shell.nix; docker-tools-nix-shell = runTest ./docker-tools-nix-shell.nix;
docker-tools-cross = handleTestOn [ "x86_64-linux" "aarch64-linux" ] ./docker-tools-cross.nix { }; docker-tools-cross = handleTestOn [ "x86_64-linux" "aarch64-linux" ] ./docker-tools-cross.nix { };

View file

@ -1,74 +1,71 @@
# This test runs docker-registry and check if it works # This test runs docker-registry and check if it works
{ pkgs, ... }:
{
name = "docker-registry";
meta = with pkgs.lib.maintainers; {
maintainers = [
globin
ironpinguin
cafkafk
];
};
import ./make-test-python.nix ( nodes = {
{ pkgs, ... }: registry =
{ { ... }:
name = "docker-registry"; {
meta = with pkgs.lib.maintainers; { services.dockerRegistry.enable = true;
maintainers = [ services.dockerRegistry.enableDelete = true;
globin services.dockerRegistry.port = 8080;
ironpinguin services.dockerRegistry.listenAddress = "0.0.0.0";
cafkafk services.dockerRegistry.enableGarbageCollect = true;
]; services.dockerRegistry.openFirewall = true;
}; };
nodes = { client1 =
registry = { ... }:
{ ... }: {
{ virtualisation.docker.enable = true;
services.dockerRegistry.enable = true; virtualisation.docker.extraOptions = "--insecure-registry registry:8080";
services.dockerRegistry.enableDelete = true; };
services.dockerRegistry.port = 8080;
services.dockerRegistry.listenAddress = "0.0.0.0";
services.dockerRegistry.enableGarbageCollect = true;
services.dockerRegistry.openFirewall = true;
};
client1 = client2 =
{ ... }: { ... }:
{ {
virtualisation.docker.enable = true; virtualisation.docker.enable = true;
virtualisation.docker.extraOptions = "--insecure-registry registry:8080"; virtualisation.docker.extraOptions = "--insecure-registry registry:8080";
}; };
};
client2 = testScript = ''
{ ... }: client1.start()
{ client1.wait_for_unit("docker.service")
virtualisation.docker.enable = true; client1.succeed("tar cv --files-from /dev/null | docker import - scratch")
virtualisation.docker.extraOptions = "--insecure-registry registry:8080"; client1.succeed("docker tag scratch registry:8080/scratch")
};
};
testScript = '' registry.start()
client1.start() registry.wait_for_unit("docker-registry.service")
client1.wait_for_unit("docker.service") registry.wait_for_open_port(8080)
client1.succeed("tar cv --files-from /dev/null | docker import - scratch") client1.succeed("docker push registry:8080/scratch")
client1.succeed("docker tag scratch registry:8080/scratch")
registry.start() client2.start()
registry.wait_for_unit("docker-registry.service") client2.wait_for_unit("docker.service")
registry.wait_for_open_port(8080) client2.succeed("docker pull registry:8080/scratch")
client1.succeed("docker push registry:8080/scratch") client2.succeed("docker images | grep scratch")
client2.start() client2.succeed(
client2.wait_for_unit("docker.service") "curl -fsS -X DELETE registry:8080/v2/scratch/manifests/$(curl -fsS -I -H\"Accept: application/vnd.docker.distribution.manifest.v2+json\" registry:8080/v2/scratch/manifests/latest | grep Docker-Content-Digest | sed -e 's/Docker-Content-Digest: //' | tr -d '\\r')"
client2.succeed("docker pull registry:8080/scratch") )
client2.succeed("docker images | grep scratch")
client2.succeed( registry.systemctl("start docker-registry-garbage-collect.service")
"curl -fsS -X DELETE registry:8080/v2/scratch/manifests/$(curl -fsS -I -H\"Accept: application/vnd.docker.distribution.manifest.v2+json\" registry:8080/v2/scratch/manifests/latest | grep Docker-Content-Digest | sed -e 's/Docker-Content-Digest: //' | tr -d '\\r')" registry.wait_until_fails("systemctl status docker-registry-garbage-collect.service")
) registry.wait_for_unit("docker-registry.service")
registry.systemctl("start docker-registry-garbage-collect.service") registry.fail("ls -l /var/lib/docker-registry/docker/registry/v2/blobs/sha256/*/*/data")
registry.wait_until_fails("systemctl status docker-registry-garbage-collect.service")
registry.wait_for_unit("docker-registry.service")
registry.fail("ls -l /var/lib/docker-registry/docker/registry/v2/blobs/sha256/*/*/data") client1.succeed("docker push registry:8080/scratch")
registry.succeed(
client1.succeed("docker push registry:8080/scratch") "ls -l /var/lib/docker-registry/docker/registry/v2/blobs/sha256/*/*/data"
registry.succeed( )
"ls -l /var/lib/docker-registry/docker/registry/v2/blobs/sha256/*/*/data" '';
) }
'';
}
)