https://octopus.com/docs/api-and-integration/bamboo/bamboo-plugin
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
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/.
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
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.
Taken directly from Atlassian's Bamboo remote agent installation guide.
- Click the 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.
- 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 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.
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/
Run the command atlas-package
to build the plugin. The compiled plugin will be saved as target\bamboo.jar
.
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:
- Build and package a new plugin JAR file
- Push the package to Octopus
- 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
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:
- 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.
- Browse to https://marketplace.atlassian.com/manage/plugins/com.octopus.bamboo/versions. Use the
atlassian@octopus.com
account - credentials are in the password manager. - Click the
Create version
button. - 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.
The nightly process is nearly identical to our release process (differences highlighted):
- Build and package a new pre-release versioned plugin JAR file
- Push the package to Octopus
- 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
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:
- Check if a new version of Bamboo server has been released
- If there is no new version, execution is stopped
- 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
- Update the compatible Bamboo version in the
<bamboo.version>
and<bamboo.data.version>
properties inside thepom.xml
file - Commit and push the changes to a new branch
- 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.