Concurrency and parallelism
Running tests and deployments in parallel is crucial for high-performing companies that cannot afford long waiting times. In Buddy, the number of pipelines and actions that can be run simultaneously is specified by the number of runners in the workspace plan. 1 runner means that only 1 pipeline can be run at a given time. 2 runners means that you can run 2 pipelines at the same time, or 1 pipeline with 2 parallelized actions, etc. etc.
Pipelines
Pipeline concurrency defines how many pipelines can run at the same time. When the number of triggered pipelines is greater that the number of runners in your plan, the subsequent executions get enqueued and wait for all previously triggered pipelines to finish.
Two pipelines running concurrently
Actions
To speed up tasks like testing and multi-server deployment, actions can be run in parallel. As with the pipelines, the number of actions that can be run simultaneously depends on the chosen plan. For example, if your plan includes 4 runners, it means you have the capability to run either 4 actions in one pipeline, or 2 pipelines with 2 parallel actions concurrently.
Three deployment actions bound in hard parallel
Soft and hard parallels
Soft and hard parallels are a way of you telling Buddy how important it is for the actions to run at the same time. Actions joined in hard parallel have to always run together, that's why at the start of every pipeline run a number of required runners is allocated to ensure these actions execute simultaneously. Since such operation can cause queues, we recommend using it for critical workflows only.
Actions linked in a soft parallel, will only run at the same time whenever there are enough free runners available in the workspace. If there are not enough free runners, the actions will run in an order set in the pipeline.
Choosing between soft and hard parallel
Use case: Parallel testing
In this example we'll create a pipeline which splits test files into three packages and runs them in parallel:
Example pipeline with split test packages
Configuration
- Create a new pipeline in your project.
Choose the Split Test Files action from the action list:
Split Test Files action
Select the number of groups (packages) into which you want to split the tests. In this example, we’ll use 3 packages.
- Choose if you want to sort them alphabetically or by file size.
Provide the path to the directory with test files. You can do it in two ways:
a. Select one file with the paths to split (each path in a separate line)
b. Use glob patterns:*
– matches any sequence of characters (excluding path separators)**
– matches any sequence of characters (including path separators)?
– matches any single character (excluding path separators)[abc]
– matches any character (excluding path separators) against characters in brackets{foo,bar,...}
– matches a sequence of characters for alternatives in the braces
Once done, save the changes:
Action configuration
The action creates environment variables required to run the tests in parallel:
$BUDDY_SPLIT_1
,$BUDDY_SPLIT_2
,$BUDDY_SPLIT_3
, etc. etc. Once the pipeline is executed, you can see the variables in the logs:Action logs
Next, you need to prepare the environment for the tests (install dependencies etc.) in the build action:
Build action with npm install
The last part is adding an action that will run the tests using the proper variable from the Split Test Files action:
Build action with variables generated by the Split Test Files action
See also
Last modified on June 6, 2024