mirror of
https://github.com/nix-community/home-manager.git
synced 2025-12-05 16:41:04 +01:00
rclone: declarative mounts (#7060)
This commit is contained in:
parent
b022c9e3b8
commit
dbc90cc3ae
3 changed files with 245 additions and 13 deletions
|
|
@ -1,20 +1,36 @@
|
|||
{ pkgs, ... }:
|
||||
|
||||
let
|
||||
sshKeys = import "${pkgs.path}/nixos/tests/ssh-keys.nix" pkgs;
|
||||
|
||||
baseMachine = extend: {
|
||||
imports = [
|
||||
"${pkgs.path}/nixos/modules/installer/cd-dvd/channel.nix"
|
||||
extend
|
||||
];
|
||||
virtualisation.memorySize = 2048;
|
||||
users.users.alice = {
|
||||
isNormalUser = true;
|
||||
description = "Alice Foobar";
|
||||
password = "foobar";
|
||||
uid = 1000;
|
||||
};
|
||||
};
|
||||
in
|
||||
{
|
||||
name = "rclone";
|
||||
|
||||
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;
|
||||
};
|
||||
nodes = {
|
||||
machine = baseMachine { };
|
||||
|
||||
remote = baseMachine {
|
||||
services.openssh.enable = true;
|
||||
|
||||
users.users.alice.openssh.authorizedKeys.keys = [
|
||||
sshKeys.snakeOilEd25519PublicKey
|
||||
];
|
||||
};
|
||||
};
|
||||
|
||||
testScript = ''
|
||||
start_all()
|
||||
|
|
@ -36,8 +52,13 @@
|
|||
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(*cmds):
|
||||
return machine.succeed(*map(alice_cmd,cmds))
|
||||
def succeed_as_alice(*cmds, box=machine):
|
||||
return box.succeed(*map(alice_cmd,cmds))
|
||||
|
||||
def systemctl_succeed_as_alice(cmd):
|
||||
status, out = machine.systemctl(cmd, "alice")
|
||||
assert status == 0, f"failed to run systemctl {cmd}"
|
||||
return out
|
||||
|
||||
def fail_as_alice(*cmds):
|
||||
return machine.fail(*map(alice_cmd,cmds))
|
||||
|
|
@ -101,6 +122,65 @@
|
|||
|
||||
# TODO: verify correct activation order with the agenix and sops hm modules
|
||||
|
||||
remote.wait_for_unit("network.target")
|
||||
remote.wait_for_unit("multi-user.target")
|
||||
|
||||
with subtest("Mount a remote (sftp)"):
|
||||
# https://rclone.org/commands/rclone_mount/#vfs-directory-cache
|
||||
# Sending a SIGHUP evicts every dcache entry
|
||||
def clear_vfs_dcache():
|
||||
svc_name = "rclone-mount:.home.alice.files@alices-sftp-remote.service"
|
||||
succeed_as_alice(f"kill -s HUP $(systemctl --user show -p MainPID --value {svc_name})")
|
||||
succeed_as_alice(
|
||||
"sync",
|
||||
"sleep 5",
|
||||
box=remote
|
||||
)
|
||||
|
||||
succeed_as_alice(
|
||||
"mkdir -p /home/alice/.ssh",
|
||||
"install -m644 ${./mount.nix} /home/alice/.config/home-manager/test-remote.nix"
|
||||
)
|
||||
|
||||
actual = succeed_as_alice("home-manager switch")
|
||||
expected = "Activating createRcloneConfig"
|
||||
assert expected in actual, \
|
||||
f"expected home-manager switch to contain {expected}, but got {actual}"
|
||||
|
||||
# remote -> machine
|
||||
succeed_as_alice(
|
||||
"mkdir /home/alice/files",
|
||||
"touch /home/alice/files/test",
|
||||
"echo started > /home/alice/files/log",
|
||||
box=remote
|
||||
)
|
||||
|
||||
succeed_as_alice("ls /home/alice/remote-files/test")
|
||||
|
||||
test_log = succeed_as_alice("cat /home/alice/remote-files/log")
|
||||
expected = "started";
|
||||
assert expected in test_log, \
|
||||
f"Mounted file does not have expected contents. Expected {test_log} to contain \"{expected}\""
|
||||
|
||||
# machine -> remote
|
||||
succeed_as_alice(
|
||||
"touch /home/alice/remote-files/new-file",
|
||||
"echo testing this works both ways! >> /home/alice/remote-files/log",
|
||||
)
|
||||
|
||||
clear_vfs_dcache()
|
||||
|
||||
succeed_as_alice("ls /home/alice/files/new-file", box=remote)
|
||||
|
||||
test_log = succeed_as_alice("cat /home/alice/files/log", box=remote)
|
||||
expected = "testing this works both ways!"
|
||||
assert expected in test_log, \
|
||||
f"Mounted file does not have expected contents. Expected {test_log} to contain \"{expected}\""
|
||||
|
||||
expected = "started"
|
||||
assert expected in test_log, \
|
||||
f"Mounted file does not have expected contents. Expected {test_log} to contain \"{expected}\""
|
||||
|
||||
logout_alice()
|
||||
'';
|
||||
}
|
||||
|
|
|
|||
27
tests/integration/standalone/rclone/mount.nix
Normal file
27
tests/integration/standalone/rclone/mount.nix
Normal file
|
|
@ -0,0 +1,27 @@
|
|||
{ pkgs, lib, ... }:
|
||||
let
|
||||
sshKeys = import "${pkgs.path}/nixos/tests/ssh-keys.nix" pkgs;
|
||||
in
|
||||
{
|
||||
programs.rclone.remotes = {
|
||||
alices-sftp-remote = {
|
||||
config = {
|
||||
type = "sftp";
|
||||
host = "remote";
|
||||
user = "alice";
|
||||
# https://rclone.org/sftp/#ssh-authentication
|
||||
key_pem = lib.pipe sshKeys.snakeOilEd25519PrivateKey.text [
|
||||
lib.trim
|
||||
(lib.replaceStrings [ "\n" ] [ "\\n" ])
|
||||
];
|
||||
known_hosts = sshKeys.snakeOilEd25519PublicKey;
|
||||
};
|
||||
mounts = {
|
||||
"/home/alice/files" = {
|
||||
enable = true;
|
||||
mountPoint = "/home/alice/remote-files";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue