Test-data Specifications
The key words “MUST”, “MUST NOT”, “SHOULD”, etc. are to be interpreted as described in RFC 2119.
1 General
1.1 Replication of test data
The new test data file within a branch (modules or pipelines) SHOULD NOT replicate existing test-data unless absolutely necessary
- If you need to make a new file that can be generated from an upstream file
- For example, if you need a particular bioinformatic index file for a tool, index an existing FASTA file on the test-datasets branch
CI tests for nf-core modules, subworkflows, or pipeline are not required to produce meaningful output.
The main goal for nf-core CI tests are to ensure a given tool ‘happily’ executes without errors.
It is OK for a test to produce nonsense output, or find ‘nothing’, as long as the tool does not crash or produce an error.
You SHOULD therefore reuse existing test data as far as possible to reduce the size of our test dataset repository.
You SHOULD only upload new test data if there is absolutely no other option within the existing test-data archive.
1.2 Size of test data
Test data SHOULD be as small as possible
- It cannot exceed the GitHub file maximum
- Data should be sub-sampled as aggressively as possible
1.3 License of test data
Test data MUST be publicly available and have licenses to allow public reuse
1.4 Documentation of test data
Test data files SHOULD be described on the given branch’s README file, describing source, how generated, licenses etc.
2 Modules
- In order to keep the size of the test data repository as minimal as possible, pre-existing files from nf-core/test-datasetsMUST be reused if at all possible.
- If the appropriate test data doesn’t exist in the modulesbranch ofnf-core/test-datasetsplease contact us on the nf-core Slack#moduleschannel (you can join with this invite) to discuss possible options.
- It may not be possible to add test data for some modules e.g. if the input data is too large or requires a local database. In these scenarios, it is recommended to use the Nextflow stubfeature to test the module. Please refer to thegtdbtk/classifymodule and its corresponding test script to understand how to use this feature for your module development.
2.1 Module test data organisation
Files SHOULD be generally organised based on existing structure, typically (for bioinformatics pipelines) by discipline, organism, platform or format
2.2 Relatedness of module test data
Downstream or related test-data files SHOULD be named based on the upstream file name
- For example, if you used genome.fastaas the upstream file, your output file should be calledgenome.<new_extension>.
2.3 Module test data documentation
Test data files MUST have an entry in the nf-core/test-datasets repo README