mu: add integration tests

This commit is contained in:
VojtechStep 2024-12-17 17:28:24 +01:00 committed by Robert Helgesson
parent 7349b01505
commit 8264bfe3a0
Failed to generate hash of commit
8 changed files with 156 additions and 3 deletions

View file

@ -55,14 +55,13 @@ in {
maildirOption = genCmdMaildir config.accounts.email.maildirBasePath; maildirOption = genCmdMaildir config.accounts.email.maildirBasePath;
dbLocation = config.xdg.cacheHome + "/mu"; dbLocation = config.xdg.cacheHome + "/mu";
muExe = getExe cfg.package; muExe = getExe cfg.package;
gawkExe = getExe pkgs.gawk;
in hm.dag.entryAfter [ "writeBoundary" ] '' in hm.dag.entryAfter [ "writeBoundary" ] ''
# If the database directory exists and registered personal addresses remain the same, # If the database directory exists and registered personal addresses remain the same,
# then `mu init` should NOT be run. # then `mu init` should NOT be run.
# In theory, mu is the only thing that creates that directory, and it is # In theory, mu is the only thing that creates that directory, and it is
# only created during the initial index. # only created during the initial index.
MU_SORTED_ADDRS=$((${muExe} info store | ${ MU_SORTED_ADDRS=$((${muExe} info store | ${gawkExe} '/personal-address/{print $4}' | LC_ALL=C sort | paste -sd ' ') || exit 0)
getExe pkgs.gawk
} '/personal-address/{print $4}' | LC_ALL=C sort | paste -sd ' ') || exit 0)
if [[ ! -d "${dbLocation}" || ! "$MU_SORTED_ADDRS" = "${ if [[ ! -d "${dbLocation}" || ! "$MU_SORTED_ADDRS" = "${
concatStringsSep " " sortedAddresses concatStringsSep " " sortedAddresses
}" ]]; then }" ]]; then

View file

@ -12,6 +12,7 @@ let
tests = { tests = {
home-with-symbols = runTest ./standalone/home-with-symbols.nix; home-with-symbols = runTest ./standalone/home-with-symbols.nix;
kitty = runTest ./standalone/kitty.nix; kitty = runTest ./standalone/kitty.nix;
mu = runTest ./standalone/mu;
nixos-basics = runTest ./nixos/basics.nix; nixos-basics = runTest ./nixos/basics.nix;
standalone-flake-basics = runTest ./standalone/flake-basics.nix; standalone-flake-basics = runTest ./standalone/flake-basics.nix;
standalone-standard-basics = runTest ./standalone/standard-basics.nix; standalone-standard-basics = runTest ./standalone/standard-basics.nix;

View file

@ -0,0 +1,5 @@
{ lib, ... }: {
imports = [ ./config-two-accounts.nix ];
accounts.email.accounts.example2.mu.enable = lib.mkForce false;
}

View file

@ -0,0 +1,9 @@
{
home.username = "alice";
home.homeDirectory = "/home/alice";
home.stateVersion = "24.11";
programs.mu.enable = true;
programs.home-manager.enable = true;
}

View file

@ -0,0 +1,9 @@
{
imports = [ ./config-no-accounts.nix ];
accounts.email.accounts.example = {
primary = true;
address = "alice@example.com";
mu.enable = true;
};
}

View file

@ -0,0 +1,5 @@
{
imports = [ ./config-one-account.nix ];
accounts.email.accounts.example.aliases = [ "alias@example.com" ];
}

View file

@ -0,0 +1,8 @@
{
imports = [ ./config-one-account.nix ];
accounts.email.accounts.example2 = {
address = "alice@example2.com";
mu.enable = true;
};
}

View file

@ -0,0 +1,117 @@
{ pkgs, ... }: {
name = "mu-store-init";
nodes.machine = { ... }: {
imports = [ "${pkgs.path}/nixos/modules/installer/cd-dvd/channel.nix" ];
virtualisation.memorySize = 2048;
users.users.alice = {
isNormalUser = true;
description = "Alice Foobar";
password = "foobar";
uid = 1000;
};
};
testScript = ''
start_all()
machine.wait_for_unit("network.target")
machine.wait_for_unit("multi-user.target")
home_manager = "${../../../..}"
home_config = "/home/alice/.config/home-manager"
def login_as_alice():
machine.wait_until_tty_matches("1", "login: ")
machine.send_chars("alice\n")
machine.wait_until_tty_matches("1", "Password: ")
machine.send_chars("foobar\n")
machine.wait_until_tty_matches("1", "alice\\@machine")
def logout_alice():
machine.send_chars("exit\n")
def alice_cmd(cmd):
return f"su -l alice --shell /bin/sh -c $'export XDG_RUNTIME_DIR=/run/user/$UID ; {cmd}'"
def succeed_as_alice(cmd):
return machine.succeed(alice_cmd(cmd))
def fail_as_alice(cmd):
return machine.fail(alice_cmd(cmd))
def switch_to(config):
succeed_as_alice(f"cp {home_config}/{config}.nix {home_config}/home.nix")
return succeed_as_alice("home-manager switch")
# succeed_as_alice(". /home/alice/.nix-profile/etc/profile.d/hm-session-vars.sh")
# Create a persistent login so that Alice has a systemd session.
login_as_alice()
# Set up a home-manager channel.
succeed_as_alice(" ; ".join([
"mkdir -p /home/alice/.nix-defexpr/channels",
f"ln -s {home_manager} /home/alice/.nix-defexpr/channels/home-manager"
]))
succeed_as_alice("nix-shell \"<home-manager>\" -A install")
succeed_as_alice(f"cp -t {home_config} ${./.}/config-*")
with subtest("Switch to empty profile"):
switch_to("config-no-accounts")
actual = succeed_as_alice("mu info store")
expected = "/home/alice/Maildir"
assert expected in actual, \
f"expected mu info store to contain {expected}, but got {actual}"
unexpected = "personal-address"
assert not unexpected in actual, \
f"expected mu info store not to contain {unexpected}, but got {actual}"
with subtest("Switch to profile with an account"):
switch_to("config-one-account")
actual = succeed_as_alice("mu info store")
expected = "alice@example.com"
assert expected in actual, \
f"expected mu info store to contain {expected}, but got {actual}"
with subtest("Switch to profile with two accounts"):
switch_to("config-two-accounts")
actual = succeed_as_alice("mu info store")
expected = "alice@example.com"
assert expected in actual, \
f"expected mu info store to contain {expected}, but got {actual}"
expected = "alice@example2.com"
assert expected in actual, \
f"expected mu info store to contain {expected}, but got {actual}"
with subtest("Switch back to profile with one account"):
switch_to("config-one-account")
actual = succeed_as_alice("mu info store")
expected = "alice@example.com"
assert expected in actual, \
f"expected mu info store to contain {expected}, but got {actual}"
unexpected = "alice@example2.com"
assert not unexpected in actual, \
f"expected mu info store not to contain {unexpected}, but got {actual}"
with subtest("Switch to profile with an alias"):
switch_to("config-one-alias")
actual = succeed_as_alice("mu info store")
expected = "alice@example.com"
assert expected in actual, \
f"expected mu info store to contain {expected}, but got {actual}"
expected = "alias@example.com"
assert expected in actual, \
f"expected mu info store to contain {expected}, but got {actual}"
with subtest("Switch to a profile with mu disabled for one account"):
switch_to("config-account-without-mu")
actual = succeed_as_alice("mu info store")
expected = "alice@example.com"
assert expected in actual, \
f"expected mu info store to contain {expected}, but got {actual}"
unexpected = "alice@example2.com"
assert not unexpected in actual, \
f"expected mu info store not to contain {unexpected}, but got {actual}"
'';
}