Native CI integration

5 minute readDeveloper productivityExtensibility

Every company wants to make their software delivery processes as efficient as possible. To this end, native CI integration seamlessly provides CI job and build data access within CloudBees CD/RO. Tasks provided with this integration include:

Triggering CI jobs

CI jobs are triggered from CloudBees CD/RO pipelines via pipeline CI Job tasks. After one-time CloudBees CI controller configuration, they become available to your pipeline tasks. Define the CI Job task to access the desired controller when creating your CloudBees CD/RO pipeline.

Defining the CloudBees CI Job task

Define a CloudBees CD/RO pipeline task as a CI Job specifying the CI configuration and other details about the CI job. Refer to Pipeline Tasks for general information about creating tasks. The steps below show creating a task with type CI Job in an existing CloudBees CD/RO pipeline.

If you have upgraded to CloudBees CD/RO v10.1 from v10.0.x, your CloudBees CI operations center configurations may need to be reworked.

  • In v10.0.x, CloudBees CI operations center URLs specified in configurations are silently appended at runtime with the /cjoc path component.

  • In v10.1, URLs are used as defined in configurations. The /cjoc component is not appended.

In order to maintain pre-v10.1 runtime compatibility, the v10.1 upgrade process modifies CloudBees CI operations center URLs in existing configurations by hardcoding the /cjoc path component. You need to rework existing URLs in configurations where appending the \cjoc path component is inappropriate.

  1. Create a new task in the CloudBees CD/RO pipeline stage.

  2. Select Select Task Type in the New Task tile and choose CI Job from the Native list.

  3. Back in the New Task tile, select Define, the Edit Task dialog displays.

    ci tasks mb

    1

    Select CI Job

    2

    Choose the CloudBees CI controller configuration or CloudBees CI operations center configuration you previously created. Here, managed-ci-controller is selected.

    3

    The CI Job Name column is automatically populated with jobs and folders already defined in the selected CI configuration or selected CloudBees CI operations center configuration. Here CI-pipeline-A from folder1 is selected.

    If the selected CI job is configured with multiple branches, you must select a branch name that is already defined for that job. Branch name can be:

    • A case-sensitive string: special characters, including /, are accepted.

    • A parameter specified with the $[] construct: the property is expanded at pipeline task run time to resolve the branch name.

    4

    If the selected CI job name defines parameters, the Parameters line is active. Click the arrow to refer to the list of parameters for the selected job.

    From here, enter values for the parameters. They are passed to the CI job next time the CloudBees CD/RO pipeline is run.

Configure with the API

To define a CI job via the CloudBees CD/RO API, refer to the createTask command.

Configuring CloudBees CI controllers

One-time setup on CloudBees CD/RO: configure connections to individual CloudBees CI controllers and optionally, CloudBees CI operations centers. This provides CloudBees CD/RO the ability to call CI jobs managed by the controllers as if they are native, where job data and parameters from CI are automatically populated into CloudBees CD/RO.

  1. On the CloudBees CD/RO main menu, select Administration  Configurations.

  2. Select CI configurations from the left-hand menu to display the CI configuration list.

  3. Select New. From here, create a new configuration or copy an existing one.

    By default, a CloudBees CI controller configuration is created.

    If the selected Type is CloudBees CI operations center, check whether you want to use this operations center as the default. If checked and a default is already configured, it is replaced by this one. All CloudBees CI controllers in that operations center are automatically discovered and populated into the configuration list.

  4. Under Credential type select either Local credential or External credential.

    1. For a local credential, type the user name and API token or password.

    2. For an external credential, select the credential project to use, and then the credential you want to use.

  5. Optionally, select the option to test the connection to the CI configuration server.

  6. Select OK when finished.

  7. If the new configuration is for the CloudBees CI operations center:

    1. Expand the list to discover all individual CloudBees CI controllers.

    2. Navigating into the list, select Copy for the controller you wish to move into the CI configurations list.

      ci ops center

      A New CI configuration dialog displays for that controller. Since Reuse the same credentials from the Operation Center CI Configuration is checked, the configuration pre-populates with sign-in credentials. Select OK to save.

Whether added directly or selected from the CloudBees CI operations center, the new configuration is added to the CloudBees CI controller configurations list and is available for CI Job tasks in CloudBees CD/RO pipelines.

Configure with the API

To configure a CloudBees CI controller via the CloudBees CD/RO API, refer to CI configuration.

Triggering CloudBees CD/RO pipelines

Using the CloudBees CD/RO Jenkins plugin, CI jobs can be configured to trigger a CloudBees CD/RO pipeline either as a post-build action from the CI job or as a pipeline task in a CI pipeline. In addition, the CI job can be configured to send job or pipeline build details to the CloudBees CD/RO pipeline.

Viewing pipeline build data

  • Build details for CI jobs triggered by CloudBees CD/RO is sent back after the job completes. To view the information:

    1. Navigate to the pipeline run of interest on the Pipeline Runs list.

    2. Expand the run via expand icon on the right of the list entry to refer to the underlying stages.

      ci view build data
    3. Click the View CI Build Data button.

  • Build Data for CloudBees CD/RO pipelines triggered by CI are denoted on the Pipeline Runs list with the Jenkins logo, as indicated in pipelines #1 and #2 below.

    To view the information sent by the post-build action from the CI process: . Select the Jenkins logo on the CloudBees CD/RO Pipeline Runs list entry. The Jenkins Build Data screen appears. . Select the Details icon on the right of build entry.

Build data console UI

The console output summary for the CI job appears as shown below.

Console for failed Jenkins build
Figure 1. Console output summary

Also on this screen are tabs for Build Artifacts and Test Results.

View the artifacts and test results
Figure 2. Build artifacts and test results

Via the API

Use the getCIBuildDetail command to programmatically get build details.

Known limitations

This section describes situations to be aware of when calling CI jobs from CloudBees CD/RO.

Infinite triggering loop

Care must be taken so that a given CloudBees CD/RO job doesn’t invoke a CI job having a post-build action that triggers the same CloudBees CD/RO pipeline; otherwise, an infinite triggering loop ensues.

Triggering the same CI job multiple times

During a given CloudBees CD/RO pipeline run a given CI job, unless it is configured with unique parameters, cannot be triggered more than once if there is already another CI build that is waiting in the queue.

CloudBees CD/RO pipeline run returns false success

The CloudBees CD/RO pipeline waits indefinitely instead of completing with an error if the target CI job is cancelled or aborted while waiting in the queue.