Merge pull request #17645 from grahamc/gocd-improve
gocd-agent: 16.7.0 startup fixes + test improvements
This commit is contained in:
commit
f191b65820
@ -57,18 +57,10 @@ in {
|
|||||||
};
|
};
|
||||||
|
|
||||||
goServer = mkOption {
|
goServer = mkOption {
|
||||||
default = "127.0.0.1";
|
default = "https://127.0.0.1:8154/go";
|
||||||
type = types.str;
|
type = types.str;
|
||||||
description = ''
|
description = ''
|
||||||
Address of GoCD Server to attach the Go.CD Agent to.
|
URL of the GoCD Server to attach the Go.CD Agent to.
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
goServerPort = mkOption {
|
|
||||||
default = 8153;
|
|
||||||
type = types.int;
|
|
||||||
description = ''
|
|
||||||
Port that Go.CD Server is Listening on.
|
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -199,13 +191,14 @@ in {
|
|||||||
${pkgs.jre}/bin/java ${concatStringsSep " " cfg.startupOptions} \
|
${pkgs.jre}/bin/java ${concatStringsSep " " cfg.startupOptions} \
|
||||||
${concatStringsSep " " cfg.extraOptions} \
|
${concatStringsSep " " cfg.extraOptions} \
|
||||||
-jar ${pkgs.gocd-agent}/go-agent/agent-bootstrapper.jar \
|
-jar ${pkgs.gocd-agent}/go-agent/agent-bootstrapper.jar \
|
||||||
${cfg.goServer} \
|
-serverUrl ${cfg.goServer}
|
||||||
${toString cfg.goServerPort}
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
User = cfg.user;
|
User = cfg.user;
|
||||||
WorkingDirectory = cfg.workDir;
|
WorkingDirectory = cfg.workDir;
|
||||||
|
RestartSec = 30;
|
||||||
|
Restart = "on-failure";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
let
|
let
|
||||||
serverUrl = "localhost:8153/go/api/agents";
|
serverUrl = "localhost:8153/go/api/agents";
|
||||||
header = "Accept: application/vnd./go.cd/v2+json";
|
header = "Accept: application/vnd.go.cd.v2+json";
|
||||||
in
|
in
|
||||||
|
|
||||||
import ./make-test.nix ({ pkgs, ...} : {
|
import ./make-test.nix ({ pkgs, ...} : {
|
||||||
@ -15,26 +15,26 @@ import ./make-test.nix ({ pkgs, ...} : {
|
|||||||
maintainers = [ grahamc swarren83 ];
|
maintainers = [ grahamc swarren83 ];
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes = {
|
nodes = {
|
||||||
gocd_agent =
|
gocd_agent =
|
||||||
{ config, pkgs, ... }:
|
{ config, pkgs, ... }:
|
||||||
{
|
{
|
||||||
virtualisation.memorySize = 2048;
|
virtualisation.memorySize = 2048;
|
||||||
services.gocd-agent = {
|
services.gocd-agent = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
};
|
||||||
|
services.gocd-server = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
services.gocd-server = {
|
};
|
||||||
enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
testScript = ''
|
testScript = ''
|
||||||
startAll;
|
startAll;
|
||||||
$gocd_agent->waitForUnit("gocd-server");
|
$gocd_agent->waitForUnit("gocd-server");
|
||||||
$gocd_agent->waitForOpenPort("8153");
|
$gocd_agent->waitForOpenPort("8153");
|
||||||
$gocd_agent->waitForUnit("gocd-agent");
|
$gocd_agent->waitForUnit("gocd-agent");
|
||||||
$gocd_agent->waitUntilSucceeds("curl -s -f ${serverUrl} -H '${header}' | awk -F \" '/\"uuid\":\s\"[a-zA-Z0-9]{8}-[a-zA-Z0-9]{4}-[a-zA-Z0-9]{4}-[a-zA-Z0-9]{4}-[a-zA-Z0-9]{12}/ {print $4}'");
|
$gocd_agent->waitUntilSucceeds("curl ${serverUrl} -H '${header}' | ${pkgs.jq}/bin/jq -e ._embedded.agents[0].uuid");
|
||||||
$gocd_agent->waitUntilSucceeds("curl -s -f ${serverUrl} -H '${header}' | awk -F \" '/\"agent_state\":\s\"Idle\"/'");
|
$gocd_agent->succeed("curl ${serverUrl} -H '${header}' | ${pkgs.jq}/bin/jq -e ._embedded.agents[0].agent_state | grep -q Idle");
|
||||||
'';
|
'';
|
||||||
})
|
})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user