nixosTests.buildbot: Port to python
This commit is contained in:
parent
5de5d753ba
commit
afc3d25824
|
@ -1,12 +1,11 @@
|
||||||
|
# Test ensures buildbot master comes up correctly and workers can connect
|
||||||
|
|
||||||
{ system ? builtins.currentSystem,
|
{ system ? builtins.currentSystem,
|
||||||
config ? {},
|
config ? {},
|
||||||
pkgs ? import ../.. { inherit system config; }
|
pkgs ? import ../.. { inherit system config; }
|
||||||
}:
|
}:
|
||||||
|
|
||||||
with import ../lib/testing.nix { inherit system pkgs; };
|
import ./make-test-python.nix {
|
||||||
|
|
||||||
# Test ensures buildbot master comes up correctly and workers can connect
|
|
||||||
makeTest {
|
|
||||||
name = "buildbot";
|
name = "buildbot";
|
||||||
|
|
||||||
nodes = {
|
nodes = {
|
||||||
|
@ -39,75 +38,76 @@ makeTest {
|
||||||
services.openssh.enable = true;
|
services.openssh.enable = true;
|
||||||
networking.firewall.allowedTCPPorts = [ 22 9418 ];
|
networking.firewall.allowedTCPPorts = [ 22 9418 ];
|
||||||
environment.systemPackages = with pkgs; [ git ];
|
environment.systemPackages = with pkgs; [ git ];
|
||||||
|
systemd.services.git-daemon = {
|
||||||
|
description = "Git daemon for the test";
|
||||||
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
after = [ "network.target" ];
|
||||||
|
|
||||||
|
serviceConfig.Restart = "always";
|
||||||
|
path = with pkgs; [ coreutils git openssh ];
|
||||||
|
environment = { HOME = "/root"; };
|
||||||
|
preStart = ''
|
||||||
|
git config --global user.name 'Nobody Fakeuser'
|
||||||
|
git config --global user.email 'nobody\@fakerepo.com'
|
||||||
|
rm -rvf /srv/repos/fakerepo.git /tmp/fakerepo
|
||||||
|
mkdir -pv /srv/repos/fakerepo ~/.ssh
|
||||||
|
ssh-keyscan -H gitrepo > ~/.ssh/known_hosts
|
||||||
|
cat ~/.ssh/known_hosts
|
||||||
|
|
||||||
|
mkdir -p /src/repos/fakerepo
|
||||||
|
cd /srv/repos/fakerepo
|
||||||
|
rm -rf *
|
||||||
|
git init
|
||||||
|
echo -e '#!/bin/sh\necho fakerepo' > fakerepo.sh
|
||||||
|
cat fakerepo.sh
|
||||||
|
touch .git/git-daemon-export-ok
|
||||||
|
git add fakerepo.sh .git/git-daemon-export-ok
|
||||||
|
git commit -m fakerepo
|
||||||
|
'';
|
||||||
|
script = ''
|
||||||
|
git daemon --verbose --export-all --base-path=/srv/repos --reuseaddr
|
||||||
|
'';
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
testScript = ''
|
testScript = ''
|
||||||
#Start up and populate fake repo
|
gitrepo.wait_for_unit("git-daemon.service")
|
||||||
$gitrepo->waitForUnit("multi-user.target");
|
gitrepo.wait_for_unit("multi-user.target")
|
||||||
print($gitrepo->execute(" \
|
|
||||||
git config --global user.name 'Nobody Fakeuser' && \
|
|
||||||
git config --global user.email 'nobody\@fakerepo.com' && \
|
|
||||||
rm -rvf /srv/repos/fakerepo.git /tmp/fakerepo && \
|
|
||||||
mkdir -pv /srv/repos/fakerepo ~/.ssh && \
|
|
||||||
ssh-keyscan -H gitrepo > ~/.ssh/known_hosts && \
|
|
||||||
cat ~/.ssh/known_hosts && \
|
|
||||||
cd /srv/repos/fakerepo && \
|
|
||||||
git init && \
|
|
||||||
echo -e '#!/bin/sh\necho fakerepo' > fakerepo.sh && \
|
|
||||||
cat fakerepo.sh && \
|
|
||||||
touch .git/git-daemon-export-ok && \
|
|
||||||
git add fakerepo.sh .git/git-daemon-export-ok && \
|
|
||||||
git commit -m fakerepo && \
|
|
||||||
git daemon --verbose --export-all --base-path=/srv/repos --reuseaddr & \
|
|
||||||
"));
|
|
||||||
|
|
||||||
# Test gitrepo
|
with subtest("Repo is accessible via git daemon"):
|
||||||
$bbmaster->waitForUnit("network-online.target");
|
bbmaster.wait_for_unit("network-online.target")
|
||||||
#$bbmaster->execute("nc -z gitrepo 9418");
|
bbmaster.succeed("rm -rfv /tmp/fakerepo")
|
||||||
print($bbmaster->execute(" \
|
bbmaster.succeed("git clone git://gitrepo/fakerepo /tmp/fakerepo")
|
||||||
rm -rfv /tmp/fakerepo && \
|
|
||||||
git clone git://gitrepo/fakerepo /tmp/fakerepo && \
|
|
||||||
pwd && \
|
|
||||||
ls -la && \
|
|
||||||
ls -la /tmp/fakerepo \
|
|
||||||
"));
|
|
||||||
|
|
||||||
# Test start master and connect worker
|
with subtest("Master service and worker successfully connect"):
|
||||||
$bbmaster->waitForUnit("buildbot-master.service");
|
bbmaster.wait_for_unit("buildbot-master.service")
|
||||||
$bbmaster->waitUntilSucceeds("curl -s --head http://bbmaster:8010") =~ /200 OK/;
|
bbmaster.wait_until_succeeds("curl --fail -s --head http://bbmaster:8010")
|
||||||
$bbworker->waitForUnit("network-online.target");
|
bbworker.wait_for_unit("network-online.target")
|
||||||
$bbworker->execute("nc -z bbmaster 8010");
|
bbworker.succeed("nc -z bbmaster 8010")
|
||||||
$bbworker->execute("nc -z bbmaster 9989");
|
bbworker.succeed("nc -z bbmaster 9989")
|
||||||
$bbworker->waitForUnit("buildbot-worker.service");
|
bbworker.wait_for_unit("buildbot-worker.service")
|
||||||
print($bbworker->execute("ls -la /home/bbworker/worker"));
|
|
||||||
|
|
||||||
|
with subtest("Stop buildbot worker"):
|
||||||
|
bbmaster.succeed("systemctl -l --no-pager status buildbot-master")
|
||||||
|
bbmaster.succeed("systemctl stop buildbot-master")
|
||||||
|
bbworker.fail("nc -z bbmaster 8010")
|
||||||
|
bbworker.fail("nc -z bbmaster 9989")
|
||||||
|
bbworker.succeed("systemctl -l --no-pager status buildbot-worker")
|
||||||
|
bbworker.succeed("systemctl stop buildbot-worker")
|
||||||
|
|
||||||
# Test stop buildbot master and worker
|
with subtest("Buildbot daemon mode works"):
|
||||||
print($bbmaster->execute(" \
|
bbmaster.succeed(
|
||||||
systemctl -l --no-pager status buildbot-master && \
|
"buildbot create-master /tmp",
|
||||||
systemctl stop buildbot-master \
|
"mv -fv /tmp/master.cfg.sample /tmp/master.cfg",
|
||||||
"));
|
"sed -i 's/8010/8011/' /tmp/master.cfg",
|
||||||
$bbworker->fail("nc -z bbmaster 8010");
|
"buildbot start /tmp",
|
||||||
$bbworker->fail("nc -z bbmaster 9989");
|
"nc -z bbmaster 8011",
|
||||||
print($bbworker->execute(" \
|
)
|
||||||
systemctl -l --no-pager status buildbot-worker && \
|
bbworker.wait_until_succeeds("curl --fail -s --head http://bbmaster:8011")
|
||||||
systemctl stop buildbot-worker && \
|
bbmaster.wait_until_succeeds("buildbot stop /tmp")
|
||||||
ls -la /home/bbworker/worker \
|
bbworker.fail("nc -z bbmaster 8011")
|
||||||
"));
|
|
||||||
|
|
||||||
|
|
||||||
# Test buildbot daemon mode
|
|
||||||
$bbmaster->execute("buildbot create-master /tmp");
|
|
||||||
$bbmaster->execute("mv -fv /tmp/master.cfg.sample /tmp/master.cfg");
|
|
||||||
$bbmaster->execute("sed -i 's/8010/8011/' /tmp/master.cfg");
|
|
||||||
$bbmaster->execute("buildbot start /tmp");
|
|
||||||
$bbworker->execute("nc -z bbmaster 8011");
|
|
||||||
$bbworker->waitUntilSucceeds("curl -s --head http://bbmaster:8011") =~ /200 OK/;
|
|
||||||
$bbmaster->execute("buildbot stop /tmp");
|
|
||||||
$bbworker->fail("nc -z bbmaster 8011");
|
|
||||||
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
meta.maintainers = with pkgs.stdenv.lib.maintainers; [ nand0p ];
|
meta.maintainers = with pkgs.stdenv.lib.maintainers; [ nand0p ];
|
||||||
}
|
} {}
|
||||||
|
|
Loading…
Reference in New Issue