summary refs log tree commit diff
path: root/nixos/tests/buildbot.nix
diff options
context:
space:
mode:
authorFernando J Pando <fernando.pando@stelligent.com>2017-03-07 14:26:21 -0500
committerFernando J Pando <fernando.pando@stelligent.com>2017-04-21 10:32:36 -0400
commit4ac06ea6a13bf082791f1e3293528dc6c1b67841 (patch)
treef07a4401e9a129befd6e0e3b87bbeff8fda2f01d /nixos/tests/buildbot.nix
parent4c0098f1dc65bc664be941fb4290274eba703483 (diff)
downloadnixpkgs-4ac06ea6a13bf082791f1e3293528dc6c1b67841.tar
nixpkgs-4ac06ea6a13bf082791f1e3293528dc6c1b67841.tar.gz
nixpkgs-4ac06ea6a13bf082791f1e3293528dc6c1b67841.tar.bz2
nixpkgs-4ac06ea6a13bf082791f1e3293528dc6c1b67841.tar.lz
nixpkgs-4ac06ea6a13bf082791f1e3293528dc6c1b67841.tar.xz
nixpkgs-4ac06ea6a13bf082791f1e3293528dc6c1b67841.tar.zst
nixpkgs-4ac06ea6a13bf082791f1e3293528dc6c1b67841.zip
buildbot: 0.9.4 -> 0.9.5
- adds distro dependency
- buildbot nodaemon in service module
- fakerepo for module tests
- service module parameter fixup
- tested on nixos
- tested on darwin
Diffstat (limited to 'nixos/tests/buildbot.nix')
-rw-r--r--nixos/tests/buildbot.nix95
1 files changed, 80 insertions, 15 deletions
diff --git a/nixos/tests/buildbot.nix b/nixos/tests/buildbot.nix
index 13a162e6c6e..828846f17c8 100644
--- a/nixos/tests/buildbot.nix
+++ b/nixos/tests/buildbot.nix
@@ -4,18 +4,22 @@ import ./make-test.nix ({ pkgs, ... } : {
   name = "buildbot";
 
   nodes = {
-    bbmaster = { config, pkgs, nodes, ... }: {
+    bbmaster = { config, pkgs, ... }: {
       services.buildbot-master = {
         enable = true;
+        package = pkgs.buildbot-full;
+
+        # NOTE: use fake repo due to no internet in hydra ci
         factorySteps = [
-          "steps.Git(repourl='git://github.com/buildbot/pyflakes.git', mode='incremental')"
-          "steps.ShellCommand(command=['trial', 'pyflakes'])"
+          "steps.Git(repourl='git://gitrepo/fakerepo.git', mode='incremental')"
+          "steps.ShellCommand(command=['bash', 'fakerepo.sh'])"
         ];
         changeSource = [
-          "changes.GitPoller('git://github.com/buildbot/pyflakes.git', workdir='gitpoller-workdir', branch='master', pollinterval=300)"
+          "changes.GitPoller('git://gitrepo/fakerepo.git', workdir='gitpoller-workdir', branch='master', pollinterval=300)"
         ];
       };
-      networking.firewall.allowedTCPPorts = [ 8010 9989 ];
+      networking.firewall.allowedTCPPorts = [ 8010 8011 9989 ];
+      environment.systemPackages = with pkgs; [ git buildbot-full ];
     };
 
     bbworker = { config, pkgs, ... }: {
@@ -23,24 +27,85 @@ import ./make-test.nix ({ pkgs, ... } : {
         enable = true;
         masterUrl = "bbmaster:9989";
       };
+      environment.systemPackages = with pkgs; [ git buildbot-worker ];
+    };
+
+    gitrepo = { config, pkgs, ... }: {
+      services.openssh.enable = true;
+      networking.firewall.allowedTCPPorts = [ 22 9418 ];
+      environment.systemPackages = with pkgs; [ git ];
     };
   };
 
   testScript = ''
+    #Start up and populate fake repo
+    $gitrepo->waitForUnit("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
+    $bbmaster->waitForUnit("network-online.target");
+    #$bbmaster->execute("nc -z gitrepo 9418");
+    print($bbmaster->execute(" \
+      rm -rfv /tmp/fakerepo && \
+      git clone git://gitrepo/fakerepo /tmp/fakerepo && \
+      pwd && \
+      ls -la && \
+      ls -la /tmp/fakerepo \
+    "));
 
-    $bbmaster->waitForUnit("network.target");
-    $bbworker->waitForUnit("network.target");
+    # Test start master and connect worker
+    $bbmaster->waitForUnit("buildbot-master.service");
+    $bbmaster->waitUntilSucceeds("curl -s --head http://bbmaster:8010") =~ /200 OK/;
+    $bbworker->waitForUnit("network-online.target");
+    $bbworker->execute("nc -z bbmaster 8010");
+    $bbworker->execute("nc -z bbmaster 9989");
+    $bbworker->waitForUnit("buildbot-worker.service");
+    print($bbworker->execute("ls -la /home/bbworker/worker"));
 
-    # Additional tests to be added
-    #$bbmaster->waitForUnit("buildbot-master.service");
-    #$bbmaster->waitUntilSucceeds("curl -s --head http://bbmaster:8010") =~ /200 OK/ or die;
-    #$bbworker->waitForUnit("buildbot-worker.service");
-    #$bbworker->waitUntilSucceeds("tail -10 /home/bbworker/worker/twistd.log") =~ /success/ or die;
+
+    # Test stop buildbot master and worker
+    print($bbmaster->execute(" \
+      systemctl -l --no-pager status buildbot-master && \
+      systemctl stop buildbot-master \
+    "));
+    $bbworker->fail("nc -z bbmaster 8010");
+    $bbworker->fail("nc -z bbmaster 9989");
+    print($bbworker->execute(" \
+      systemctl -l --no-pager status buildbot-worker && \
+      systemctl stop buildbot-worker && \
+      ls -la /home/bbworker/worker \
+    "));
+
+
+    # Test buildbot daemon mode
+    # NOTE: daemon mode tests disabled due to broken PYTHONPATH child inheritence
+    #
+    #$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 = with pkgs.stdenv.lib.maintainers; {
-    maintainers = [ nand0p ];
-  };
+  meta.maintainers = with pkgs.stdenv.lib.maintainers; [ nand0p ];
 
 })