nf-test utility functions
This repository contains utility functions for nf-test.
These functions are used to help capture level tests using nf-test.
nf-core pipelines create a yml file listing all the versions of the software used in the pipeline.
Here is an example of this file coming from the rnaseq pipeline.
UNTAR:
untar: 1.34
Workflow:
nf-core/rnaseq: v3.16.0dev
Nextflow: 24.04.4
This function remove the Nextflow version from this yml file, as it is not relevant for the snapshot. Therefore for the purpose of the snapshot, it would consider this to be the contents of the YAML file:
UNTAR:
untar: 1.34
Workflow:
nf-core/rnaseq: v3.16.0dev
Usage:
assert snapshot(removeNextflowVersion("$outputDir/pipeline_info/nf_core_rnaseq_software_mqc_versions.yml")).match()
The only argument is path to the file which must be a versions file in YAML format as per the nf-core standard.
Files produced by a pipeline can be compared to a snapshot. This function produces a list of all the content of a directory, and can exclude some files based on a glob pattern. From there one can get just filenames and snapshot only the names when content is not stable. Or snapshot the whole list of files that have stable content.
In this example, these are the files produced by a pipeline:
results/
├── pipeline_info
│ └── execution_trace_2024-09-30_13-10-16.txt
└── stable
├── stable_content.txt
└── stable_name.txt
2 directories, 3 files
In this example, 1 file is stable with stable content (stable_content.txt
), and 1 file is stable with a stable name (stable_name.txt
).
The last file has no stable content (execution_trace_2024-09-30_13-10-16.txt
) as its name is based on the date and time of the pipeline execution.
For this example, we want to snapshot the files that have stable content, and the names of files and folders that are stable. stable_name
is a list of every file and folder except those matching the glob pipeline_info/execution_*.{html,txt}
. stable_content
is a list of every file except those matching the two globs pipeline_info/execution_*.{html,txt}
and **/stable_name.txt
which is contained in the tests/getAllFilesFromDir/.nftignore
file. By using stable_name*.name
, we extract the name of every file in stable_name
and add them to the snapshot. stable_content
can be used in the snapshot directly to include the hash of the file contents.
def stable_name = getAllFilesFromDir(params.outdir, true, ['pipeline_info/execution_*.{html,txt}'], null )
def stable_content = getAllFilesFromDir(params.outdir, false, ['pipeline_info/execution_*.{html,txt}'], 'tests/getAllFilesFromDir/.nftignore' )
assert snapshot(
stable_name*.name,
stable_content
).match()
First argument is the pipeline outdir
directory path, second is a boolean to include folders, and the third is a list of glob patterns to ignore, and the fourth is a file containing a list of glob patterns to ignore.