@icyphy/github-issue-junit

0.1.7 • Public • Published

Based on https://github.com/vitalets/github-trending-repos/ and a suggestion by @nebgnahz.

Read JUnit HTML output and add a comment to an open issue on GitHub.

This module hacks around the problem of running a Travis-CI job and wanting to notify users of failed tests.

This is a start on solving Handle Ant's JUnit XML formatted output from test/spec runs.

See https://github.com/icyphy/ptII-test/issues/1 for sample output.

To Do

  1. The contents of the JUnit html output file overview-summary.html is being parsed, which seems fragile.
  2. It might be good to list the tests that have failed.
  3. It might be good to notice if new tests have failed.

How to use

  1. Set up your Travis-ci job to run JUnit tests, save the output as xml and upload the test results to GitHub pages. See ptII/.travis.yml and ptII/bin/ptIITravisBuild.sh.

  2. In the gh-pages branch, run the ant junitreport target in frames format. See build.xml. The main thing is to create the JUnit HTML summary page at an accessible location.

  3. Create an issue in your GitHub repo that will be the issue that gets updated with the test results. See https://github.com/icyphy/ptII-test/issues/1

  4. Create a label for the issue that signifies that it will be updated, for example junit-results.

  5. Add the URL of the JUnit summary results page created by running the ant junitresults target, for example https://icyphy.github.io/ptII-test/reports/junit/html/overview-summary.html. This tool looks for issues with a specific label and searches for urls that matches a regular expression defined in scripts/config.js. So the issues need to ahve the appropriate label and the appropriate URL.

  6. In your environment, set the JUNIT_LABEL variable to the name of the label created above

export JUNIT_LABEL=junit-results
  1. In your environment, set GITHUB_ISSUE_JUNIT to the API URL of the repo containing the JUnit output:
export GITHUB_ISSUE_JUNIT=https://api.github.com/repos/icyphy/ptII-test
  1. Edit the regular expressions in scripts/helpers/issues.js. (FIXME: These should be environment varialbles)

  2. To update an issue from Travis-ci, get a GitHub token

  3. On GitHub, under your account on the upper right, click on Settings -> Developer Settings -> Personal access tokens -> Generate new token

  4. The new token should have public_repo status

  5. On Travis-ci, on your project page, click on More options -> Settings, then add the token from the step above as GITHUB_TOKEN

  6. For testing purposes, set the GITHUB_TOKEN environment variable on your local machine

  7. If necessary, update any other variables in scripts/config.js

  8. To test:

node ./scripts/junit-results.jso
  1. To actually upload the results to an issue:
export JUNIT_RESULTS_NOT_DRY_RUN=false
node ./scripts/junit-results.js
  1. To have Travis do the update, create a script:
#!/bin/bash

mkdir node_modules
npm install @icyphy/github-issue-junit
export JUNIT_LABEL=junit-results
export JUNIT_RESULTS_NOT_DRY_RUN=false
export GITHUB_ISSUE_JUNIT=https://api.github.com/repos/cxbrooks/travis-junit
(cd node_modules/@icyphy/github-issue-junit/scripts; node junit-results.js)

How to clean results that are older than 30 days

  1. Follow steps 1 - 7 above

  2. To test

node ./scripts/issue-cleaner.js
  1. To actually upload the results to an issue:
export JUNIT_RESULTS_NOT_DRY_RUN=false
node ./scripts/issue-cleaner.js

How to publish updates to this module

  1. Update the patch number in package.json

  2. Login to npm npm login

    Username: icyphy-npm
    Password: See https://wiki.eecs.berkeley.edu/ptolemy/Ptolemy/Accounts or passwords/icyphy-npm in the  https://repo.eecs.berkeley.edu/git/projects/ealprivi/ealprivi.git repo.
    Email: icyphy-npm@icyphy.org
    
  3. Publish: npm publish --access public

Readme

Keywords

none

Package Sidebar

Install

npm i @icyphy/github-issue-junit

Weekly Downloads

1

Version

0.1.7

License

MIT

Unpacked Size

176 kB

Total Files

25

Last publish

Collaborators

  • cxbrooks
  • icyphy-npm