While Nx Cloud provides several pre-built steps, you can create custom steps to suit your specific needs. Custom steps are defined by creating a new YAML file.
Defining a Custom Step
Section titled “Defining a Custom Step”To create a custom step, follow these steps:
1. Create a New YAML File: Create a new YAML file in your .nx/workflows
directory (e.g., custom-step.yaml
)
2. Define the Step Template: Below is an example of a custom step definition:
name: 'Custom Step'description: 'This is a custom step that does XYZ.'definition: using: 'node' main: './scripts/custom-script.js' post: './scripts/post-custom-script.js'inputs: - name: 'input1' description: 'Description for input1' default: 'default_value' required: true - name: 'input2' description: 'Description for input2' required: false
Explanation of Fields
Section titled “Explanation of Fields”name:
- The name of the custom step.
description:
- A description of what the custom step does.
definition:
- using: The runtime environment. Supported values are
node
andaggregate
.- node: If
using
is set tonode
, then onlymain
andpost
can be used. - aggregate: If
using
is set toaggregate
, then onlysteps
can be used.
- node: If
- main: Path to the main script to run (only if
using
isnode
). - post: Path to the post script to run (only if
using
isnode
).- runs before the agent is cleaned up
- steps: A list of sub-steps to be executed (only if
using
isaggregate
). Steps follow the same definition as launch templates.
- using: The runtime environment. Supported values are
inputs:
- name: The name of the input.
- description: A description of the input.
- default: Default value for the input.
- required: Whether the input is required.
Using Inputs in Scripts
Section titled “Using Inputs in Scripts”If your custom step has inputs, they can be accessed in scripts or JavaScript files using environment variables. Each input is prefixed with NX_CLOUD_INPUT_
. For example, if you have an input called input1
, you can access it in a JavaScript file like this:
const input1 = process.env.NX_CLOUD_INPUT_input1;console.log(`The value of input1 is: ${input1}`);
Using Custom Steps in Launch Templates
Section titled “Using Custom Steps in Launch Templates”Once you've defined your custom step, you can use it in your launch templates by referencing the custom step file. Here's an example:
launch-templates: custom-template: resource-class: 'docker_linux_amd64/medium' image: 'ubuntu22.04-node20.11-v7' init-steps: - name: Custom Step uses: 'your-org/your-repo/main/.nx/workflows/custom-steps.yaml' env: CUSTOM_VAR: 'custom_value' inputs: input1: 'value1' input2: 'value2'
Validating Custom Steps
Section titled “Validating Custom Steps”Just like launch templates, you should validate your custom steps to ensure they are defined correctly. In your CI pipeline, use the nx-cloud validate
command with the --step-file
flag to ensure nobody merges in invalid changes to your step:
nx-cloud validate --workflow-file=./.nx/workflows/custom-steps.yaml --step-file
Ensure your custom steps are committed to your source control repository before running the validation.
By defining and organizing custom steps in this way, you can create highly tailored workflows that meet the specific needs of your projects and CI/CD pipelines.