The plugin makes use of the Jenkins Credential store, making it easier to manage the Helix Versioning Engine connection for multiple Jenkins jobs. P4 Plugin credentials must be added to the 'Global' or a User defined domain, using one of the two supported plugin Credentials: 'Perforce Password Credential' or 'Perforce Ticket Credential'.
To add a Credential:
- Navigate to the Jenkins Credentials page (select 'Credentials' on the left hand side)
- Select 'Global credentials' (or add domain if needed)
- Select 'Add Credentials' from the left hand side
- Choose 'Perforce Password Credential' from the 'Kind' drop-down select
- Enter a Description e.g. local test server
- Enter the P4Port e.g. localhost:1666
- Enter a valid username and password
- Press the 'Test Connection' button (you should see Success)
- Click 'Save' to save.
The 'Perforce Ticket Credential' supports using a ticket file (such as the default P4TICKETS file) or a ticket value (returned by the command p4 login -p). If Ticket authentication is used for remote builds the Ticket must be valid for the remote host (either login on the remote host or use p4 login -a).
All P4 plugin Credential types support SSL for use on a Secured Helix Versioning Engine (P4D); to use just check the SSL box and provide the Trust fingerprint.
Perforce Helix Workspaces are configured on the Jenkin Job configuration page and support the following behaviours:
- Static
The Workspace specified must have been previously defined. The plugin user must either own the workspace or the spec should be unlocked allowing it to make edits. The Workspace View remains static, but Jenkins will update other fields such as the Workspace root and clobber option.
- Spec File
The Workspace configuration is loaded from a depot file containing a Client Workspace Spec (same output as p4 client -o and the Spec depot '.p4s' format). The name of the Workspace must match the name of the Client Workspace Spec.
- Manual
Allows the specified Workspace to be created (if it does not exist) or update the spec by setting the various options. Jenkins will fill out the Workspace root and may override the clobber option.
- Template & Stream
In this mode the Workspace View is generated using the specified template workspace or stream. The name of the Workspace is generated using the Workspace Name Format field and makes it an ideal choice for Matrix builds.
Many of the Workspace fields can include environment variables to help define their value. Take the 'Worksapce name' often I use:
jenkins-${NODE_NAME}-${JOB_NAME}
If the job is called 'foo' and built on a slave 'linux' it expands to:
jenkins-linux-foo
Jenkins provides a set of environment variable and you can also define your own. Here is a list of built in variables:
BUILD_NUMBER
- The current build number, such as "153"
BUILD_ID
- The current build id, such as "2005-08-22_23-59-59"
BUILD_DISPLAY_NAME
- The name of the current build, something like "#153".
JOB_NAME
- Name of the project of this build, such as "foo"
BUILD_TAG
- String of "jenkins-${JOB_NAME}-${BUILD_NUMBER}".
EXECUTOR_NUMBER
- The unique number that identifies the current executor.
NODE_NAME
- Name of the slave or "master".
NODE_LABELS
- Whitespace-separated list of labels that the node is assigned.
WORKSPACE
- Absolute path of the build as a workspace.
JENKINS_HOME
- Absolute path on the master node for Jenkins to store data.
JENKINS_URL
- URL of Jenkins, like http://server:port/jenkins/
BUILD_URL
- Full URL of this build, like http://server:port/jenkins/job/foo/15/
JOB_URL
- Full URL of this job, like http://server:port/jenkins/job/foo/
The plugin allows the use of environemnt vaiables in fields like the Workspace view and Stream path. For example:
//depot/main/proj/... //jenkins-${NODE_NAME}-${JOB_NAME}/...
or with a Matrix build you might have defined your own variables like ${OS}
. Remember they can be used anywhere in the mapping:
//depot/main/${JOB_NAME}/bin.${OS}/... //jenkins-${NODE_NAME}-${JOB_NAME}-${OS}/bin/${OS}/...
The plugin will populate the Jenkins workspace with the file revisions needed for the build. The way the workspace is populated is configured on the Jenkins Job configuration page and support the following behaviours:
- Automatic cleanup and sync
The plugin will revert any shelved or pending files from the workspace; this includes the removal of files that were added by the shelved or pending change. Depending on the two check options boxes the plugin will then clean up any extra files or restore any modified or missing files. Finally, the plugin will sync the required file revisions to the workspace populating the 'have' table.
- Forced clean and sync
The plugin will remove all files from under the workspace root, then force sync the required file revisions to the workspace. If the populating the 'have' table options is enabled then the 'have' list will be updated.
This method is not recommended as the cost of IO resources on server and client are high. Apart from exceptional circumstances the Automatic cleanup and sync option will produce the same result.
- Sync only
The plugin will not attempt to cleanup the workspace; the sync operation will update all files (as CLOBBER is set) to the required set of revisions. If the populating the 'have' table options is enabled then the 'have' list will be updated.
To build immediately select the Build now button...
Or use the call the build/ URL endpoint e.g. http://jenkins_host:8080/job/myJobID/build
(where myJobID is the name of your job and jenkins_host the name or IP address of your Jenkins server).
A Jenkins job can build at any point in the codes history, identified by a Perforce Helix change or label.
The Jenkins job can be pinned to a Perforce Helix change or label by setting the Pin build at Perforce Label
field under the Populate options. Any time the Jenkins job is trigged, it will only build upto the pinned point.
If you are using downstream jobs (for example) you can use the Parameterized Trigger Plugin to pass '${P4_CHANGELIST}' as the parameter to the downstream job. The downstream job can then pin the build at the passed in changelist so both upstream and downstream jobs run against the same point in the history of the code.
Alternativly, a change or label can be passed using the Build Review
parameters or URL end point (see the Build Review chapter for details)
Related issues: JENKINS-29296, JENKINS-33163
The plugin supports parallel execution of Jenkins Jobs. Jenkins will create a new workspace directory workspace@2
and so on. The plugin will automatically template the current workspace appending .clone2
for the templates' name.
For custom workspaces, where an alternative location has been set e.g. Advanced --> Use custom workspace --> Provide a Directory. Then you will need to add the executor number to the end of your path.
For example:
/Users/pallen/Workspaces/custom@${EXECUTOR_NUMBER}
The plugin will then correctly template the workspaces as needed.
Perforce can trigger Jenkins to Build based on an event, such as a submitted change. A triggered build requires an administrator to add a Perforce trigger (Perforce documents here).
The trigger will need to POST a JSON payload to the Jenkins end-point p4/change/
. The JSON payload must contain the p4port
string that matchs the P4Port field specified in the Perforce Credential.
For example, a simple change-commit
trigger might use curl:
#!/bin/bash
CHANGE=$1
curl --header 'Content-Type: application/json' \
--request POST \
--data payload="{change:$CHANGE,p4port:\"localhost:1666\"}" \
http://localhost:8080/jenkins/p4/change
and have an entry in p4 triggers
for changes on //depot/...
:
jenkins change-commit //depot/... "/p4/common/bin/triggers/jenkins.sh %change%"
Note: If your Jenkins server needs authentication you will also need to provide a security 'CRUMB'. The following is an example of how you can get this and use to trigger a job:
#!/bin/bash
CHANGE=$1
USER=triggeruser
PASSWORD=Password
P4PORT=localhost:1666
SERVER=http://localhost:8080
# Get CRUMB
CRUMB=$(curl -s --user $USER:$PASSWORD $SERVER/crumbIssuer/api/xml?xpath=concat\(//crumbRequestField,%22:%22,//crumb\))
# Trigger builds across all triggered jobs (where relevant)
curl -s --user $USER:$PASSWORD -H "$CRUMB" --request POST --data "payload={change:$CHANGE,p4port:\"$P4PORT\"}" $SERVER/p4/change
On the Jenkins side you need to enable the 'Perforce triggered build' in the Job Configuration:
Jobs can be manually triggered by using the 'P4 Trigger' button on the top level Jenkins page:
and compleating the trigger form:
Building a Jenkins Job can be triggered using the SCM polling option, Build Now button or calling the build/ URL endpoint.
To enable SCM polling, check the 'Poll SCM' option and provide a Schedule using the Cron format. For example every 10 minutes Monday to Friday, the 'H' is a time offset (calculated using a Hash of the Job name).
When polling is used, changes can be filtered to not trigger a build; the filters are configured on the Jenkin Job configuration page and support the following types:
The polling event will only return the oldest unbuilt change, resulting in incremental builds.
Changes owned by the Perforce Helix user specified in the filter will be excluded.
Changes where all the file revision's path starting with the String specified in the filter will be excluded.
For example, with a Filter of "//depot/main/tests":
Case A (change will be filtered):
Files:
//depot/main/tests/index.xml
//depot/main/tests/001/test.xml
//depot/main/tests/002/test.xml
Case B (change will not be filtered, as build.xml is outside of the filter):
Files:
//depot/main/src/build.xml
//depot/main/tests/004/test.xml
//depot/main/tests/005/test.xml
The plugin supports a Build Review Action with a review/build/
URL endpoint. Parameters can be passed informing Jenkins of Perforce Helix shelf to unshelve and changelist to sync to. There are also Pass/Fail callback URLs for use with Swarm.
An example URL that would build the review in the shelved change 23980:
http://jenkins_host:8080/job/myJobID/review/build?status=shelved&review=23980
The Build Review Action support the following parameters:
- status (shelved or submitted)
- review (the pending shelved change)
- change (the submitted change)
- label (a Perforce label, instead of change)
- pass (URL to call after a build succeeded)
- fail (URL to call after a build failed)
Please note these paramiter are stored in the Environment and can be used with variable expansion e.g. ${label}
; for this reason please avoid these names for slaves and matrix axis.
If Jenkins requires users to login, then your Perforce trigger will need to use a Jenkins authorised account. Find the API Token
for the trigger user under:
Jenkins --> People --> (user) --> Configure --> API Token --> Show API Token
Use the API Token with BasicAuth in the URL, for example:
https://user:0923840952a90898cf90fe0989@jenkins_host:8080/job/myJobID/review/build?status=shelved&review=23980
The Build Review Action can be invoked manually from within Jenkins by selecting the Build Review button on the left hand side. This provides a form to specify the parameters for build.
The plugin supports unshelving one or more shelved changes into your Jenkins workspace as a build step. Select the 'Perforce: Unshelve' from the 'Add build step' dropdown and provide a change-list number or custom environment variable ${VAR}
in the 'Unshelve Changelist` box.
There is an optional 'Resolve Option' select box to choose the type of resolve to use on the unshelved files. This might be needed if the shelved revisions are at a different revision to the files sync'ed in the workspace.
After a build Jenkins provides the ability to see the details of a build. Select the build of interest from the Build History on the left hand side. You then get a Perforce change summary for the build and clicking on the View Detail link for specific files.
Detailed view...
Jenkins can tag builds automatically as a Post Build Action or allow manual tagging of a build. The Tags are stored in Perforce Helix as Automatic Labels with the label view based on the workspace at the time of tagging.
Tagging with Post Build Action
Manual Tagging
- Select the build that you wish to tag from the project page.
- Click on the 'Label This Build' link on the left hand panel, if the build has already been tagged the link will read 'Perforce Label'.
- Update the label name and description as required and click 'Label Build' to add the label to Perforce Helix.
- Once the build is labeled you will see the label details appear in a table above. New labels can be added to the same build or labels can be updated by providing the same label name.
Jenkins can automatically shelve or submit build assets to Perforce. Select the 'Add post-build action' and select the 'Perforce: Publish assets' from the list. Select the Credentials and Workspace options, you can connect to a different Perforce server if required. Update the description if required, ${variables}
are expanded.
Shelving with Post Build Action
Submitting with Post Build Action
Use a unique Perforce Workspace to Publish the assets. The Client View should be as narrow as possible, ideally only mapping the assets that need to be published. Adding a postfix of -publish
to the Workspace will help to identify its purpose. For Perforce Streams, a virtual stream may help to filter the view and +import
mappings when submitting assets to non-stream location.
Repository browsing allows Jenkins to use an external browser, like Swarm, P4Web, etc... to navigate files and changes associated with a Jenkins build.
To enable the feature select the Repository browser from the Job Configuration page and provide the full URL to the browser.
Link to change in Swarm
The plugin supports the Workflow and has DSL support for Perforce Helix p4sync
, p4unshelve
, p4tag
and p4publish
.
To use the Workflow install the plugin(s) as needed. Create a new Workflow Job by selecting 'New Item' from the left hand menu, provide an 'Item name' and choose a 'Workflow' project.
You can use the snippet genertor to create each step and use the code to compose your workflow script.
For example, a basic sync script:
- Check the 'Snippet Generator' box and from the 'Sample Step' drop down choose
P4 Sync
. - Select a valid P4 plugin Credential
- Fill out ONLY ONE of the three boxes for the code source.
e.g.
Stream Codeline : //streams/st1-main
or
Template Workspace : template_ws
or
Depot path : //depot/projX
Press the 'Generate Groovy' button...
Use this snippet with your intended target e.g. a slave calles 'my_slave'
node('my_slave') {
p4sync credential: 'server_id', stream: '//stream/main'
}
For more examples and usage please refer to the Workflow docs.
The plugin exposes the following additional variables:
- P4_CHANGELIST - current changelist (valid for this to be blank when there are no changes).
- P4_CLIENT - Client currently in use.
- P4_PORT - Perforce server port currently in use.
- P4_USER - Perforce user in use.
- P4_TICKET - Perforce ticket used (can be hidden using global configuration option 'Perforce: Secure P4_TICKET').
- HUDSON_CHANGELOG_FILE - Location on disk of 'changelog.xml' containing list of changes in this build.
For example in a Pipeline script you can use:
${env.P4_CHANGELIST}
For more details on using Workflow with the P4 Plugin please refer to the Workflow section.
Error: Setting up a SSL Credentials connection to a Helix Versioning Engine (P4D).
Unable to connect: com.perforce.p4java.exception.ConnectionException:
Error occurred during the SSL handshake:
invalid SSL session
Solution: Due to current US export control restrictions for some countries, the standard JDK package only comes with 128 bit encryption level cyphers. In order to use P4Java to connect to an SSL-enabled Helix Versioning Engine (P4D), those living in eligible countries may download the unlimited strength JCE (Java Cryptography Extension) package and replace the current default cryptography jar files on the build server with the unlimited strength files.
The libraries can be downloaded from:
http://www.oracle.com/technetwork/java/javase/downloads/jce-7-download-432124.html
Installation instructions can be found in the file 'README.txt' in the JCE download.
Error: Perforce login error part way through a build with an Edge/Commit setup.
Perforce password (P4PASSWD) invalid or unset.
- no such file(s).
ERROR: Unable to update workspace:
com.perforce.p4java.exception.AccessException: Perforce password (P4PASSWD) invalid or unset.
Solution: The following configurables must be set to allow the Edge to forward the login information to the Commit server.
p4 configure set cluster.id=myID
p4 configure set myEdge#rpl.forward.login=1
- One Jenkins Job per Swarm branch