2019-12-05 09:57:32 -05:00
|
|
|
#!/usr/bin/env nextflow
|
2020-07-16 09:17:48 -04:00
|
|
|
import checksum
|
2019-12-05 16:11:12 -05:00
|
|
|
nextflow.preview.dsl = 2
|
2020-03-16 10:17:38 -04:00
|
|
|
|
2020-07-14 11:38:20 -04:00
|
|
|
params.out_dir = "test_output"
|
2020-03-16 10:17:38 -04:00
|
|
|
params.fastqc_args = ''
|
2020-07-14 11:38:20 -04:00
|
|
|
params.publish_dir_mode = "copy"
|
2020-03-16 10:17:38 -04:00
|
|
|
|
2020-07-14 11:38:20 -04:00
|
|
|
include { FASTQC } from '../main.nf'
|
2019-12-05 09:57:32 -05:00
|
|
|
|
2020-07-14 11:38:20 -04:00
|
|
|
/**
|
|
|
|
* Test if FASTQC runs with single-end data
|
|
|
|
*/
|
|
|
|
workflow test_single_end {
|
2020-07-17 04:43:50 -04:00
|
|
|
input_files = Channel.fromPath("${baseDir}/input/test_single_end.fastq.gz")
|
|
|
|
.map {f -> [f.name.replace(".fastq.gz", ""), true, f]}
|
2020-07-14 11:38:20 -04:00
|
|
|
FASTQC(input_files)
|
2020-07-16 08:20:37 -04:00
|
|
|
|
|
|
|
// test that the output looks as expected
|
|
|
|
FASTQC.out.html.map { name, is_single_end, html_file ->
|
2020-07-16 09:17:48 -04:00
|
|
|
html_hash = checksum.getMD5(new File("${html_file}"));
|
2020-07-16 08:20:37 -04:00
|
|
|
|
2020-07-17 04:43:50 -04:00
|
|
|
assert name == "test_single_end"
|
2020-07-16 08:20:37 -04:00
|
|
|
assert is_single_end == true
|
2020-07-17 04:43:50 -04:00
|
|
|
assert html_file.getName() == "test_single_end_fastqc.html"
|
2020-07-17 05:30:28 -04:00
|
|
|
// Hash seems to vary between local runs and GitHub Actions
|
|
|
|
// TODO: Might be solved when using Docker for tests?
|
|
|
|
// assert html_hash == "8ed68442ebb5b9706bf79b4f66701e15"
|
2020-07-16 08:20:37 -04:00
|
|
|
}
|
|
|
|
FASTQC.out.zip.map { name, is_single_end, zip_file ->
|
|
|
|
// NOTE: output zip files do not have a consistent hash
|
2020-07-17 04:43:50 -04:00
|
|
|
assert name == "test_single_end"
|
2020-07-16 08:20:37 -04:00
|
|
|
assert is_single_end == true
|
2020-07-17 04:43:50 -04:00
|
|
|
assert zip_file.getName() == "test_single_end_fastqc.zip"
|
2020-07-16 08:20:37 -04:00
|
|
|
}
|
2020-07-14 11:38:20 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test if FASTQC runs with paired end data
|
|
|
|
*/
|
|
|
|
workflow test_paired_end {
|
2020-07-15 09:07:19 -04:00
|
|
|
input_files = Channel.fromFilePairs("input/test_R{1,2}.fastq.gz")
|
2020-07-15 07:00:10 -04:00
|
|
|
.map {f -> [f[0], false, f[1]]}
|
2020-07-14 11:38:20 -04:00
|
|
|
FASTQC(input_files)
|
2020-07-16 08:20:37 -04:00
|
|
|
|
|
|
|
// test that the output looks as expected
|
|
|
|
FASTQC.out.html.map { name, is_single_end, html_files ->
|
|
|
|
html_r1 = html_files[0]
|
|
|
|
html_r2 = html_files[1]
|
|
|
|
|
2020-07-16 09:17:48 -04:00
|
|
|
html_r1_hash = checksum.getMD5(new File("${html_r1}"));
|
|
|
|
html_r2_hash = checksum.getMD5(new File("${html_r2}"));
|
2020-07-16 08:20:37 -04:00
|
|
|
|
|
|
|
assert name == "test_R"
|
|
|
|
assert is_single_end == false
|
|
|
|
assert html_r1.getName() == "test_R_1_fastqc.html"
|
|
|
|
assert html_r2.getName() == "test_R_2_fastqc.html"
|
|
|
|
assert html_r1_hash == "082c13ce7163ea0f52a66b83cb57b0f0"
|
|
|
|
assert html_r2_hash == "4ff04ec8da77e3af512f03b8c09a9e04"
|
|
|
|
}
|
|
|
|
FASTQC.out.zip.map { name, is_single_end, zip_files ->
|
|
|
|
zip_r1 = zip_files[0]
|
|
|
|
zip_r2 = zip_files[1]
|
|
|
|
// NOTE: output zip files do not have a consistent hash
|
|
|
|
|
|
|
|
assert name == "test_R"
|
|
|
|
assert is_single_end == false
|
|
|
|
assert zip_r1.getName() == "test_R_1_fastqc.zip"
|
|
|
|
assert zip_r2.getName() == "test_R_2_fastqc.zip"
|
|
|
|
}
|
2020-07-14 11:38:20 -04:00
|
|
|
}
|
2019-12-05 09:57:32 -05:00
|
|
|
|
2019-12-05 16:11:12 -05:00
|
|
|
workflow {
|
2020-07-14 11:38:20 -04:00
|
|
|
test_single_end()
|
|
|
|
test_paired_end()
|
2019-12-05 09:57:32 -05:00
|
|
|
}
|