Manage workflows

11 minute read

Use the CloudBees workflow management features to configure CloudBees platform workflows. Begin by accessing workflow management features. Then use the workflow composer visual and code editors to configure these workflow objects.

  • Triggers: These are events that start a workflow run. Triggers are displayed in the Trigger section of the visual composer and under on in the code editor.

    There are four types of triggers.

    • Push - Starts the workflow based upon a push request and git tags.

    • Pull - Starts the workflow based upon a pull request.

    • Schedule - Starts the workflow based upon configured cron schedules. There is no limit on the number of schedules.

    • Manual - Allows users with permission to trigger a workflow run.

  • Jobs: Workflow activities.

    There are two types of jobs.

    • Standard - Contains at least one step with a valid uses entry.

    • Custom - A job that executes the workflow job using the delgates object.

    • Manual approval is currently the only custom job. Configure a manual approval job to require an approval of the workflow run. Refer to:

Access Workflows List

To access a workflow:

  1. Select Up/down arrows, and then select a component in an organization.

  2. Select Workflows on the left panel to display the list of workflows.

    Workflows
    Figure 1. Workflows list

Use these workflow management features:

  1. Create a new workflow by selecting Create workflow.

  2. Access workflow Yaml file.

    • View the workflow Yaml file by selecting the workflow name link.

    • Modify workflow in the Composer by selecting Edit Yaml.

    • Resize workflow viewer width by dragging Resize .

Use the Composer visual editor to configure a workflow

Use the Workflow composer to create and configure workflows.

Use either the visual tool and YAML scripting, or both together, to compose your workflow. Updates made with the visual tool or the code editor are automatically displayed in both.

Open a workflow in the Workflow composer one of the following ways:

  • Select the Edit Yaml link for the workflow on the Workflows page.

  • Select the workflow name link on the Runs page.

Workflow composer
Figure 2. Workflow composer

Use the following feature to configure a workflow:

  1. Use the Workflow composer to:

    • Switch the repository branch by selecting branch name.

    • Exit workflow composer without saving changes by selecting Cancel.

    • Save changes to the workflow by selecting Commit.

    • Trigger a new workflow run by selecting Run.

      If the Run is not present, add a manual trigger. Refer to Configure a manual trigger.
  2. Configure workflow settings or triggers

    • Modify workflow name and env key/value pairs by selecting settings.

    • Select Trigger to add a new or Vertical ellispsis to edit an existing push, pull, manual, or schedule trigger.

  3. Configure a standard or approval job

    • Create a new job by selecting Job or Approval and then dragging it to the job area of the visual composer.

    • Modify an existing joby by selecting the Vertical ellipsis next to a job, and then select Edit.

    • Remove job needs object by double-clicking on the line connecting jobs.

  4. Adjust the composer view.

    • Resize composer width by dragging Resize.

    • Display only the visual tool by selecting Visual

    • Display only the code editor selecting Script

    • Display both by selecting Split.

      When SPLIT is active, select Horizontal split to arrange the visual tool above the code editor, or select Vertical split to arrange the visual tool and code editor side by side.

Use the workflow code editor

Use the workflow code editor to configure a workflow according to YAML formating specifications. For additional details related to configuring workflow objects refer to:

To use the code editor begin by opening a workflow in the Workflow composer one of the following ways:

  • Select the Edit Yaml link for the workflow on the Workflows page.

  • Select the workflow name link on the Runs page.

Code Editor
Figure 3. Code editor

Save a workflow

  1. In the workflow Composer, select COMMIT.

  2. Enter a Commit message.

  3. Select a branch to commit to from the following options:

    • Select Commit to a current branch:<current branch>.

    • Select Commit to a new branch, then enter a new branch name.

    • If committing to a new branch, you may optionally select Start a pull request to merge to <your default branch>.

  4. Select FINISH.

    Commit workflow
    Figure 4. Commit workflow
  5. Check your repository for the commit.

    All CloudBees platform workflows for your component are saved in .cloudbees/workflows in the connected repository.

Configure a push or pull trigger

Configure a workflow run to start with a push or pull-request.

To configure a push or pull-request trigger:

  • Use the code editor to configure push or pull trigger. Refer to CloudBees DSL syntax for code details.

    View push and pull trigger code examples
    apiVersion: automation.cloudbees.io/v1alpha1 kind: workflow name: Example 2 on: push: branches: - "**" tags: - git-tag-name pull_request: branches: - main jobs: build: steps: - name: Say hello uses: docker://golang:1.20.3-alpine3.17 shell: sh run: | echo "hello world"
  • Access trigger configuration features via the workflow Composer.

    • Create a new trigger by selecting Trigger or drag Trigger to the trigger area of the visual composer.

    • Modify an existing trigger by selecting the Vertical ellipsis next to a trigger, and then choosing Edit.

Code Editor
Figure 5. Edit push or pull trigger

Use these features to configure a push or pull-request trigger.

  1. Configure push or pull-request

    • Ensure Pull request or Push is the selected Type option.

    • Choose one or more branches in the Branches field by:

      • Entering ** to select all branches.

      • Selecting an existing branch.

      • Defining a branch pattern name.

    • Choose one or more git tags for a push trigger in the Tags field by:

      • Defining a tag patten names. (Recommended) e.g. "v*"

      • Entering a specific tag name. e.g. "v1.0"

  2. Manage trigger.

    • Remove a branch by selecting Vertical ellipsis next to a branch.

    • Exit and discard changes by selecting Cancel

    • Keep trigger configuration changes.

      1. Select Save. The schedule trigger is displayed in the visual composer trigger section and in the code editor: on: push or pull-request.

      2. Continue workflow configuration one of the following ways:

Configure a manual trigger

Only users with administrative permissions can trigger a workflow to run a manual workflow.

Add a manual trigger to the workflow to allow users with the proper permissions to trigger a workflow run. Add input parameters to the trigger to customize workflow runtime behavior. For example, use a parameter to select the deployment environment, enable or disable a feature during deployment, or select a server or service to deploy.

Avoid using parameters these types of data as parameter

Access tokens

Payment information

Binary data

Personally identifiable information

Encryption keys and certificates

Private keys

Large data files

Secrets and passwords

Long strings or complex data structures

Sensitive configuration files

Once configured, a user with proper permission can trigger a workflow using the:

To configure a manual trigger:

  • Use the code editor to configure a schedule trigger. Refer to CloudBees DSL syntax for code details.

    View manual trigger with input parameters
    apiVersion: automation.cloudbees.io/v1alpha1 kind: workflow name: Example 2 on: workflow_dispatch: inputs: stringIn: type: string default: String input value required: true description: Input string pickList: type: choice options: - abc - def - ghi default: abc description: Pick list description booleen: type: boolean default: true description: A Boolean entry RetryCount: type: number default: 3 required: true description: Retry deployment a certain number of times. jobs: build: steps: - name: Say hello uses: docker://golang:1.20.3-alpine3.17 shell: sh run: | echo "hello world"
  • Access trigger configuration features via the workflow Composer.

    • Create a new trigger by selecting Trigger or drag Trigger to the trigger area of the visual composer.

    • Modify an existing trigger by selecting the Vertical ellipsis next to a trigger, and then choosing Edit.

    Create trigger
    Figure 6. Edit manual trigger

Use these feature to configure a manual trigger.

  1. Configure a manual trigger:

    • Ensure Manual is the selected Type option.

    • Change parameter order.

      1. Select a parameter Move dots.

      2. Drag the step to new location in parameter sequence.

    • Create up to 10 input parameters.

      1. Select + add parameter.

      2. Select an input parameter type from the menu options.

        View parameter type definitions
        • String: Allows users to input a text-based value, which can then be used within the workflow to control behavior, pass data, or configure settings.

        • Number: This function accepts numerical inputs, allowing users to specify integer or floating-point values. For example, you can allocate the number of CPUs or memory units to set a threshold such as error_threshold: 100. You can also manage versions, timeouts, and IDs.

        • Boolean: This parameter type accepts binary values: true or false. It is ideal for toggling features, enabling or disabling specific steps, or controlling conditional logic within a workflow.

        • Choice: This parameter allows users to select a single option from a predefined list of choices. It is particularly useful to guide user input to specific, valid options, ensuring consistency and reducing the risk of errors.

          1. Enter a name for the parameter.

          2. Complete applicable fields

        • Enter a description for the parameter.

        • Enter a default parameter value. This value is applied when value is provided in the request.

        • Make the parameter value required in the request by selecting Required.

          If true, an error occurs when no value is provided for the parameter in the request and no default value is defined.

        View trigger input parameters
        apiVersion: automation.cloudbees.io/v1alpha1 kind: workflow name: Example 2 on: workflow_dispatch: inputs: stringIn: type: string default: String input value required: true description: Input string pickList: type: choice options: - abc - def - ghi default: abc description: Pick list description booleen: type: boolean default: true description: A Boolean entry RetryCount: type: number default: 3 required: true description: Retry deployment a certain number of times. jobs: build: steps: - name: Say hello uses: docker://golang:1.20.3-alpine3.17 shell: sh run: | echo "hello world"
  2. Complete manual approval trigger configuration:

    • Exit and discard changes by selecting Cancel.

    • Keep schedule trigger configuration changes.

      1. Select Save. The manual trigger is displayed in the visual composer trigger section and in the code editor: on: workflow_dispatch:.

      2. Continue workflow configuration one of the following ways.

Configure a schedule trigger

Use the schedule trigger to start a workflow run according to configured cron schedules. Scheduled triggers execute only on the default branch of the repository.

Cron expressions are configured in UTC timezone.

Once configured, workflow runs triggered by this schedule appear in the Runs list with trigger by details similar to:

#592 Scheduled At 0, 10, 26, 33, 40, and 50 minutes past the hour, every hour, every day (UTC).

Configure a schedule trigger:

  • Use the code editor to configure a schedule trigger. Refer to CloudBees DSL syntax for code details.

    View schedule trigger code examples
    apiVersion: automation.cloudbees.io/v1alpha1 kind: workflow name: Example 2 on: push: branches: - "**" schedule: - cron: 0 7 1 * 1,2,3,4 - cron: 0 14 * * 1,2,3,4 - cron: 0 15 * * 1,2,3,4 - cron: 0 16 * * 1,2,3,4 jobs: build: steps: - name: Say hello uses: docker://golang:1.20.3-alpine3.17 shell: sh run: | echo "hello world"
  • Access trigger configuration features via the workflow Composer.

    • Create a new trigger by selecting Trigger or drag Trigger to the trigger area of the visual composer.

    • Modify an existing trigger by selecting the Vertical ellipsis next to a trigger, and then choosing Edit.

    Edit schedule trigger
    Figure 7. Edit trigger

Use these features to configure a schedule trigger:

  1. Configure schedules

    • Ensure Schedule is the selected Type option.

    • Enter schedules in cron format.

  2. Manage schedules

    • Create schedules by selecting + new schedule.

    • Remove a schedule by selecting Vertical ellipsis next to a schedule.

    • Exit and discard changes by selecting Cancel.

    • Keep schedule trigger configuration changes.

      1. Select Save. The schedule trigger is displayed in the visual composer trigger section and in the code editor: on: schedule.

      2. Continue workflow configuration one of the following ways.

Configure a standard job

To configure a standard job:

  • Use the code editor to configure an approval job. Refer to CloudBees DSL syntax for code details.

  • Access job configuration features via the workflow Composer.

    • Create a new job by selecting Job or drag Job to the job area of the visual composer.

    • Modify an existing job by selecting the Vertical ellipsis next to a job, and then choosing Edit.

      Create job
      Figure 8. Edit job

Use these features to configure a standard job.

  1. Complete applicable job fields.

    • Enter name for the job.

    • Indicate the job or jobs that must complete successfully before the job runs by selecting Add needs.

    • Specify a job run environment by selecting the name from the Environment options.

  2. Manage services.

    Services is a Preview feature.
    View Service management information
    1. Access service configuration fields of the following ways.

      • Configure new service by selecting the Add service link.

      • Modify an existing service by to create a or the Vertical ellipsis next to a service, and then choosing Edit.

    2. Complete applicable service configuration fields:

    Service
    Figure 9. Service
    • Enter a name for the service.

    • Enter the docker image name or tag.

    • Specify the service environment by selecting the name from the Add environment options.

    • The argument values will override the values in the CMD Dockerfile. For details related service arg syntax, refer to jobs.<job_id>.services.<service_id>.args

  3. Manage steps.

    • Change job step order.

      1. Select a step Move dots.

      2. Drag the step to a new location in the job sequence.

    • Delete the step by selecting Vertical ellipsis in the step header, and then choosing Delete.

    • Create a new or modify an existing step.

      1. Access step configuration fields one of the the following ways.

        • Create a new step by selecting the Add step link.

        • Modify an existing step by selecting Vertical ellipsis next to a step, and then choosing Edit.

      2. Complete applicable step configuration fields:

        View image of Step fields
        Step
        Figure 10. Step
        • Enter a name for the step.

        • Locate and select a preconfigured action or container to execute the job from the Uses field options, or Select from catalog to search the catalog.

        • Select a Kind option (other than None) to use the data from this step for Analytics calculations.

  4. Modify job

    • Specify a job output key value pair by selecting Add output.

    • Exit and discard changes by selecting Cancel.

    • Keep job configuration changes.

      1. Select Save. The standard job is displayed in the visual composer and in the code editor, under jobs:.

      2. Continue workflow configuration one of the following ways.

Configure a manual approval job

Add a Manual approval custom job to insert a workflow approval. Once set up, approvers will be notified via email that an approval response is required.

To configure a manual approval job:

  • Use the code editor to configure an approval job. Refer to Manual approval for code details.

    View manual approval code example
    apiVersion: automation.cloudbees.io/v1alpha1 kind: workflow name: Example 2 on: push: branches: - "**" jobs: build: steps: - name: Say hello uses: docker://golang:1.20.3-alpine3.17 shell: sh run: | echo "hello world" workflow-approval: timeout-minutes: 4320 delegates: cloudbees-io/manual-approval/custom-job.yml@v1 with: approvers: de39a936-7a04-11ec-81d0-42010a83ae75 disallowLaunchByUser: true notifyAllEligibleUsers: true instructions: "Enter instructive text for approvers here. "
  • Access job configuration features via the workflow Composer.

    • Create a new job by selecting Job or dragging Job to the job area of the visual composer.

    • Modify an existing job by selecting the Vertical ellipsis next to a job, and then choosing Edit.

    Create manual approval
    Figure 11. Create manual approval

Use these features to configure a manual approval job.

  1. Complete applicable fields.

    • Enter a name for the approval job.

    • Review or modify the timeout-minutes default value of 4320 minutes. This is the number of minutes approvers have to respond to the approval request.

    • To specify a job or jobs that must successfully complete before the approval job runs.

      1. Select Add needs.

      2. Select the name of the job.

    • Select the name of users who can approve the workflow run. Both user IDs and email addresses are supported.

    • Enter instructive text for the approvers. This text will be visible in the approval email notification and run details.

    • Ensure that the person who starts the workflow cannot approve workflow by selecting Disallow workflow initiator from approving.

    • Specify who will receive notification to participate in workflow approval process by selecting Notify all eligible users.

      Notifications will be sent as follows:

      • If users are listed in Approvers and Notify all eligible users is true or false, then

        • Only listed approvers will receive notification.

        • Only listed approvers can participate in approval process.

      • If Approvers is blank and Notify all eligible users is false, then

        • No notifications will be sent.

        • All eligible users can participate in approval process.

      • If Approvers is blank and Notify all eligible users is true, then

        • The CloudBees platform will select and notify up to 10 eligible users.

        • All eligible users can participate in approval process.

  2. Complete approval job configuration.

    • Exit and discard changes by selecting Cancel.

    • Keep job configuration changes.

      1. Select Save. The approval job is displayed in the visual composer and in the code editor, under jobs: with delegates value of cloudbees-io/manual-approval/custom-job.yml@v1

      2. Continue workflow configuration one of the following ways.