2016-04-05 16:52:55 +01:00
|
|
|
import ./make-test.nix {
|
|
|
|
name = "taskserver";
|
|
|
|
|
2016-04-11 11:03:16 +01:00
|
|
|
nodes = rec {
|
2016-04-05 16:52:55 +01:00
|
|
|
server = {
|
|
|
|
networking.firewall.enable = false;
|
|
|
|
services.taskserver.enable = true;
|
|
|
|
services.taskserver.server.host = "::";
|
|
|
|
services.taskserver.server.fqdn = "server";
|
|
|
|
services.taskserver.organisations = {
|
|
|
|
testOrganisation.users = [ "alice" "foo" ];
|
|
|
|
anotherOrganisation.users = [ "bob" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
client1 = { pkgs, ... }: {
|
|
|
|
networking.firewall.enable = false;
|
|
|
|
environment.systemPackages = [ pkgs.taskwarrior ];
|
|
|
|
users.users.alice.isNormalUser = true;
|
|
|
|
users.users.bob.isNormalUser = true;
|
|
|
|
users.users.foo.isNormalUser = true;
|
2016-04-11 11:03:16 +01:00
|
|
|
users.users.bar.isNormalUser = true;
|
2016-04-05 16:52:55 +01:00
|
|
|
};
|
|
|
|
|
2016-04-11 11:03:16 +01:00
|
|
|
client2 = client1;
|
2016-04-05 16:52:55 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
testScript = { nodes, ... }: let
|
|
|
|
cfg = nodes.server.config.services.taskserver;
|
|
|
|
portStr = toString cfg.server.port;
|
|
|
|
in ''
|
|
|
|
sub su ($$) {
|
|
|
|
my ($user, $cmd) = @_;
|
|
|
|
my $esc = $cmd =~ s/'/'\\${"'"}'/gr;
|
|
|
|
return "su - $user -c '$esc'";
|
|
|
|
}
|
|
|
|
|
|
|
|
sub setupClientsFor ($$) {
|
|
|
|
my ($org, $user) = @_;
|
|
|
|
|
|
|
|
for my $client ($client1, $client2) {
|
|
|
|
$client->nest("initialize client for user $user", sub {
|
|
|
|
$client->succeed(
|
|
|
|
su $user, "task rc.confirmation=no config confirmation no"
|
|
|
|
);
|
|
|
|
|
|
|
|
my $exportinfo = $server->succeed(
|
2016-04-05 17:40:15 +01:00
|
|
|
"nixos-taskserver export-user $org $user"
|
2016-04-05 16:52:55 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
$exportinfo =~ s/'/'\\'''/g;
|
|
|
|
|
|
|
|
$client->succeed(su $user, "eval '$exportinfo' >&2");
|
|
|
|
$client->succeed(su $user,
|
|
|
|
"task config taskd.server server:${portStr} >&2"
|
|
|
|
);
|
|
|
|
|
|
|
|
$client->succeed(su $user, "task sync init >&2");
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-11 11:03:16 +01:00
|
|
|
sub testSync ($) {
|
|
|
|
my $user = $_[0];
|
|
|
|
subtest "sync for user $user", sub {
|
|
|
|
$client1->succeed(su $user, "task add foo >&2");
|
|
|
|
$client1->succeed(su $user, "task sync >&2");
|
|
|
|
$client2->fail(su $user, "task list >&2");
|
|
|
|
$client2->succeed(su $user, "task sync >&2");
|
|
|
|
$client2->succeed(su $user, "task list >&2");
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2016-04-05 16:52:55 +01:00
|
|
|
startAll;
|
|
|
|
|
|
|
|
$server->waitForUnit("taskserver.service");
|
|
|
|
|
|
|
|
$server->succeed(
|
2016-04-05 17:40:15 +01:00
|
|
|
"nixos-taskserver list-users testOrganisation | grep -qxF alice",
|
|
|
|
"nixos-taskserver list-users testOrganisation | grep -qxF foo",
|
|
|
|
"nixos-taskserver list-users anotherOrganisation | grep -qxF bob"
|
2016-04-05 16:52:55 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
$server->waitForOpenPort(${portStr});
|
|
|
|
|
|
|
|
$client1->waitForUnit("multi-user.target");
|
|
|
|
$client2->waitForUnit("multi-user.target");
|
|
|
|
|
|
|
|
setupClientsFor "testOrganisation", "alice";
|
|
|
|
setupClientsFor "testOrganisation", "foo";
|
|
|
|
setupClientsFor "anotherOrganisation", "bob";
|
|
|
|
|
2016-04-11 11:03:16 +01:00
|
|
|
testSync $_ for ("alice", "bob", "foo");
|
|
|
|
|
|
|
|
$server->fail("nixos-taskserver add-user imperativeOrg bar");
|
|
|
|
$server->succeed(
|
|
|
|
"nixos-taskserver add-org imperativeOrg",
|
|
|
|
"nixos-taskserver add-user imperativeOrg bar"
|
|
|
|
);
|
|
|
|
|
|
|
|
setupClientsFor "imperativeOrg", "bar";
|
|
|
|
|
|
|
|
testSync "bar";
|
2016-04-05 16:52:55 +01:00
|
|
|
'';
|
|
|
|
}
|