nixosTests.buildbot: Port to python

This commit is contained in:
Jacek Galowicz 2020-01-26 11:48:59 +01:00
parent 5de5d753ba
commit afc3d25824

View file

@ -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 ];
} } {}