{ lib, pkgs, ... }: # This needs to be a VM test because the FUSE kernel module can't be used inside of a derivation in the Nix sandbox. # This test also exercises the LZFSE support in darling-dmg. let # The last kitty release which is stored on an HFS+ filesystem inside the disk image test-dmg-file = pkgs.fetchurl { url = "https://github.com/kovidgoyal/kitty/releases/download/v0.17.4/kitty-0.17.4.dmg"; hash = "sha256-m+c5s8fFrgUc0xQNI196WplYBZq9+lNgems5haZUdvA="; }; in { name = "darling-dmg"; meta.maintainers = with lib.maintainers; [ Luflosi ]; nodes.machine = { }; testScript = '' start_all() machine.succeed("mkdir mount-point") machine.succeed("'${pkgs.darling-dmg}/bin/darling-dmg' '${test-dmg-file}' mount-point") # Crude way to verify the contents # Taken from https://stackoverflow.com/questions/545387/linux-compute-a-single-hash-for-a-given-folder-contents # This could be improved. It does not check symlinks for example. hash = machine.succeed(""" (find mount-point -type f -print0 | sort -z | xargs -0 sha256sum; \ find mount-point \( -type f -o -type d \) -print0 | sort -z | \ xargs -0 stat -c '%n %a') \ | sha256sum """).strip() assert hash == "00e61c2ef171093fbf194e420c17bb84bcdb823238d70eb46e375bab2427cc21 -", f"The disk image contents differ from what was expected (was {hash})" ''; }