Try to match the subcommands to act more like the subcommands from the taskd binary and also add a subcommand to list groups. Signed-off-by: aszlig <aszlig@redmoonstudios.org>
		
			
				
	
	
		
			167 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
import ./make-test.nix {
 | 
						|
  name = "taskserver";
 | 
						|
 | 
						|
  nodes = rec {
 | 
						|
    server = {
 | 
						|
      services.taskserver.enable = true;
 | 
						|
      services.taskserver.listenHost = "::";
 | 
						|
      services.taskserver.fqdn = "server";
 | 
						|
      services.taskserver.organisations = {
 | 
						|
        testOrganisation.users = [ "alice" "foo" ];
 | 
						|
        anotherOrganisation.users = [ "bob" ];
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
    client1 = { pkgs, ... }: {
 | 
						|
      environment.systemPackages = [ pkgs.taskwarrior pkgs.gnutls ];
 | 
						|
      users.users.alice.isNormalUser = true;
 | 
						|
      users.users.bob.isNormalUser = true;
 | 
						|
      users.users.foo.isNormalUser = true;
 | 
						|
      users.users.bar.isNormalUser = true;
 | 
						|
    };
 | 
						|
 | 
						|
    client2 = client1;
 | 
						|
  };
 | 
						|
 | 
						|
  testScript = { nodes, ... }: let
 | 
						|
    cfg = nodes.server.config.services.taskserver;
 | 
						|
    portStr = toString cfg.listenPort;
 | 
						|
  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, "rm -rf /home/$user/.task"),
 | 
						|
            (su $user, "task rc.confirmation=no config confirmation no")
 | 
						|
          );
 | 
						|
 | 
						|
          my $exportinfo = $server->succeed(
 | 
						|
            "nixos-taskserver user export $org $user"
 | 
						|
          );
 | 
						|
 | 
						|
          $exportinfo =~ s/'/'\\'''/g;
 | 
						|
 | 
						|
          $client->nest("importing taskwarrior configuration", sub {
 | 
						|
            my $cmd = su $user, "eval '$exportinfo' >&2";
 | 
						|
            my ($status, $out) = $client->execute_($cmd);
 | 
						|
            if ($status != 0) {
 | 
						|
              $client->log("output: $out");
 | 
						|
              die "command `$cmd' did not succeed (exit code $status)\n";
 | 
						|
            }
 | 
						|
          });
 | 
						|
 | 
						|
          $client->succeed(su $user,
 | 
						|
            "task config taskd.server server:${portStr} >&2"
 | 
						|
          );
 | 
						|
 | 
						|
          $client->succeed(su $user, "task sync init >&2");
 | 
						|
        });
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
    sub restartServer {
 | 
						|
      $server->succeed("systemctl restart taskserver.service");
 | 
						|
      $server->waitForOpenPort(${portStr});
 | 
						|
    }
 | 
						|
 | 
						|
    sub readdImperativeUser {
 | 
						|
      $server->nest("(re-)add imperative user bar", sub {
 | 
						|
        $server->execute("nixos-taskserver org remove imperativeOrg");
 | 
						|
        $server->succeed(
 | 
						|
          "nixos-taskserver org add imperativeOrg",
 | 
						|
          "nixos-taskserver user add imperativeOrg bar"
 | 
						|
        );
 | 
						|
        setupClientsFor "imperativeOrg", "bar";
 | 
						|
      });
 | 
						|
    }
 | 
						|
 | 
						|
    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");
 | 
						|
      };
 | 
						|
    }
 | 
						|
 | 
						|
    sub checkClientCert ($) {
 | 
						|
      my $user = $_[0];
 | 
						|
      my $cmd = "gnutls-cli".
 | 
						|
        " --x509cafile=/home/$user/.task/keys/ca.cert".
 | 
						|
        " --x509keyfile=/home/$user/.task/keys/private.key".
 | 
						|
        " --x509certfile=/home/$user/.task/keys/public.cert".
 | 
						|
        " --port=${portStr} server < /dev/null";
 | 
						|
      return su $user, $cmd;
 | 
						|
    }
 | 
						|
 | 
						|
    startAll;
 | 
						|
 | 
						|
    $server->waitForUnit("taskserver.service");
 | 
						|
 | 
						|
    $server->succeed(
 | 
						|
      "nixos-taskserver user list testOrganisation | grep -qxF alice",
 | 
						|
      "nixos-taskserver user list testOrganisation | grep -qxF foo",
 | 
						|
      "nixos-taskserver user list anotherOrganisation | grep -qxF bob"
 | 
						|
    );
 | 
						|
 | 
						|
    $server->waitForOpenPort(${portStr});
 | 
						|
 | 
						|
    $client1->waitForUnit("multi-user.target");
 | 
						|
    $client2->waitForUnit("multi-user.target");
 | 
						|
 | 
						|
    setupClientsFor "testOrganisation", "alice";
 | 
						|
    setupClientsFor "testOrganisation", "foo";
 | 
						|
    setupClientsFor "anotherOrganisation", "bob";
 | 
						|
 | 
						|
    testSync $_ for ("alice", "bob", "foo");
 | 
						|
 | 
						|
    $server->fail("nixos-taskserver user add imperativeOrg bar");
 | 
						|
    readdImperativeUser;
 | 
						|
 | 
						|
    testSync "bar";
 | 
						|
 | 
						|
    subtest "checking certificate revocation of user bar", sub {
 | 
						|
      $client1->succeed(checkClientCert "bar");
 | 
						|
 | 
						|
      $server->succeed("nixos-taskserver user remove imperativeOrg bar");
 | 
						|
      restartServer;
 | 
						|
 | 
						|
      $client1->fail(checkClientCert "bar");
 | 
						|
 | 
						|
      $client1->succeed(su "bar", "task add destroy everything >&2");
 | 
						|
      $client1->fail(su "bar", "task sync >&2");
 | 
						|
    };
 | 
						|
 | 
						|
    readdImperativeUser;
 | 
						|
 | 
						|
    subtest "checking certificate revocation of org imperativeOrg", sub {
 | 
						|
      $client1->succeed(checkClientCert "bar");
 | 
						|
 | 
						|
      $server->succeed("nixos-taskserver org remove imperativeOrg");
 | 
						|
      restartServer;
 | 
						|
 | 
						|
      $client1->fail(checkClientCert "bar");
 | 
						|
 | 
						|
      $client1->succeed(su "bar", "task add destroy even more >&2");
 | 
						|
      $client1->fail(su "bar", "task sync >&2");
 | 
						|
    };
 | 
						|
 | 
						|
    readdImperativeUser;
 | 
						|
 | 
						|
    subtest "check whether declarative config overrides user bar", sub {
 | 
						|
      restartServer;
 | 
						|
      testSync "bar";
 | 
						|
    };
 | 
						|
  '';
 | 
						|
}
 |