Cache Task Results
When it comes to running tasks, caching etc., Lerna and Nx can be used interchangeably. When we say "Lerna can cache builds", we mean that Lerna uses Nx which can cache builds.
It's costly to rebuild and retest the same code over and over again. Lerna uses a computation cache to never rebuild the same code twice.
Setup
Lerna via Nx has the most sophisticated and battle-tested computation caching system. It knows when the task you are about to run has been executed before, so it can use the cache to restore the results of running that task.
If you don't have nx.json
, run npx lerna add-caching
.
To enable caching for build
and test
, edit the targetDefaults
property in nx.json
to include the build
and test
tasks:
{
"targetDefaults": {
"build": {
"cache": true
},
"test": {
"cache": true
}
}
}
Note, cacheable operations need to be side effect free, meaning that given the same input they should always result in the same output. As an example, e2e test runs that hit the backend API cannot be cached as the backend might influence the result of the test run.
Now, run the following command twice. The second time the operation will be instant:
lerna run build --scope=header
> lerna run build --scope=header
> header:build [existing outputs match the cache, left as is]
> header@0.0.0 build
> rimraf dist && rollup --config
src/index.tsx → dist...
created dist in 858ms
—————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————
Lerna (powered by Nx) Successfully ran target test for project header (4ms)
Nx read the output from the cache instead of running the command for 1 out of 1 tasks.
Replaying from Cache
When Lerna determines that the inputs for a task have not changed, it recreates the outputs of that task as if it actually ran on your machine - but much faster. The outputs of a cached task include both the terminal output and the files created in the defined output
directories for that task.
You can test this out by deleting the dist
folder that the header:build
task outputs to and then running lerna run build --scope=header
again. The cached task will replay instantly and the correct files will be present in the dist
folder.
header/
└── dist/ <-- this folder gets recreated
If your task creates output artifacts in a different location, you can change the output folder(s) that are cached. You can also customize which inputs will invalidate the cache if they are changed.
Advanced Caching
For a more in-depth understanding of the caching implementation and to fine-tune the caching for your repo, read How Caching Works.