2014-03-06 18:06:53 +00:00
|
|
|
# verifies:
|
|
|
|
# 1. jenkins service starts on master node
|
|
|
|
# 2. jenkins user can be extended on both master and slave
|
|
|
|
# 3. jenkins service not started on slave node
|
2021-05-29 17:17:36 +01:00
|
|
|
# 4. declarative jobs can be added and removed
|
2014-04-11 16:15:56 +01:00
|
|
|
|
2019-11-24 19:54:10 +00:00
|
|
|
import ./make-test-python.nix ({ pkgs, ...} : {
|
2014-06-28 15:04:49 +01:00
|
|
|
name = "jenkins";
|
2021-01-10 19:08:30 +00:00
|
|
|
meta = with pkgs.lib.maintainers; {
|
2019-02-22 15:14:13 +00:00
|
|
|
maintainers = [ bjornfor coconnor domenkozar eelco ];
|
2015-07-12 11:09:40 +01:00
|
|
|
};
|
2014-04-14 13:02:44 +01:00
|
|
|
|
2014-02-10 20:07:12 +00:00
|
|
|
nodes = {
|
2014-04-11 16:15:56 +01:00
|
|
|
|
|
|
|
master =
|
2018-07-20 21:56:59 +01:00
|
|
|
{ ... }:
|
2021-05-29 17:17:36 +01:00
|
|
|
{ services.jenkins = {
|
|
|
|
enable = true;
|
|
|
|
jobBuilder = {
|
|
|
|
enable = true;
|
|
|
|
nixJobs = [
|
|
|
|
{ job = {
|
|
|
|
name = "job-1";
|
|
|
|
builders = [
|
|
|
|
{ shell = ''
|
|
|
|
echo "Running job-1"
|
|
|
|
'';
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
{ job = {
|
|
|
|
name = "folder-1";
|
|
|
|
project-type = "folder";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
{ job = {
|
|
|
|
name = "folder-1/job-2";
|
|
|
|
builders = [
|
|
|
|
{ shell = ''
|
|
|
|
echo "Running job-2"
|
|
|
|
'';
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
specialisation.noJenkinsJobs.configuration = {
|
|
|
|
services.jenkins.jobBuilder.nixJobs = pkgs.lib.mkForce [];
|
|
|
|
};
|
2014-03-06 18:06:53 +00:00
|
|
|
|
|
|
|
# should have no effect
|
|
|
|
services.jenkinsSlave.enable = true;
|
|
|
|
|
2018-06-30 00:55:42 +01:00
|
|
|
users.users.jenkins.extraGroups = [ "users" ];
|
2014-09-05 14:50:55 +01:00
|
|
|
|
2015-02-10 15:49:47 +00:00
|
|
|
systemd.services.jenkins.serviceConfig.TimeoutStartSec = "6min";
|
2014-03-06 18:06:53 +00:00
|
|
|
};
|
2014-04-11 16:15:56 +01:00
|
|
|
|
|
|
|
slave =
|
2018-07-20 21:56:59 +01:00
|
|
|
{ ... }:
|
2014-04-11 16:15:56 +01:00
|
|
|
{ services.jenkinsSlave.enable = true;
|
2014-03-06 18:06:53 +00:00
|
|
|
|
2018-06-30 00:55:42 +01:00
|
|
|
users.users.jenkins.extraGroups = [ "users" ];
|
2014-02-10 20:07:12 +00:00
|
|
|
};
|
2014-04-11 16:15:56 +01:00
|
|
|
|
2014-02-10 20:07:12 +00:00
|
|
|
};
|
|
|
|
|
2021-05-29 17:17:36 +01:00
|
|
|
testScript = { nodes, ... }:
|
|
|
|
let
|
|
|
|
configWithoutJobs = "${nodes.master.config.system.build.toplevel}/specialisation/noJenkinsJobs";
|
|
|
|
jenkinsPort = nodes.master.config.services.jenkins.port;
|
|
|
|
jenkinsUrl = "http://localhost:${toString jenkinsPort}";
|
|
|
|
in ''
|
2019-11-24 19:54:10 +00:00
|
|
|
start_all()
|
2014-02-10 20:07:12 +00:00
|
|
|
|
2019-11-24 19:54:10 +00:00
|
|
|
master.wait_for_unit("jenkins")
|
2017-12-14 15:01:09 +00:00
|
|
|
|
2019-11-24 19:54:10 +00:00
|
|
|
assert "Authentication required" in master.succeed("curl http://localhost:8080")
|
2017-12-14 15:01:09 +00:00
|
|
|
|
2019-11-24 19:54:10 +00:00
|
|
|
for host in master, slave:
|
|
|
|
groups = host.succeed("sudo -u jenkins groups")
|
|
|
|
assert "jenkins" in groups
|
|
|
|
assert "users" in groups
|
2014-03-06 18:06:53 +00:00
|
|
|
|
2019-11-24 19:54:10 +00:00
|
|
|
slave.fail("systemctl is-enabled jenkins.service")
|
2021-05-29 17:17:36 +01:00
|
|
|
|
|
|
|
with subtest("jobs are declarative"):
|
|
|
|
# Check that jobs are created on disk.
|
|
|
|
master.wait_for_unit("jenkins-job-builder")
|
|
|
|
master.wait_until_fails("systemctl is-active jenkins-job-builder")
|
|
|
|
master.wait_until_succeeds("test -f /var/lib/jenkins/jobs/job-1/config.xml")
|
|
|
|
master.wait_until_succeeds("test -f /var/lib/jenkins/jobs/folder-1/config.xml")
|
|
|
|
master.wait_until_succeeds("test -f /var/lib/jenkins/jobs/folder-1/jobs/job-2/config.xml")
|
|
|
|
|
|
|
|
# Wait until jenkins is ready, reload configuration and verify it also
|
|
|
|
# sees the jobs.
|
|
|
|
master.succeed("curl --fail ${jenkinsUrl}/cli")
|
|
|
|
master.succeed("curl ${jenkinsUrl}/jnlpJars/jenkins-cli.jar -O")
|
|
|
|
master.succeed("${pkgs.jre}/bin/java -jar jenkins-cli.jar -s ${jenkinsUrl} -auth admin:$(cat /var/lib/jenkins/secrets/initialAdminPassword) reload-configuration")
|
|
|
|
out = master.succeed("${pkgs.jre}/bin/java -jar jenkins-cli.jar -s ${jenkinsUrl} -auth admin:$(cat /var/lib/jenkins/secrets/initialAdminPassword) list-jobs")
|
|
|
|
jobs = [x.strip() for x in out.splitlines()]
|
|
|
|
# Seeing jobs inside folders requires the Folders plugin
|
|
|
|
# (https://plugins.jenkins.io/cloudbees-folder/), which we don't have
|
|
|
|
# in this vanilla jenkins install, so limit ourself to non-folder jobs.
|
|
|
|
assert jobs == ['job-1'], f"jobs != ['job-1']: {jobs}"
|
|
|
|
|
|
|
|
master.succeed(
|
|
|
|
"${configWithoutJobs}/bin/switch-to-configuration test >&2"
|
|
|
|
)
|
|
|
|
|
|
|
|
# Check that jobs are removed from disk.
|
|
|
|
master.wait_for_unit("jenkins-job-builder")
|
|
|
|
master.wait_until_fails("systemctl is-active jenkins-job-builder")
|
|
|
|
master.wait_until_fails("test -f /var/lib/jenkins/jobs/job-1/config.xml")
|
|
|
|
master.wait_until_fails("test -f /var/lib/jenkins/jobs/folder-1/config.xml")
|
|
|
|
master.wait_until_fails("test -f /var/lib/jenkins/jobs/folder-1/jobs/job-2/config.xml")
|
|
|
|
|
|
|
|
# Reload jenkins' configuration and verify it also sees the jobs as removed.
|
|
|
|
master.succeed("${pkgs.jre}/bin/java -jar jenkins-cli.jar -s ${jenkinsUrl} -auth admin:$(cat /var/lib/jenkins/secrets/initialAdminPassword) reload-configuration")
|
|
|
|
out = master.succeed("${pkgs.jre}/bin/java -jar jenkins-cli.jar -s ${jenkinsUrl} -auth admin:$(cat /var/lib/jenkins/secrets/initialAdminPassword) list-jobs")
|
|
|
|
jobs = [x.strip() for x in out.splitlines()]
|
|
|
|
assert jobs == [], f"jobs != []: {jobs}"
|
2014-02-10 20:07:12 +00:00
|
|
|
'';
|
2017-12-14 15:01:09 +00:00
|
|
|
})
|