I decided to not maintain this project any longer. I have not been using this project myself for a while now, which makes it difficult to provide the necessary support and maintenance it requires. Nevertheless, I will leave the project on github in case anybody wants to fork and continue.
Gnome 3 Shell Extension to represent the current state of all jobs of a Jenkins CI Server. By default it monitors a local Jenkins instance by using its JSON API at http://localhost:8080/api/json. This is the default URL when installing jenkins on Ubuntu 12.04 using apt-get. See "configuration" for details on how to customize this for your needs. Feel free to mail me any problems, suggestions or feedback to mail@philipphoffmann.de :-)
- Gnome 3.4.x
- Jenkins CI Server (with json api publicly available, see configuration)
Jenkins Indicator is publicly available on extensions.gnome.org. You can conveniently install it like any other Gnome 3 extension in the library.
-
Copy all files to
~/.local/share/gnome-shell/extensions/jenkins-indicator@philipphoffmann.de
-
Assuming that you have the gnome shell running hit Alt+F2, type
r
orrestart
(without the ticks), hit enter. The shell should now restart.
If everything is set up correctly you should be able to click the extension icon to bring up a popup menu with all your Jenkins jobs.
You can configure the extension using the regular extension settings dialog either by clicking settings in the extension popup menu or by running gnome-shell-extension-prefs
and selection the Jenkins CI Server Indicator in the drop down menu.
Each tab holds the settings for one Jenkins CI Server.
You can add more servers by clicking add server.
There is a little X button on the tabs to remove the server.
Each server you configure will be represented with its own indicator in the status panel.
You can configure the following settings:
Set this value to whatever you want. This value is only used in the popup menu and notifications. You should provide a name thats useful to you.
Set its value to your Jenkins web frontend URL. If you have views defined for your Jenkins dashboard you can also put in the URL of the view here.
You can check if the JSON API is available in your web browser by appending /api/json
to your web frontend URL (which is what the extension does to get its information).
Enable authentication if your Jenkins CI Server instance uses authentication.
Provide a username you want the extension to use to login to your Jenkins CI Server instance if authentication is enabled.
Every Jenkins CI Server user has an API token. This is used for querying the Jenkins CI Server API instead of the users password. You can get the API token from the Jenkins CI Server Web Frontend. Go to the users preferences and click "Show API token".
You can enable the "Green Balls Plugin" in this section which enables using green ball icons instead of blue ones, just like the green balls plugin in Jenkins (Thanks to negesti for this contribution).
By default the extension automatically requests the Jenkins CI Server for the state of all jobs at a given interval. You can turn this feature off or on. You can also change the auto-refresh interval that the extensions uses to track changes. It is set to 3 seconds by default, meaning that every 3 seconds the extension requests the Jenkins CI Server for the current state of all jobs. You can set this to whatever interval is fine for you.
Notifications will appear as little popup messages at the bottom of the screen as soon as a job finished building. You can disable this if you dont like it. "stack notifications" means that notifications will be stored in the bottom right corner until you read them (click the notification to make it disappear). Please be aware that the extension checks your Jenkins CI Server only at the provided auto-refresh interval. If the build time for a job is shorter than the auto-refresh interval the extension will most likely not notice finished builds.
There is a filter for each job state. Enabling the switch will show the matching jobs in the popup menu, disabling the switch will hide those jobs. You can also filter jobs by their name. Providing "all" or ".*" will show you all jobs. You can use a regular expression to match the name also. To filter your jobs by name you have to provide a comma-separated list of the expressions that match the jobs you want to appear in the popup menu. You can negate a pattern prepending the char ! to it.
Let's see an example:
my_job,.*thisisimportant,!.*thisisnot.*
This will match the job named "my_job", all the jobs that end with "thisisimportant", and all those jobs that do not have "thisisnot" in their names.
Feel free to contribute your ideas to the project. Please run the test suite before submitting any pull request by running
gjs lib/gjsunit.js
from the project directory.
Thanks to the following contributors for their valuable feedback:
- negesti (Green Balls Plugin)
- fchaillou (Gnome 3.6 compatibility and job name filter)
- david-caro (Job name filter regexps)