mu: add integration tests
This commit is contained in:
parent
7349b01505
commit
8264bfe3a0
8 changed files with 156 additions and 3 deletions
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
{ lib, ... }: {
|
||||||
|
imports = [ ./config-two-accounts.nix ];
|
||||||
|
|
||||||
|
accounts.email.accounts.example2.mu.enable = lib.mkForce false;
|
||||||
|
}
|
9
tests/integration/standalone/mu/config-no-accounts.nix
Normal file
9
tests/integration/standalone/mu/config-no-accounts.nix
Normal 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;
|
||||||
|
}
|
9
tests/integration/standalone/mu/config-one-account.nix
Normal file
9
tests/integration/standalone/mu/config-one-account.nix
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
{
|
||||||
|
imports = [ ./config-no-accounts.nix ];
|
||||||
|
|
||||||
|
accounts.email.accounts.example = {
|
||||||
|
primary = true;
|
||||||
|
address = "alice@example.com";
|
||||||
|
mu.enable = true;
|
||||||
|
};
|
||||||
|
}
|
5
tests/integration/standalone/mu/config-one-alias.nix
Normal file
5
tests/integration/standalone/mu/config-one-alias.nix
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
imports = [ ./config-one-account.nix ];
|
||||||
|
|
||||||
|
accounts.email.accounts.example.aliases = [ "alias@example.com" ];
|
||||||
|
}
|
8
tests/integration/standalone/mu/config-two-accounts.nix
Normal file
8
tests/integration/standalone/mu/config-two-accounts.nix
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
imports = [ ./config-one-account.nix ];
|
||||||
|
|
||||||
|
accounts.email.accounts.example2 = {
|
||||||
|
address = "alice@example2.com";
|
||||||
|
mu.enable = true;
|
||||||
|
};
|
||||||
|
}
|
117
tests/integration/standalone/mu/default.nix
Normal file
117
tests/integration/standalone/mu/default.nix
Normal 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}"
|
||||||
|
'';
|
||||||
|
}
|
Loading…
Reference in a new issue