GitXplorerGitXplorer
l

jenkins-dashboard

public
0 stars
9 forks
0 issues

Commits

List of commits on branch master.
Unverified
c549d2392449c27e739b8d3255eab2daf97f87bb

Removed old unused stuff

ffondasimone committed 9 years ago
Unverified
afdbb4d54f09dd76abaae85b8d1bd18b8830d49b

Readme, license, example conf

ffondasimone committed 9 years ago
Unverified
8916dd0834d197daf1ecdb8010ea6322e04519fb

* Getting configuration file through ajax

ffondasimone committed 9 years ago
Unverified
27dea73126a2d93a64de987f31b2fbfbe3ae83ff

Proper order or build jobs before index injection

ffondasimone committed 9 years ago
Unverified
8c374d4ad871511d697f8a0172edfe46b79edcaf

Configuration file, using that for debug, fixtures, auth, ws auth; new gulp target for fixtures; bump deps

ffondasimone committed 9 years ago
Unverified
c7e36e01e0c99bd81092dd8831d53a254267e52b

Ignoring conf file

ffondasimone committed 9 years ago

README

The README file for this repository.

A better Jenkins Dashboard

A simple client-server app to display in real time the status of your favourite jenkins jobs, get alerts when something goes wrong or fancy animated gifs when everything is good.

How does it work

The server app is a single caching point for every client, allowing for dozens of clients to get real time updates without having to flood the jenkins API.

When a job is running, the server will make sure to poll jenkins about it not more than once every 2 seconds, sharing the same result to all clients intersted. A view is updated, with the same mechanism, every 9 seconds. This means that you get to know that a job started in less than 10 seconds, and of its completion in less than 2.

Besides the thing working pretty nicely, the whole project started as a weekend-garage-hackaton-project, so the code might not be top notch! :P

What does it show?

All of the jobs belonging to the configured views, sorted by name or last build time, or running first, broken second then everything else.

If all of the jobs are green, the background will be green. If any of the jobs is either yellow or red (in jenkins terms), the background will be red. FIX THEM!

If a job fails, you can receive a message telling you what is broken and who broke it. The dashboard can tell it to you with a configured accent! Or show a message. Or both.

When everything is green, you will be able to enjoy your well deserved configured screen saver.

Install it

You will need some node/npm (brew, http://nodejs.org/, whatever) stuff installed. Then run:

  • npm install

Configure it

Create jd.conf.json (eg by copying the given -dist file), and configure:

  • jenkinsURL the jenkins installation URL
  • serverURL server part of the jenkins-dashboard, if run on localhost it's localhost:4001
  • jenkinsAuth requires a path to a plain text file with user:password informations to authenticato to jenkins with basic auth
  • wsAuth is the authentication for the websocket, atm only prezi's godauth is supported
  • debug activates some output to check what the server part is doing, useful
  • useFixtures makes the server part not query jenkins at all, but instead provides some fixtures for the client parts. Useful for development
  • pronunciationTable key-value pairs to have the vocal announcements speak better, or just different things

Create the configured auth file with username and password to query jenkins, in the format username:s0m3p4ssw0rd, if needed.

Run it locally / develop

There's a server part and a client part. Both are run through gulp with:

  • gulp

.. and both gets rerun/refreshed if you change the sources (live reload, live development).

Deploy it

You just need to run the server part (node server/server.js), keeping it up (with supervisord, forever.. whatever) and provide the HTML through apache or something. With apache you might want to use a RewriteRule ^ index.html [L], to allow HTML5 deep links. Also you need to provide the same jd.conf.json to both parts.

Hidden feature: list jobs running on machines with a given label

You need to manually enter the "label:labelName" in the view name URL part, eg: https://localhost:4000/label:jenkins_cool_label/runningTimestamp