Blog Engineering How to use external status checks for merge requests
October 4, 2021
7 min read

How to use external status checks for merge requests

Want to integrate third-party systems and apps with GitLab merge requests? Here's everything you need to know.

Blog fallback hero

The external status checks for merge requests capability was recently introduced in GitLab and it allows the integration of third-party systems and applications with GitLab merge requests.

What are "external status checks for merge requests"?

External status checks are API calls to systems or applications that sit outside GitLab. These API calls are invoked during merge requests, which display a widget with the status of each external check. With external status checks, you can integrate GitLab with third-party systems, e.g. Salesforce, PeopleSoft, Microsoft Dynamics, etc., that require manual approval for merge requests. This makes it easy to see that merge requests have met external requirements before being merged, adding an extra method to ensure compliance and audit requirements are met.

Steps to enable and use external status checks for merge requests

In this example, I have a sample project called my-proj, for which I'd like to add and exercise a single external status check, which will hypothetically do some kind of validation for the merge request.

Adding an external status check to your project

External status checks are added to merge requests by heading to your project’s Settings > General and then expanding the Merge requests section. Towards the bottom of the Merge requests section, you will see an Add status check button, which you will need to click to to display the Add status check pop-up dialog:

Add status check dialog with filled values {: .note.text-center}

In the dialog above, the external service name is being given the name compliance-check. The external API that will be called is:

https://tech-marketing-sandbox-cd-compvalidator.compliance.gitlabworkshops.io/validate

NOTE: the validate service above was a simple Java service that I set up ahead of time to mimic a third-party external service. It returned an HTTP 200 success message when invoked. In a real life scenario, this external API call would be a SaaS service or an on-premises ERP system, for example.

The API above is a call - invoked from any merge requests created under this project - to an external system that will run a compliance check and validate modifications to this application.

As the target branch, the default Any branch has been selected. Another option could have been the main branch.

When you click the Add status check button, an entry will be created in the Status checks table, as shown below:

status check table
Status checks table

External status check in action

To exercise the external status check for merge requests, we need to create a merge request. But before that, let's create an issue.

  1. Create an issue by clicking on Issues > List from the left vertical navigation menu to get to the Issues screen.

  2. Then click on the New Issue button

  3. On the New Issue window:

3.1. In the Title field, enter "External status check demo"

3.2. In the Description field, enter "Issue to demonstrate an external status check"

3.3. Click on Assign to me next to the Assignees field

3.4. Click on the Create issue button at the bottom of the window

Creating an issue {: .note.text-center}

Once the issue is created, you will be in the detail issue window.

  1. Click on the Create merge request button on the right hand side of the detailed issue window.

create a merge request
Creating a merge request

Once the merge request is created, you will be in the detail merge request window.

  1. Click on the Open in Web IDE button on the right hand side of the detailed merge request window:

open webIDE
Opening the Web IDE

  1. Make a minor update to the application. In the sample project my-proj, I modified two files: DemoApplication.java and DemoApplicationTests.java.

6.1. In the DemoApplication.java class, I added the word "today" to the string returned by a call to this class:

update DemoApp
Making a simple update to DemoApplication.java

6.2. In the DemoApplicationTests.java class, which is a unit test for DemoApplication.java, I also added the word "today" to the string in the assertThat() invocation to match the value returned by a call to the DemoApplication.java class:

update DemoAppTests
Making a simple update to DemoApplicationTests.java

  1. Click on the Commit… button at the bottom of the Web IDE window. And then ensure to select the feature branch for the merge request before clicking on the Commit button again:
Committing to the feature branch {: .note.text-center}
  1. Go back to the merge request detail window by clicking on the merge request number on the bottom margin of the window:
Clicking on merge request link at bottom of window {: .note.text-center}
  1. On the detail merge request window, scroll down until you see a section titled Status checks 1 pending. This is the merge request widget that lists all external status checks associated with merge requests. Click on the Expand button on the right hand side of this section:

expanding status checks widget
Expanding the status checks widget in the merge request

  1. In the expanded section, you will see an entry for the external status check you defined above, whose name is compliance-check. Notice that to the left of its name, there is a pause symbol indicating to the merge request stakeholders that the check is still in progress and has not communicated its approval to the merge request yet:

list of status checks
List of external status checks

  1. In a real life scenario, the pause symbol would change to a green checkmark when the external status check communicates to GitLab that the compliance validation is finished, i.e. the merge request has been approved by the external service:

status checks passed
Status checks that have passed

How does an external status check inform GitLab that it has approved the merge request

Using an external status check integrates GitLab merge requests to a home-grown or SaaS application, for example, by invoking an API of this external system. Once this external system does its compliance validation or check, then it needs to inform GitLab that it has approved the merge request. To do this, the external system API must make use of the GitLab external status checks API to communicate to GitLab that the MR is approved. This is a 2-step process:

  1. The first step is to get the ID of the external status check you need to approve. Here is an example of how to invoke the GitLab API to do this:

curl --request GET --header "PRIVATE-TOKEN: " "https://gitlab.com/api/v4/projects/28933616/merge_requests/1/status_checks"

An example of what the command above will return follows:

[{"id":86,"name":"compliance-check","external_url":"https://tech-marketing-sandbox-cd-compvalidator.compliance.gitlabworkshops.io/validate","status":"pending"}]

The example return value above shows that the ID of the external status check that we’d like to approve is 86.

NOTE: Although I'm showing an example of how to invoke the GitLab API above using the curl command, the idea is that your external system API call would carry out any checks and validation and then it would assemble this message in a REST HTTP call back to GitLab to communicate its approval of the merge request.

  1. Once you have the ID of the external status check, you can then approve it by using the GitLab API. Here’s an example:

curl --request POST --header "PRIVATE-TOKEN:" "https://gitlab.com/api/v4/projects/28933616/merge_requests/1/status_check_responses?sha=&external_status_check_id=86"

Executing the REST API call above will approve the external status check on the GitLab merge request.

NOTE: to obtain the <SHA at HEAD of the source branch>, here’s an example of the command you’d need to execute:

$ git ls-remote https://gitlab.com/tech-marketing/sandbox/cd/my-proj.git

The URL in the preceding line is the URL to the git project for your merge request. And here’s an example of the output of the preceding command:

ad1eeee497c99466797a1155f514d3c0c2f0cc45	HEAD
9e209c8d409a0867c1df4e0965aa675277176137	refs/heads/1-external-status-check-demo
ad1eeee497c99466797a1155f514d3c0c2f0cc45	refs/heads/master
9e209c8d409a0867c1df4e0965aa675277176137	refs/merge-requests/1/head

In the output above, the SHA for the feature branch associated with the merge request is 9e209c8d409a0867c1df4e0965aa675277176137

What we've learned

GitLab recently introduced "external status checks for merge requests," which are effectively API calls to systems/application that sit outside GitLab. As you could see, with external status checks for merge requests, we were able to integrate GitLab with a third-party system that required manual approval for a merge request, ensuring that your application updates meet compliance and audit requirements.

For a demo of this feature in action, watch the video below:

We want to hear from you

Enjoyed reading this blog post or have questions or feedback? Share your thoughts by creating a new topic in the GitLab community forum. Share your feedback

Ready to get started?

See what your team could do with a unified DevSecOps Platform.

Get free trial

New to GitLab and not sure where to start?

Get started guide

Learn about what GitLab can do for your team

Talk to an expert