Configure Plugins with JCasC
data:image/s3,"s3://crabby-images/4fe8b/4fe8be1694c99faa870efa17a9153714b611328a" alt="Dheeraj Singh Jodha"
This blog post is for anyone interested to know how to configure a plugin using the Jenkins Configuration as a Code (JCasC) plugin, more specifically, this blog will guide you to get the YAML equivalent of a plugin’s configuration and use it to do some changes to the plugin without using the Jenkins UI.
If you’re a beginner at JCasC and want to learn more about it, you can head over to the following resources to understand JCasC better:
Brief Introduction to jenkins.yaml file
-
The
jenkins.yaml
file contains the configuration of the Jenkins instance in YAML format. The JCasC plugin refers to this file to configure the Jenkins instance. -
The default location of
jenkins.yaml
is$JENKINS_HOME/jenkins.yaml
, from where it can be fetched into the Jenkins server whenever you apply a new configuration. -
Download your
jenkins.yaml
file by going toManage Jenkins
>Configuration as Code
>Download Configuration
. -
Make sure this file is saved at location
$JENKINS_HOME/jenkins.yaml
. -
Let’s change the
systemMessage
field to:
data:image/s3,"s3://crabby-images/9de67/9de679d8923dd2da22f1ff983bc3318b2170ee0f" alt="Updating the jenkins.yaml file"
-
Reload the existing configuration to apply the system message change
-
Now, go back to the Dashboard and you can see the updated System Message on top:
data:image/s3,"s3://crabby-images/2c71e/2c71e8ee2173f8bd647fe7eaf8e6e0122d57edbb" alt="Viewing the changes"
-
This file will be used later to configure the plugin using JCasC.
Configure the plugin on the UI
-
For this demo, install the
View Job Filters
plugin. -
Let’s create a view by clicking on the
New View
option on the left side of the Dashboard. -
Give it a name (say, “testView”) and set its type to
List View
, and click on theOK
button.
data:image/s3,"s3://crabby-images/37e45/37e451be769ebb8b5873a6336289f0eeb86fac58" alt="Naming the View"
-
Now click on
Add Job Filter
to add any kind of filter, so let’s selectBuild Duration Filter
and fill the field with any value (say, "60" minutes),
data:image/s3,"s3://crabby-images/9457a/9457ab70cd567051cdf44dcc3bd45427be55f9ab" alt="Add Filters"
-
Click on
Apply
>Save
. -
To view the full configuration, check out your main
jenkins.yaml
configuration file, by clicking onManage Jenkins
>Configuration as Code
>View Configuration
-
Go to the
views
section in this YAML file to see details related to the view,
data:image/s3,"s3://crabby-images/80ae2/80ae221497a4a2c82647eeaa3118818d31de1e70" alt="YAML file on Jenkins UI"
Download the Configuration
-
Now that you have successfully configured your plugin by UI, let’s download the configuration by going to
Manage Jenkins
on the Dashboard, then click onConfiguration as Code
under "System Configuration". -
Now click on the
Download Configuration
button to save the configuration file locally.
data:image/s3,"s3://crabby-images/2e754/2e75440d7a7afbf74872589336e996f2d1c8dba9" alt="Download Configuration"
Update JCasC file locally
-
Add some changes in your downloaded copy of the
jenkins.yaml
file, to see those changes being automatically reflected on the UI. -
For demo purposes, let’s change the
name
to “YoutubeDemoView” and set thebuildDurationMinutes
as "55".
data:image/s3,"s3://crabby-images/96a94/96a94eef119dc8f4e0860e3a2e7b2d92d565f423" alt="YAML file on Text Editor"
-
Save the file.
Load the jenkins.yaml file on the Jenkins server
-
Now to reflect the local changes done in the
jenkins.yaml
file onto the Jenkins server, click on theReload existing configuration
button.
data:image/s3,"s3://crabby-images/22d85/22d851c9e4094830e4433a05fa451a22320a255a" alt="Apply New Configuration"
Verify the changes on the UI
-
Go back to the main page by clicking on the Jenkins logo on the top-left side.
-
And you will notice that the name of your view has been changed from "testView" to “YoutubeDemoView”,
-
And the field value of
Build Duration Filter
has been changed from "60" to “55”. -
These two are the exact changes that we did locally in our
jenkins.yaml
file.
data:image/s3,"s3://crabby-images/06f33/06f33b746480f1c14b77835ae503001059609b7c" alt="View Updated Changes"
Congratulations! You’ve successfully configured a plugin (“View Job Filter”) automatically with the help of the “Jenkins Configuration as Code” plugin! You can repeat the same process for other plugins as well.