forked from mirrors/nixpkgs
1759825b34
These commands shouldn't have to be here in the first place as ecryptfs homes should be automatically unmounted during logoff.
82 lines
2.6 KiB
Nix
82 lines
2.6 KiB
Nix
import ./make-test.nix ({ pkgs, ... }:
|
|
{
|
|
name = "ecryptfs";
|
|
|
|
machine = { config, pkgs, ... }: {
|
|
imports = [ ./common/user-account.nix ];
|
|
boot.kernelModules = [ "ecryptfs" ];
|
|
security.pam.enableEcryptfs = true;
|
|
environment.systemPackages = with pkgs; [ keyutils ];
|
|
};
|
|
|
|
testScript = ''
|
|
$machine->waitForUnit("default.target");
|
|
|
|
# Set alice up with a password and a home
|
|
$machine->succeed("(echo foobar; echo foobar) | passwd alice");
|
|
$machine->succeed("chown -R alice.users ~alice");
|
|
|
|
# Migrate alice's home
|
|
my $out = $machine->succeed("echo foobar | ecryptfs-migrate-home -u alice");
|
|
$machine->log("ecryptfs-migrate-home said: $out");
|
|
|
|
# Log alice in (ecryptfs passwhrase is wrapped during first login)
|
|
$machine->sleep(2); # urgh: wait for username prompt
|
|
$machine->sendChars("alice\n");
|
|
$machine->sleep(1);
|
|
$machine->sendChars("foobar\n");
|
|
$machine->sleep(2);
|
|
$machine->sendChars("logout\n");
|
|
$machine->sleep(2);
|
|
|
|
# Why do I need to do this??
|
|
$machine->succeed("su alice -c ecryptfs-umount-private || true");
|
|
$machine->sleep(1);
|
|
$machine->fail("mount | grep ecryptfs"); # check that encrypted home is not mounted
|
|
|
|
# Show contents of the user keyring
|
|
my $out = $machine->succeed("su - alice -c 'keyctl list \@u'");
|
|
$machine->log("keyctl unlink said: " . $out);
|
|
|
|
# Log alice again
|
|
$machine->sendChars("alice\n");
|
|
$machine->sleep(1);
|
|
$machine->sendChars("foobar\n");
|
|
$machine->sleep(2);
|
|
|
|
# Create some files in encrypted home
|
|
$machine->succeed("su alice -c 'touch ~alice/a'");
|
|
$machine->succeed("su alice -c 'echo c > ~alice/b'");
|
|
|
|
# Logout
|
|
$machine->sendChars("logout\n");
|
|
$machine->sleep(2);
|
|
|
|
# Why do I need to do this??
|
|
$machine->succeed("su alice -c ecryptfs-umount-private || true");
|
|
$machine->sleep(1);
|
|
|
|
# Check that the filesystem is not accessible
|
|
$machine->fail("mount | grep ecryptfs");
|
|
$machine->succeed("su alice -c 'test \! -f ~alice/a'");
|
|
$machine->succeed("su alice -c 'test \! -f ~alice/b'");
|
|
|
|
# Log alice once more
|
|
$machine->sendChars("alice\n");
|
|
$machine->sleep(1);
|
|
$machine->sendChars("foobar\n");
|
|
$machine->sleep(2);
|
|
|
|
# Check that the files are there
|
|
$machine->sleep(1);
|
|
$machine->succeed("su alice -c 'test -f ~alice/a'");
|
|
$machine->succeed("su alice -c 'test -f ~alice/b'");
|
|
$machine->succeed(qq%test "\$(cat ~alice/b)" = "c"%);
|
|
|
|
# Catch https://github.com/NixOS/nixpkgs/issues/16766
|
|
$machine->succeed("su alice -c 'ls -lh ~alice/'");
|
|
|
|
$machine->sendChars("logout\n");
|
|
'';
|
|
})
|