This page lists the arguments you can supply to the Octopus Jenkins Pipelines commands to run against your Octopus Deploy server.
The Jenkins Pipeline support requires plugin version 3.0.0 or later and Jenkins version 2.190.1 or later.
The toolId parameter refers to the Name of the Global Tool Configuration for Octopus CLI, available at Manage Jenkins ➜ Global Tool Configuration.
The serverId parameter refers to the Server ID of the OctopusDeploy Plugin configuration, available at Manage Jenkins ➜ Configure System.
Pack
Step name: octopusPack
octopusPack allows you to create a package from files on disk during your pipeline execution.
| Parameters | Required | Description | 
|---|---|---|
| toolId | Yes | The configured Octopus CLI tool to use. | 
| packageId | Yes | The ID of the package. | 
| packageFormat | Yes | The format of the package, zipornupkg. | 
| sourcePath | Yes | Path containing files and directories to include in package. | 
| overwriteExisting | No | Overwrite an existing package with the same name and version. Valid values are trueorfalse. Defaults tofalse. | 
| includePaths | No | New-line separated paths to include files. | 
| outputPath | No | Path to write final package. Defaults to .. | 
| packageVersion | No | Package version, defaults to a timestamp-based version. | 
| verboseLogging | No | Turn on verbose logging. Valid values are trueorfalse. | 
| additionalArgs | No | Additional arguments to pass to the Octopus CLI pack command. | 
Example:
octopusPack \
  additionalArgs: '-author "My Company"', \
  outputPath: './artifacts/', \
  overwriteExisting: false, \
  packageFormat: 'zip', \
  packageId: 'OctoPetShop', \
  packageVersion: '1.1.${BUILD_NUMBER}', \
  sourcePath: './bin/Release/publish/', \
  toolId: 'octocli', \
  verboseLogging: falsePush
Step name: octopusPushPackage
octopusPushPackage allows you to push packages to the package repository in an Octopus Server.
| Parameters | Required | Description | 
|---|---|---|
| toolId | Yes | The configured Octopus CLI tool to use. | 
| serverId | Yes | The configured Server ID of the target server to push the package. | 
| spaceId | Yes | The ID of the Space on the server to push the package. | 
| packagePaths | Yes | The path to the package. | 
| overwriteMode | Yes | Valid values are FailIfExists,OverwriteExistingorIgnoreIfExists. | 
| verboseLogging | No | Turn on verbose logging. Valid values are trueorfalse. | 
| additionalArgs | No | Additional arguments to pass to the Octopus CLI push command. | 
Example:
octopusPushPackage \
  overwriteMode: 'FailIfExists', \
  packagePaths: './artifacts/OctoPetShop.1.1.${BUILD_NUMBER}.zip', \
  serverId: 'octopus-server', \
  spaceId: 'Spaces-1', \
  toolId: 'octocli'Examples for the packagePaths parameter:
Absolute path
The path to the package can be provided as an absolute path on the Jenkins server or Agent. ${WORKSPACE} is the directory which the job runs within.
- packagePaths: "${WORKSPACE}/artifacts/Package.0.0.${BUILD_NUMBER}.zip".
- packagePaths: "/home/jenkins/workspace/artifacts/Package.0.0.${BUILD_NUMBER}.zip".
Relative path
The path is a relative path from the WORKSPACE directory.
- packagePaths: "artifacts/Package.0.0.${BUILD_NUMBER}.zip"
Glob Patterns
The package selection can also be done using ANT glob patterns.
- packagePaths: "artifacts/**/*.0.0.${BUILD_NUMBER}.zip".- This will pick up all the packages, in all folders under the artifactsdirectory with a name matching the0.0version and current build number.
 
- This will pick up all the packages, in all folders under the 
Multiple paths
The packagePaths parameter also supports multiple values from the above options separated by a \n character.
- packagePaths: "artifacts/package1/Package1.0.0.${BUILD_NUMBER}.zip\nartifacts/package2/Package2.0.0.${BUILD_NUMBER}.zip"
Push package info
Step: octopusPushBuildInformation
octopusPushBuildInformation allows you to push package information to an Octopus Server.
| Parameters | Required | Description | 
|---|---|---|
| toolId | Yes | The configured Octopus CLI tool to use. | 
| serverId | Yes | The configured Server ID of the target server to push the build information. | 
| spaceId | Yes | The ID of the Space on the server to push the build information. | 
| packageId | Yes | The ID of the packages to push the version information, multiple values can be provided separated by \n. | 
| commentParser | Yes | Valid values are GitHubandJira. | 
| overwriteMode | Yes | Valid values are FailIfExists,OverwriteExistingorIgnoreIfExists. | 
| gitUrl | No | The URL of the repository for the package(s). | 
| gitBranch | No | The branch that was checked out in the repository. Available via git checkout. | 
| gitCommit | No | The commit ID of the most recent commit on the branch. Available via git checkout. | 
| verboseLogging | No | Turn on verbose logging. Valid values are trueorfalse. | 
| additionalArgs | No | Additional arguments to pass to the Octopus CLI build-information command. | 
Example:
octopusPushBuildInformation \
  toolId: 'octocli', \
  serverId: 'octopus-server', \
  spaceId: 'Spaces-1', \
  commentParser: 'GitHub', \
  overwriteMode: 'FailIfExists', \
  packageId: 'OctoPetShopService', \
  packageVersion: '1.2.${BUILD_NUMBER}', \
  verboseLogging: false, \
  additionalArgs: '--debug', \
  gitUrl: 'https://github.com/OctopusSamples/OctoPetShop', \
  gitBranch: '${GIT_BRANCH}', \
  gitCommit: '${GIT_COMMIT}'Due to limitations in Jenkins Pipelines, you will need to pass the Git URL, Git Branch and Git Commit values to the octopusPushBuildInformation.
Including these values will allow the build information to provide correct URL links to the source.
For a pipeline source from SCM, set the parameters to gitUrl: '${GIT_URL}' gitBranch: '${GIT_BRANCH}' gitCommit: '${GIT_COMMIT}', the checkoutVars script will not be required.
For a inline pipeline definition configure the step as:
steps {
    script {
        def checkoutVars = checkout([$class: 'GitSCM', userRemoteConfigs: [[url: 'https://github.com/OctopusSamples/RandomQuotes-Java.git']]])
        env.GIT_URL = checkoutVars.GIT_URL
        env.GIT_BRANCH = checkoutVars.GIT_BRANCH
        env.GIT_COMMIT = checkoutVars.GIT_COMMIT
    }
    octopusPushBuildInformation commentParser: 'GitHub', overwriteMode: 'FailIfExists', packageId: 'randomquotes', packageVersion: "1.0.${BUILD_NUMBER}", serverId: "octopus-server", spaceId: "Spaces-2", toolId: 'Default', gitUrl: "${GIT_URL}", gitBranch: "${GIT_BRANCH}", gitCommit: "${GIT_COMMIT}"
}Create release
Step: octopusCreateRelease
octopusCreateRelease allows you to push packages to the package repository in an Octopus Server.
| Parameters | Required | Description | 
|---|---|---|
| toolId | Yes | The configured Octopus CLI tool to use. | 
| serverId | Yes | The configured Server ID of the target server to create the release in. | 
| spaceId | Yes | The ID of the space on the server to create the release in. | 
| project | Yes | The ID of the project to create the release in. | 
| releaseVersion | Yes | The version number for the release. | 
| channel | No | The name of the target channel. Defaults to Defaultchannel. | 
| packageConfigs | No | Collection of package versions to set when creating the release. | 
| defaultPackageVersion | No | The default version to use for packages associated with the release. | 
| deployThisRelease | No | Deploy release after creation. Valid values are trueorfalse. Defaults tofalse. | 
| waitForDeployment | No | Wait for deployment to complete before continuing. Valid values are trueorfalse. Defaults tofalse. | 
| cancelOnTimeout | No | Cancel the deployment after the waitForDeploymenttime. Valid values aretrueorfalse. Defaults tofalse. | 
| tenant | No | The tenant to deploy the release to. | 
| tenantTag | No | The tenant tag to deploy the release to. | 
| deploymentTimeout | No | How long to wait for deployment. Format is HH:mm:ss. Default is00:10:00. | 
| environment | Conditional | The environment to deploy release to. Required if deployThisReleaseistrue. | 
| jenkinsUrlLinkback | No | Include link to the Jenkins build that created the release. Valid values are trueorfalse. Default isfalse. | 
| releaseNotes | No | Include release notes in release. Valid values are trueorfalse. Default isfalse. | 
| releaseNotesSource | No | Valid values are fileorscm. | 
| releaseNotesFile | Conditional | The file path for release notes, required if releaseNotesSourceisfile. | 
| verboseLogging | No | Turn on verbose logging. Valid values are trueorfalse. | 
| additionalArgs | No | Additional arguments to pass to the Octopus CLI create-release command. | 
Example:
octopusCreateRelease \
  serverId: 'octopus-server', \
  spaceId: 'Spaces-1', \
  project: 'Random Quotes', \
  releaseVersion: '2.3.${BUILD_NUMBER}', \
  toolId: 'octocli', \
  packageConfigs: [[packageName: 'Nuget.CommandLine', packageReferenceName: 'NugetCLI', packageVersion: '5.5.1']], \
  deployThisRelease: true, \
  cancelOnTimeout: false, \
  deploymentTimeout: '00:15:00', \
  environment: 'test', \
  tenant: 'The Tenant', \
  tenantTag: 'importance/high', \
  jenkinsUrlLinkback: true, \
  releaseNotes: true, \
  releaseNotesSource: 'scm'Deploy release
Step: octopusDeployRelease
octopusDeployRelease allows you to push packages to the package repository in an Octopus Server.
| Parameters | Required | Description | 
|---|---|---|
| toolId | Yes | The configured Octopus CLI tool to use. | 
| serverId | Yes | The configured Server ID of the target server to deploy the release. | 
| spaceId | Yes | The ID of the Space on the server to deploy the release. | 
| project | Yes | The ID of the project to deploy the release. | 
| environment | Yes | Environment to deploy release. | 
| releaseVersion | Yes | The version number for the release. | 
| cancelOnTimeout | No | Cancel the deployment after the waitForDeploymenttime. Valid values aretrueorfalse. Defaults tofalse. | 
| tenant | No | The tenant to deploy the release to. | 
| tenantTag | No | The tenant tag to deploy the release to. | 
| waitForDeployment | No | Wait for deployment to complete before continuing. Valid values are trueorfalse. | 
| deploymentTimeout | No | How long to wait for deployment. Format is HH:mm:ss. Default is00:10:00. | 
| variables | No | Set prompted variable values. Format is key1=value1\nkey2=value2. | 
| verboseLogging | No | Turn on verbose logging. Valid values are trueorfalse. | 
| additionalArgs | No | Additional arguments to pass to the Octopus CLI deploy-release command. | 
Example:
octopusDeployRelease \
  toolId: 'octocli', \
  serverId: 'octopus-server', \
  spaceId: 'Spaces-1', \
  project: 'OctoPetShop', \
  environment: 'test', \
  releaseVersion: '1.2.${BUILD_NUMBER}', \
  deploymentTimeout: '00:05:00', \
  waitForDeployment: false, \
  cancelOnTimeout: trueHelp us continuously improve
Please let us know if you have any feedback about this page.
Page updated on Sunday, January 1, 2023