Skip to content

jenkinsci/ez-templates-plugin

This branch is 118 commits ahead of, 1 commit behind JoelJ/ez-templates:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

6fd147d · Jun 28, 2023
Aug 16, 2020
Apr 15, 2022
Dec 29, 2018
May 1, 2022
Jul 1, 2016
Jun 28, 2023
Feb 26, 2013
Dec 29, 2018
Feb 25, 2021
Aug 16, 2020
Aug 16, 2020
Jul 1, 2016
Dec 29, 2018
Jul 1, 2016

Build Status

Allows you to use any job as a template for other jobs.

Using EZ-Templates

Creating a template

Any Jenkins job can be used as a template

  • Select Allow this job to be used as a template

A template can be a runnable job in its own right or be disabled and used only as a parent for "real" jobs. Image of template configuration

❗ WARNING: Templates have the capacity to magnify a bad decision so should never be used without an automated backup solution in place. ThinBackup plugin is a good candidate for this.

Using a template

Existing jobs

Any Jenkins job can inherit from a template of the same job type.

  • Select Use another job as a template and enter the template's name
  • Click Apply. When you open the job after this, you will see the configuration copied in from the template.

Image of implmentation configuration

❗ The same job type (e.g. Maven/Freestyle) is important.

New jobs

Choose New Item > Copy existing item and enter the template's name. The new job will be automatically created as an implementation.

Customising the implementation

Synchronisation happens whenever an implementation job or its template is saved. The implementation overwrites its config with that of the template, discarding any local changes.

Only configured items (see Advanced section) are retained.

❗ External edits are not monitored, users must manually Configure>Save after changing the raw config.xml.

Job Parameters

One of those is the Parameters section.

  • New parameters added to the template are added to the implementation
  • Old parameters not in the template are removed from the implementation
    • ❗ Renaming a template parameter counts as a removal and addition - it is not synched as a "rename" and you will lose any customisation.
  • Existing parameters are synchronised
    • The parameters' Default Values are retained by the implementation.
    • ❗ You cannot delete choices from a choice parameter, this would require a full remove/add of the property to reset the implementations.

Usecases

Not everything can be parameterised in a Jenkins job config. Here's a few sample uses

  • SCM Repository URL can be a param, allowing completely different projects to be built with the same template
    • Alternatively the param could simply the Git branch (e.g. master, feature)
  • Combined with NodeLabel plugin, implementations can specify build node requirements
    • e.g. Only build on Linux or boxes with IPv6
  • Parameterized Trigger and Conditional BuildStep plugins are the basis of many flexible configurations based on job parameters

About

A easy and seamless way to create and use templates in Jenkins.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 98.3%
  • Other 1.7%