Jenkins servers can be defined globally on the Administration page of Bitbucket Server or per project on the project settings page.
Base URL
should be the http/https root address to you jenkins serverServer Nickname
is a unique name for this server. This is used by job settings to choose which Bitbucket Server to run the job on.Default User
andDefault Token
are optional and used as a fall back authentication for triggering jobsBuild Token Root Plugin
uses an alternate address for triggering builds anonymously. Enable this only if you have the Build Token Root Plugin installed in JenkinsCSRF
if your Jenkins is CSRF protected, enable this option
Enable Parameterized Builds for Jenkins under the hooks settings for a repository.
You can add as many jobs as you want (within reason),
they will be triggered in the order they are added.
Job Name
is the name of the jenkins job to trigger. If the job is contained in a folder set the job name as folderName/job/jobName.Ref Type
will apply your triggers to either branch operations or tag operations- Multibranch Pipeline should only be used to trigger jenkins multibranch pipelines
- Triggers
Token
correspondes to the authorization token on your job configuration page in Jenkins- Build Parameters
Ref Filter
uses java regex syntax to only trigger a build for branches/tags that match the filter- the filter will only be used for branch/tag creation, branch pushes, and branch/tag deletion
- leave blank to match all branches
Monitored Paths
will only trigger a build if a file in the diff matches the filter- the filter will only be used for branch pushes and PR events
- leave blank to match all changes
Required Build Permission
will restrict who can trigger a Jenkins job using the repository permissions- This is only available on manual triggers
PR Destination Filter
functions identically toRef Filter
but on the branch being merged intoIgnore Committers
list of bitbucket user names separated by new line, Commits from any of these specified users will be ignored and will not trigger any builds- This is only available on push event triggers
Ignore Commits With String
If a commit message contains this configured string in it, that commit will be ignored and will not trigger any builds. Uses java regex syntax- This is only available on push event triggers
On your user account page you can add your Jenkins API token.
When added bitbucket server will use your Jenkins account
to trigger jobs for branches you create/push, pull requests you open, or for manual builds.
If you have multiple Jenkins servers setup you can set the api token for each one.
Order of authentication:
The Jenkins user Token
from the Jenkins User Settings will be used for authentation first.
If that is not set then the Token
parameter in the job configuration will be used second.
If that is not set then the Default User
and Default Token
on the Jenkins
server settings page will be used.
You can use any combination of triggers.
REF CREATED
- triggers a build for branch or tag creation events
- the branch or tag name must match the
Ref Filter
parameter (leave blank to match all)
PUSH EVENT
- triggers a build for branch push events to the repository (new branches do not count even if they contain new commits)
- the branch must match the
Ref Filter
parameter (leave blank to match all) - the files modified in the commits must match the
Monitored Paths
parameter (leave blank to match all)
MANUAL
REF DELETED
- triggers a build for branch or tag deletion events
- the branch or tag name must match the
Ref Filter
parameter (leave blank to match all)
AUTO MERGED
- triggers a build for automatic merge events
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
PR OPENED
- triggers a build for pull request creation events
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
PR REOPENED
- triggers a build if the pull request is re-opened
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
PR SOURCE RESCOPED
- triggers a build if changes are pushed to the source branch (e.g. "feature/yourfeature")
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
PR DEST RESCOPED
- triggers a build if changes are pushed to the destination branch (e.g. "master")
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
PR MERGED
- triggers a build for pull request merge events
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
PR DECLINED
- triggers a build for pull request declined events
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
PR DELETED
- triggers a build for pull request declined events
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
PR APPROVED
- triggers a build whenever a pull request is approved
- the files modified in the PR must match the
Monitored Paths
parameter (leave blank to match all)
branch=$BRANCH
environment=dev;test;prod
boolean=true
Build parameters can be specified using key=value pairs.
You can use predefined variables that will be replaced when the build is triggered.
For example branch=$BRANCH
will replace $BRANCH with the branch name that triggered the build.
Built-in variables:
- $BRANCH: the branch name or tag name that triggered the build (without refs/heads/ or refs/tags/)
- $COMMIT: the commit hash that triggered the build
- $REPOSITORY: the repository slug
- $PROJECT: the project key
- $TRIGGER: the trigger that triggered the build
- PR-specific variables (only availably when using a 'PR' prefixed trigger)
- $PRID: bitbucket id of the PR
- $PRDESTINATION: name of the destination branch in the PR
- $PRTITLE: title of the PR
- $PRDESCRIPTION: description of the PR (may be empty)
- $PRAUTHOR: display name of the author of the PR
- $PREMAIL: display email address of the author of the PR
- $PRURL: bitbucket URL of the PR
- $PRSOURCEPROJECT: the project where the source branch of a PR resides (if not using a fork then this is the same as $PROJECT)
- $PRSOURCEREPOSITORY: the repository where the source branch of a PR resides (if not using a fork then this is the same as $REPOSITORY)
- $MERGECOMMIT: the commit hash of the commit on the destination branch caused by the PR merge. Only available to
PR MERGED
trigger
Parameter Types:
- string:
key=value
- choice:
key=option1;option2;option3
- when using the
MANUAL
trigger users will be prompted with a dropdown list of the choices - separate each choice with a semicolon
option1
will be the default for push events
- when using the
- boolean:
key=true
- when using the
MANUAL
trigger users will be prompted with a checkbox true
will be the default, usekey=false
to make false the default
- when using the
Jenkins Multibranch pipelines can be built directly or through scans. Therefore, if the Multibranch Pipeline checkbox is
selected, REF CREATED
, REF DELETED
, and PUSH EVENT
triggers will cause a scan while all others will trigger a build
for the given branch. Triggers still need to be selected like any other job.
- Pull requests should be opened against master
- Write unit tests for any changes you make
- A passing Travis CI build is required