Skip to content

OctopusDeploy/Octopus-Bamboo

Repository files navigation

Octopus Deploy Bamboo Plugin

Documentation

https://octopus.com/docs/api-and-integration/bamboo/bamboo-plugin

SDK Installation

This plugin used the Atlassian SDK. You can find more information about how to install and run the SDK from https://developer.atlassian.com/display/DOCS/Introduction+to+the+Atlassian+Plugin+SDK

Updating Bamboo Dependencies

Edit the pom.xml file and set <bamboo.version>6.2.1</bamboo.version> and <bamboo.data.version>6.2.1</bamboo.data.version> (the actual versions will be different to these examples) to the latest Bamboo version. This in turn will mean atlas-run will load the specified Bamboo version.

You can find the versions that are available at https://maven.atlassian.com/maven-external/com/atlassian/bamboo/atlassian-bamboo-web/.

Running Bamboo

Run the command atlas-run to start an instance of Bamboo with the plugin deployed.

The credentials are admin / admin.

If Bamboo fails to start running atlas-clean may resolve the issue.

Note there is a bug in AMPS 8.0.0 that means atlas-run doesn't work. See https://ecosystem.atlassian.net/browse/AMPS-1479 for details. The workaround is to run

mvn com.atlassian.maven.plugins:amps-dispatcher-maven-plugin:8.0.0:run -gs C:/Applications/Atlassian/atlassian-plugin-sdk-8.0.4/apache-maven-3.5.4/conf/settings.xml

Debugging Bamboo

Run the command atlas-debug to start an instance of Bamboo with the plugin deployed and debugging enabled.

Create a Remote Debug configuration as below.

Once the atlas command has the server to the point where it is fully running, you can start the Remote Debug configuration and IntelliJ will attach to the running process.

Testing changes on a remote Bamboo build agent

Taken directly from Atlassian's Bamboo remote agent installation guide.

1. Enable remote agent support
  • Click the cog icon in the Bamboo header and choose Overview.
  • In the left-hand panel, under Build Resources, click Agents.
  • Click either Enable Remote Agent Support or Disable Remote Agent Support.
2. Download and install the remote agent
  • Create a directory on the agent machine (e.g. bamboo-agent-home) to serve as the Bamboo agent home for the remote agent.
  • Click the cog icon in the Bamboo header and choose Overview.
  • In the left-hand panel, under Build Resource, click Agents in the left panel.
    • The 'Agents' screen displays showing the lists of all local agents and all remote agents that currently exist on your Bamboo system.
  • If not already enabled, click the Enable remote agent support link
  • Click Install Remote Agent. The 'Installing a remote agent' screen will display
  • Click DOWNLOAD Remote Agent JAR and save the JAR file to the directory on the agent machine that you created above.
  • Copy the command under 'Running a Remote Agent' to the clipboard for use in Step 3 that follows.
3. Launch the remote agent

Once installed, run the remote agent by executing the command line obtained above. This command will look something like this:

java -jar atlassian-bamboo-agent-installer-<version>.jar http://bamboo-host-server:6990/bamboo/agentServer/

Building the Plugin

Run the command atlas-package to build the plugin. The compiled plugin will be saved as target\bamboo.jar.

Deploying a new version of the plugin to the Atlassian Marketplace

Automated process

We use release-please and conventional commits to generate release notes for new versions.

The process once the release-please PR is merged is as follows:

  1. Build and package a new plugin JAR file
  2. Push the package to Octopus
  3. Automatically kick off a deployment to the Production environment
    • Upload plugin JAR file using the Atlassian Marketplace REST API
    • Create a new app version in the Atlassian Marketplace using the Atlassian Marketplace REST API
    • Confirm that the new app version was created
      • If the process fails to create the new app version, the deployment will fail

Manual process

Keep in mind that the Bamboo plugin does not ship with the Octopus CLI tool. Updates to the CLI tool don't require that the Bamboo plugin be republished.

To update the marketplace, use the following steps:

  1. Build the new JAR file.
    • You can do this locally, or get the artifact from the GitHub Actions run for the version you want to publish.
    • Note that if you are building locally you will need to increment the version inside the pom.xml file before building (<version>1.0.3</version>). This version is used by the store to show the latest artifact to end users.
  2. Browse to https://marketplace.atlassian.com/manage/plugins/com.octopus.bamboo/versions. Use the atlassian@octopus.com account - credentials are in the password manager.
  3. Click the Create version button.
  4. Follow the wizard to upload the JAR file. The wizard will show you a lot of pages relating to how the add-on is to be displayed, but you can keep the exiting content. The only requirement are some release notes.

Nightly builds

The nightly process is nearly identical to our release process (differences highlighted):

  1. Build and package a new pre-release versioned plugin JAR file
  2. Push the package to Octopus
  3. Automatically kick off a deployment to the Test environment
    • Upload plugin JAR file using the Atlassian Marketplace REST API
    • Create a new private app version in the Atlassian Marketplace using the Atlassian Marketplace REST API
      • This version will not be visible in the marketplace for people outside the Octopus organization
    • Confirm that the new app version was created
      • If the process fails to create the new app version, the deployment will fail

Automated Bamboo server compatibility version updates

We have a weekly scheduled workflow that checks if there has been a new version of Bamboo server released since we last updated our Bamboo plugin.

This process is as follows:

  1. Check if a new version of Bamboo server has been released
    • If there is no new version, execution is stopped
  2. Open a new issue with details of current and new Bamboo compatible versions
    • If there is already an open issue, it will update the existing issue with the new version details
  3. Update the compatible Bamboo version in the <bamboo.version> and <bamboo.data.version> properties inside the pom.xml file
  4. Commit and push the changes to a new branch
  5. Open a PR for the changes
    • The issue from step 2 above will be referenced and will be closed once the PR is merged

Once the PR has been reviewed and merged, the automated release-please process described above will take over to push the new version of the plugin to the Atlassian Marketplace.