DSL automation as code

8 minute readReferenceDeveloper productivity

DSL automation as code refers to the end-to-end process, or round-trip capability, of maintaining the domain specific language (DSL) representation of CloudBees CD/RO objects in a nested file structure. It is available for all CloudBees CD/RO objects.

Topics in this section:

Access this round-trip capability from the CloudBees CD/RO UI via the Export DSL and Import DSL service catalog items.

Service catalog items
Figure 1. Export DSL and Import DSL service catalog items

Navigate to the catalog items as follows:

  1. Select the Service Catalog tab in the topmost CloudBees CD/RO banner.

  2. Select DSL from the All Catalogs dropdown in the upper right of the Service Catalog page.

    From here, you access the Export DSL and Import DSL catalog items.

Example: copying a pipeline

This example shows how to copy an existing pipeline from an established project to a new project.

  1. Consider the pipeline below, both the visual representation on the left and the file hierarchy on the right.

    Existing pipeline
    └───projects
        └───ProjectProto
            │   project.dsl
            │
            └───pipelines
                ├───PipelineA
                │   │   pipeline.dsl
                │   │
                │   └───stages
                │       └───Stage 1
                │           └───tasks
                │                   Task 2.cmd
                │
                └───PipelineB
                        pipeline.dsl
  2. Use the Export DSL catalog item to create the DSL representation of the object hierarchy.

    Create the DSL representation
    Figure 2. Export the pipeline
  3. On the first part of the UI enter:

    • Resource: the resource on which to export the DSL. Enter a resource name from the Main Menu > Resources list. Here, `local ` is used to indicate the CloudBees CD/RO server system itself.

    • Directory Path: the directory path on Resource into which DSL is exported. In this case C:/DSLorig.

    • Object Type, select the top-level object type. In this case, Project.

    • Project: select the source project. In this case, ProjectProto is the project housing the pipeline.

  4. Then, set options as detailed below, noting required options important for this example.

    Option Setting Notes

    Options for Exporting DSL

    Suppress Nulls

    checked

    Optional. Check to exclude fields with null values in the exported DSL to reduce bulk of resulting DSL file.

    Suppress Defaults

    checked

    Optional. Check to suppress the default values for API arguments. Consider the failProcedure procedure step; it has a default value for its errorHandling argument. With Suppress Defaults checked for a procedure that includes the failProcedure procedure step without errorHandling specified, the exported DSL suppresses the value for errorHandling. This option is not meant to suppress the formal parameter defaults.

    Suppress Parent

    checked

    Required. Check to suppress information about the top-level project. Checking this creates a project-agnostic DSL file.

    Include ACLs

    as required

    Optional. Include access control lists as required.

    Options for Child Objects

    Include All Child Objects

    unchecked

    Required. Uncheck in order to restrict export just to pipelines.

    Child Object Types to Include

    pipelines

    Required. Export just pipelines to DSL file.

    Include all Child Objects in a Single DSL File

    unchecked

    Required. Export into a single DSL file.

    Child Object Types to Export to Separate DSL files

    pipelines

    All pipeline information is exported to separate files in order to aid in cherry-picking files connected with pipeline to be copied.

  5. Create a new folder representing the project into which you copy the PipelineA file hierarchy, and copy the files, highlighted in violet. In this example, C:/DSLtest/projects/MyNewProject is the folder representing the new project.

    C:DSLorig
    └───projects
        └───ProjectProto
            │   project.groovy
            │
            └───pipelines
                ├───PipelineA
                │   │   pipeline.dsl
                │   │
                │   └───stages
                │       └───Stage 1
                │           └───tasks
                │                   Task 2.cmd
                │
                └───PipelineB
                        pipeline.dsl
    C:DSLtest
    └───projects
        └───MyNewProject
            └───pipelines
                └───PipelineA
                    │   pipeline.dsl
                    │
                    └───stages
                        └───Stage 1
                            └───tasks
                                    Task 2.cmd
  6. Use the ImportDSL catalog item to import PipelineA copy into project MyProject.

  7. Enter the resource name and directory path to the DSL hierarchy. In this case, local ` and `C:/DSLtest are entered, respectively.

  8. Select OK. The Job Details page displays ongoing status during the import.

    Import the pipeline
    Figure 3. Import the pipeline
  9. View the new pipeline.

    View the pipeline
    Figure 4. View the pipeline

Using the export DSL catalog item

Use the Export DSL catalog item to create the DSL representation of the object hierarchy. With this UI, you can specify details about the top-level object and desired nested objects you wish to export to the file system. By default, the DSL is exported into separate files in a directory tree representing the object hierarchy, for ease of editing and management.

Select Export on the Export DSL tile to get started. The New Export DSL dialog displays. Refer to the table below for configuration details. When finished, select OK to save your preferences and initiate the export.

Label Description

Resource Name

(Required) The resource where the DSL files are to be written. Enter a resource name from the Main Menu > Resources list.

Directory Path

(Required) The directory on the resource where the DSL files are to be written. In cluster mode, and as an overall best practice, specify a path on a shared drive.

Object Type

(Required) The top-level object type of the exported DSL hierarchy. Choose one from the dropdown.

<object name>

(Required) The specific top-level object name The label and contents of this pull down is context-sensitive based on the Object Type.

Options for exporting DSL

These options control what is emitted in the exported DSL for each child object.

Suppress Nulls

Select to suppress both object and custom properties with null values in the exported DSL. If not selected, all properties are returned, subject to Suppress Defaults setting.

To override null values for custom properties from being suppressed, set the server setting, disableNotSuppressNullsOption, to true:

ectool setProperty /server/settings/disableNotSuppressNullsOption true

Suppress Defaults

Select to suppress object and custom properties with default values in the exported DSL.

Suppress Parent

Select to exclude the object’s parent references in the exported DSL.

Include ACLs

Select to include each object’s access control list in the exported DSL.

Options for child objects

These options control how the hierarchy is stored in the file structure.

Include All Child Objects

Select to include all child objects in the top-level object hierarchy specified by <object name>.

If not selected, the Child Object Types to Include box opens. Enter a comma-separated list of child object types to include.

Use the describeObjectTypeStructure command to get a list of the hierarchy for a given top-level object type. Peruse the hierarchy for the child object of interest and use its objectType.collectionName as the value to include in the comma-separated list.

Example: pipelines,releases,applications

Include all Child Objects in a Single DSL File

Select to include all child objects into a single DSL file.

If not selected, the Child Object Types to Export to Separate DSL files box opens. Enter a comma-separated list of child object types.

  • Wildcard characters are accepted.

  • Qualify the object as needed to uniquely specify it.

Example: pipelines,procedures.*,applications.applicationTiers.components

Refer to Specifying child object lists for more details about specifying lists.

Specifying child object lists

Use information in this section to help you formulate child object lists when you wish to export your objects into separate DSL files. That is, when Include all Child Objects in a Single DSL File is not selected.

Use the describeObjectTypeStructure command to get a list of the hierarchy for a given top-level object type. Peruse the hierarchy for the child object of interest and use its objectType.collectionName as the value to include in the comma-separated list.

For example, to get the hierarchy of child objects for the project top-level type, use:

ectool describeObjectTypeDslStructure --objectType project --topLevelOnly 1

This returns a project object detail and the list of its child objects. Choose any combination of child types and pass them as a comma-separated list. Listing a child type generates DSL for all entities of that type and for all its child entities. Only types listed are included in DSL generation process.

  • Wildcard characters are accepted.

  • Qualify the object as needed to uniquely specify it.

For example:

  • pipelines,releases:

    • Each pipeline and release full hierarchy placed into its own file.

  • pipelines.stages:

    • Each pipeline partial hierarchy down to the stage level placed into its own file.

    • Each stage and all nested hierarchy placed into its own file, nested under its pipeline in the file structure.

  • pipelines.stages.tasks:

    • Each pipeline partial hierarchy down to the stage level placed into its own file.

    • Each stage and task placed into its own file, nested under its pipeline in the file structure.

  • pipelines.*:

    • Each pipeline and every nested component, down to gate tasks and pre- and post-gate elements, placed under it in its own file, nested under its pipeline in the file structure.

Using the import DSL catalog item

Use the Import DSL catalog item to run the specified domain-specific language script, thus creating a new or overwriting an existing object hierarchy. With this UI, you specify details about the file system location from which the import takes place.

All information at the specified Directory Path is imported, so make sure you have made desired changes to the DSL scripts before you initiate the import. Otherwise, you could unintentionally overwrite your current objects.

Select Import on the Import DSL tile to get started. The New Import DSL dialog displays. When finished, select OK to save your preferences.

Label Description

Resource Name

(Required) The resource where the DSL files are read from. Enter a resource name from the Main Menu > Resources list. Specify `local ` to work with a local directory.

Directory Path

(Required) The directory on the resource from which the DSL files are read. In cluster mode, and as an overall best practice, specify a path on a shared drive.

Overwrite

(Required) Select to enable overwrite mode.

  • If the object exists, all attributes and child objects are overwritten by the values in the DSL files.

  • If an existing child object is absent in the imported DSL, it is deleted by the import.

  • If an existing top-level object is absent in the imported DSL, it is not deleted. This applies to top-level children of a project such as applications, pipeline, releases, environments, an so on.

Using the import DSL from git catalog item

You can use the Import DSL from Git catalog item to run the specified domain-specific language script from a Git repository; creating a new or overwriting an existing object hierarchy. With this UI, you can specify details about the Git repository, the branch name, and the location in the checked-out directory from which the import takes place.

All information at the specified Directory Path is imported, so make sure you have made desired changes to the DSL scripts before you initiate the import. Otherwise, you could unintentionally overwrite your current objects.

Select Import on the Import DSL from Git tile to get started. The New Import DSL from Git dialog displays. When finished, select OK to save your preferences.

Label Description

Git Plugin Configuration

(Required) The name of the ECSCM-Git plugin configuration for the Git repository. To create the Git repository configuration, from the CloudBees CD/RO main menu select Administration  Plugins. From the displayed Plugins page, select ECSCM-Git > Create Configuration.

Git Repository

(Required) The Git repository URL from which to import the DSL. For example, https://github.com/my-github-org/demo-project.git.

Repository Branch

The Git repository branch to use. If not specified, master is used.

Resource Name

(Required) The resource from where the DSL files are read. Enter a resource name from the Main Menu > Resources list. Specify local to work with a local directory.

Checkout Directory

(Required) The directory on Resource Name to where Repository Branch is checked out and from where the DSL files are read. In cluster mode you must specify a path on a shared drive.

Relative path to DSL files

The relative path within Checkout Directory containing the DSL files to import. All DSL files at this location and in subdirectories are imported.

Overwrite

Select to enable overwrite mode.

  • If the object exists, all attributes and child objects are overwritten by the values in the DSL files.

  • If an existing child object is absent in the imported DSL, it is deleted by the import.

  • If an existing top-level object is absent in the imported DSL, it is not deleted. This applies to top-level children of a project such as applications, pipelines, releases, environments, an so on.

Delete directory after import

Select to delete Checkout Directory after the DSL import is finished.