summary refs log tree commit diff
path: root/maintainers/scripts/hydra-eval-failures.py
diff options
context:
space:
mode:
authorDomen Kožar <domen@dev.si>2017-01-28 22:29:00 +0100
committerDomen Kožar <domen@dev.si>2017-01-28 22:29:15 +0100
commit4c22b9529b9a7ac13c50bbac3ca81e450297b998 (patch)
tree10792af1446bea7b4d55a2551c6e4c292b9d8c12 /maintainers/scripts/hydra-eval-failures.py
parent8a2956691a14498cd141e0f4fd1ab24e3170c038 (diff)
downloadnixpkgs-4c22b9529b9a7ac13c50bbac3ca81e450297b998.tar
nixpkgs-4c22b9529b9a7ac13c50bbac3ca81e450297b998.tar.gz
nixpkgs-4c22b9529b9a7ac13c50bbac3ca81e450297b998.tar.bz2
nixpkgs-4c22b9529b9a7ac13c50bbac3ca81e450297b998.tar.lz
nixpkgs-4c22b9529b9a7ac13c50bbac3ca81e450297b998.tar.xz
nixpkgs-4c22b9529b9a7ac13c50bbac3ca81e450297b998.tar.zst
nixpkgs-4c22b9529b9a7ac13c50bbac3ca81e450297b998.zip
Add a script to get failures for hydra eval /cc @globin
Diffstat (limited to 'maintainers/scripts/hydra-eval-failures.py')
-rwxr-xr-xmaintainers/scripts/hydra-eval-failures.py89
1 files changed, 89 insertions, 0 deletions
diff --git a/maintainers/scripts/hydra-eval-failures.py b/maintainers/scripts/hydra-eval-failures.py
new file mode 100755
index 00000000000..1b5df32c452
--- /dev/null
+++ b/maintainers/scripts/hydra-eval-failures.py
@@ -0,0 +1,89 @@
+#!/usr/bin/env nix-shell
+#!nix-shell -i python -p pythonFull pythonPackages.requests pythonPackages.pyquery pythonPackages.click
+
+# To use, just execute this script with --help to display help.
+
+import subprocess
+import json
+
+import click
+import requests
+from pyquery import PyQuery as pq
+
+
+maintainers_json = subprocess.check_output([
+    'nix-instantiate',
+    'lib/maintainers.nix',
+    '--eval',
+    '--json'])
+maintainers = json.loads(maintainers_json)
+MAINTAINERS = {v: k for k, v in maintainers.iteritems()}
+
+
+def get_response_text(url):
+    return pq(requests.get(url).text)  # IO
+
+EVAL_FILE = {
+    'nixos': 'nixos/release.nix',
+    'nixpkgs': 'pkgs/top-level/release.nix',
+}
+
+
+def get_maintainers(attr_name):
+    nixname = attr_name.split('.')
+    meta_json = subprocess.check_output([
+        'nix-instantiate',
+        '--eval',
+        '--strict',
+        '-A',
+        '.'.join(nixname[1:]) + '.meta',
+        EVAL_FILE[nixname[0]],
+        '--json'])
+    meta = json.loads(meta_json)
+    if meta.get('maintainers'):
+        return [MAINTAINERS[name] for name in meta['maintainers'] if MAINTAINERS.get(name)]
+
+
+@click.command()
+@click.option(
+    '--jobset',
+    default="nixos/release-16.09",
+    help='Hydra project like nixos/release-16.09')
+def cli(jobset):
+    """
+    Given a Hydra project, inspect latest evaluation
+    and print a summary of failed builds
+    """
+
+    url = "http://hydra.nixos.org/jobset/{}".format(jobset)
+
+    # get the last evaluation
+    click.echo(click.style(
+        'Getting latest evaluation for {}'.format(url), fg='green'))
+    d = get_response_text(url)
+    evaluations = d('#tabs-evaluations').find('a[class="row-link"]')
+    latest_eval_url = evaluations[0].get('href')
+
+    # parse last evaluation page
+    click.echo(click.style(
+        'Parsing evaluation {}'.format(latest_eval_url), fg='green'))
+    d = get_response_text(latest_eval_url + '?full=1')
+
+    # TODO: aborted evaluations
+    # TODO: dependency failed without propagated builds
+    for tr in d('img[alt="Failed"]').parents('tr'):
+        a = pq(tr)('a')[1]
+        print "- [ ] [{}]({})".format(a.text, a.get('href'))
+
+        maintainers = get_maintainers(a.text)
+        if maintainers:
+            print "  - maintainers: {}".format(", ".join(map(lambda u: '@' + u, maintainers)))
+        # TODO: print last three persons that touched this file
+        # TODO: pinpoint the diff that broke this build, or maybe it's transient or maybe it never worked?
+
+
+if __name__ == "__main__":
+    try:
+        cli()
+    except:
+        import pdb;pdb.post_mortem()