Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Help: Azure DevOps YAML Pipelines #288

Merged
merged 4 commits into from
Sep 20, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions src/_data/sidebar.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ help:
link: /continuous-integration/
icon: terminal
items:
- label: Azure Devops
link: /continuous-integration/azure-devops/
- label: Github Action
link: /continuous-integration/github-actions/
- label: CI
Expand Down
117 changes: 117 additions & 0 deletions src/_help/continuous-integration/azure-devops.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
---
title: Azure DevOps
---

- TOC
{:toc}

## Generate your API documentation & changelog

Azure DevOps has a feature called "Pipelines", which allow you to chain together various actions for Continuous Integration & Continuous Delivery. In this tutorial we'll show you how to create a pipeline, and use it to deploy your Bump.sh API documentation when new commits are pushed to your main Git branch, and show how to check for breaking changes on pull requests.

## Azure DevOps YAML Pipelines vs. Classic Pipelines

Azure DevOps supports two distinct pipeline formats, the old "Classic Pipelines" built and managed via a drag-and-drop interface, and "YAML Pipelines" which are configured entirely via a YAML file in the repo.

Seeing as YAML Pipelines are the newer approach, and many people may have never worked with Classic Pipelines, we'll stick with YAML Pipelines for this tutorial. This also has the benefit of being entirely Git controlled, so you can change your pipelines along with your OpenAPI and all the API source-code all at once.

## Setting up Bump.sh with an Azure DevOps YAML Pipeline

### Step 1: Setup Azure Organization & Project

**Sign in** to your Azure organization if you have one, or **[sign up](https://azure.microsoft.com/en-us/free)**
philsturgeon marked this conversation as resolved.
Show resolved Hide resolved

Then navigate to an existing project, or create a new one if you need to.

![](/images/guides/azure-devops/organization-and-project.png)

Click on the project, then click **Pipelines**, and **New Pipeline** to get the whole thing going.

![](/images/guides/azure-devops/new-project-pipeline.png)

Select where your code is hosted. You can choose from Azure Repos Git, GitHub, Bitbucket, or other repositories. For this example, we’ll assume you are using **Azure Repos Git**.

### Step 2: Configure Your YAML Pipeline

Choose **YAML** when prompted to configure the pipeline, and select the repository branch you want the pipeline to monitor (e.g., `main`).

Then you'll be presented with lots of options for start templates. Click "Node.js" because Bump.sh CLI is built with Node.

![](/images/guides/azure-devops/pipeline-templates.png)

Now we can override the YAML Pipeline they've popped in the repo with our own. You can do this by cloning the new repository, or by pulling the commits on an exist repository.

Either way, let's update `azure-pipelines.yml` with the following:


```yaml
# azure-pipelines.yml
trigger:
- main
variables:
- group: bumpsh
pool:
vmImage: 'ubuntu-latest'
steps:
- task: UseNode@1
inputs:
version: '20.x'
displayName: 'Install Node.js'
- script: |
npm install bump-cli
displayName: 'Install Bump CLI'
- script: |
npm exec -- bump deploy "openapi.yaml" --doc "azure-demo" --token "$(BUMP_TOKEN)"
displayName: 'Deploy API Documentation'
```

### **Step-by-Step Breakdown**
1. **Trigger**: This pipeline triggers automatically whenever there are changes to the `main` branch.

2. **Pool**: Specifies that the pipeline should use the latest available Ubuntu agent.
3. **Steps**:
- **UseNode Task**: Installs Node.js using the `UseNode` task. The `version: '20.x'` line ensures that Node.js version 20.x is installed.
- **npm install**: Installs the npm packages defined in your `package.json` file.
- **CLI command**: The `bump deploy` command is a placeholder for any CLI command you want to run. Replace `mycli` with the actual command you need (e.g., `npm run build` or `az --version`).

### Step 3: Setup Environment Variables

Azure DevOps handles environment variables a little differently to other CI/CD tools, but it's ok when you know how.

Firstly, pop over to **Pipelines > Library** and click on **\+ Variable Groups**.

![](/images/guides/azure-devops/add-variable-group.png)
philsturgeon marked this conversation as resolved.
Show resolved Hide resolved

Create a new group with the name `bumpsh`, which matches the `group: bumpsh` we defined in the workflow.

In another browser tab, pop over to your Bump.sh API's Documentation settings, go to the “CI deployment” section, and grab your API key.

Back in the Azure variable group page, create a new variable called `BUMP_TOKEN`, paste in the API key, and click the lock icon to make it secret.

![](/images/guides/azure-devops/bump-variable-group.png)

For security reasons, referencing the variable group in the YAML workflow is not enough to give the pipeline access to the variables. This requires one more step: click "Pipeline permissions" and select your pipeline.

![](/images/guides/azure-devops/pipeline-permissions-variable-group.png)

Now we should be good to go!

### Step 4: Save and Commit the YAML File

Make sure the pipeline file is saved as `azure-pipelines.yml` in the root of your repository, commit, and push.

Once the YAML file is in the repository, Azure DevOps will automatically detect it and run the pipeline, based on the branch configuration. Seeing as we've set this file to trigger on the `main` branch, make sure you are pushing commits there.

Head over to **Pipelines** and click on the latest commit, you might see the pipeline still running, and when its done you will see whether it worked or not. If it worked, you'll see a green tick, and can click on each step to see what happened. The step that runs `bump deploy` should look like this:

![](/images/guides/azure-devops/first-run.png)

Here we can see the documentation has been created, and there's even a link to go and see it.

## Troubleshooting

If this is a new Azure DevOps account you might have problems with:

> "No hosted parallelism has been purchased or granted."

You can request free pipeline runs by entering a name and address in this [web form](https://aka.ms/azpipelines-parallelism-request). It says it might take 2-3 days but it's usually closer to 1.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added src/images/guides/azure-devops/first-run.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading