From 2b977a47af8a319f6ef6e7b918e7bb64babbaa04 Mon Sep 17 00:00:00 2001 From: Suzanne Jin Date: Thu, 16 Jan 2025 12:24:18 +0100 Subject: [PATCH 1/2] update NORM meta in abundance_differential_filter (#7302) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * modified abundance_differential_filter to use meta_exp in deseq_norm and limma_norm, and updated test snapshots * update snapshot * update snapshot * revert order to call modules * revert test name * update snapshot * update snapshot * fix bug related to norm_inputs * avoid running multiple times NORM unecessarily by using unique(). Updated snapshots * remove view() * add back norm_inputs to avoid repeated computation of all the contrasts * distinguish contrasts_for_diff and contrasts_for_norm * remove unique() * add view to check everything is right * update view * update view * remerge criteria but with def meta at the beginning * remove view. bug fixed. --------- Co-authored-by: Matthias Hörtenhuber --- .../abundance_differential_filter/main.nf | 27 +-- .../abundance_differential_filter/meta.yml | 2 +- .../tests/deseq2_basic.config | 8 +- .../tests/deseq2_limmavoom_basic.config | 6 +- .../tests/deseq2_limmavoom_propd_basic.config | 6 +- .../tests/main.nf.test | 4 +- .../tests/main.nf.test.snap | 160 ++++++------------ 7 files changed, 83 insertions(+), 130 deletions(-) diff --git a/subworkflows/nf-core/abundance_differential_filter/main.nf b/subworkflows/nf-core/abundance_differential_filter/main.nf index 4930b708b55..8c11efa55eb 100644 --- a/subworkflows/nf-core/abundance_differential_filter/main.nf +++ b/subworkflows/nf-core/abundance_differential_filter/main.nf @@ -31,15 +31,16 @@ workflow ABUNDANCE_DIFFERENTIAL_FILTER { // Set up how the channels crossed below will be used to generate channels for processing def criteria = multiMapCriteria { meta_input, abundance, analysis_method, fc_threshold, stat_threshold, meta_exp, samplesheet, meta_contrasts, variable, reference, target -> + def meta_for_diff = mergeMaps(meta_contrasts, meta_input) + [ 'method': analysis_method ] + def meta_input_new = meta_input + [ 'method': analysis_method ] samples_and_matrix: - meta_map = meta_input + [ 'method': analysis_method ] - [meta_map, samplesheet, abundance] - contrasts: - meta_map = mergeMaps(meta_contrasts, meta_input) + [ 'method': analysis_method ] - [ meta_map, variable, reference, target ] + [ meta_input_new, samplesheet, abundance ] + contrasts_for_diff: + [ meta_for_diff, variable, reference, target ] filter_params: - meta_map = mergeMaps(meta_contrasts, meta_input) + [ 'method': analysis_method ] - [meta_map, [ 'fc_threshold': fc_threshold, 'stat_threshold': stat_threshold ]] + [ meta_for_diff, [ 'fc_threshold': fc_threshold, 'stat_threshold': stat_threshold ]] + contrasts_for_norm: + [ meta_input_new, variable, reference, target ] } // For DIFFERENTIAL modules we need to cross the things we're iterating so we @@ -70,13 +71,13 @@ workflow ABUNDANCE_DIFFERENTIAL_FILTER { // LIMMA_NORM directly. It internally runs normalization + DE analysis. LIMMA_NORM( - norm_inputs.contrasts.filter{it[0].method == 'limma'}.first(), + norm_inputs.contrasts_for_norm.filter{it[0].method == 'limma'}, norm_inputs.samples_and_matrix.filter{it[0].method == 'limma'} ) LIMMA_DIFFERENTIAL( - inputs.contrasts.filter{it[0].method == 'limma'}, - inputs.samples_and_matrix.filter { it[0].method == 'limma' } + inputs.contrasts_for_diff.filter{ it[0].method == 'limma' }, + inputs.samples_and_matrix.filter{ it[0].method == 'limma' } ) // ---------------------------------------------------- @@ -91,14 +92,14 @@ workflow ABUNDANCE_DIFFERENTIAL_FILTER { // DESEQ2_NORM directly. It internally runs normalization + DE analysis. DESEQ2_NORM( - norm_inputs.contrasts.filter{it[0].method == 'deseq2'}.first(), + norm_inputs.contrasts_for_norm.filter{it[0].method == 'deseq2'}, norm_inputs.samples_and_matrix.filter{it[0].method == 'deseq2'}, ch_control_features.first(), ch_transcript_lengths.first() ) DESEQ2_DIFFERENTIAL( - inputs.contrasts.filter{it[0].method == 'deseq2'}, + inputs.contrasts_for_diff.filter{it[0].method == 'deseq2'}, inputs.samples_and_matrix.filter{it[0].method == 'deseq2'}, ch_control_features.first(), ch_transcript_lengths.first() @@ -112,7 +113,7 @@ workflow ABUNDANCE_DIFFERENTIAL_FILTER { // not produce a normalized matrix. PROPR_PROPD( - inputs.contrasts.filter{it[0].method == 'propd'}, + inputs.contrasts_for_diff.filter{it[0].method == 'propd'}, inputs.samples_and_matrix.filter { it[0].method == 'propd' } ) diff --git a/subworkflows/nf-core/abundance_differential_filter/meta.yml b/subworkflows/nf-core/abundance_differential_filter/meta.yml index 509520f3ec3..cc22f805353 100644 --- a/subworkflows/nf-core/abundance_differential_filter/meta.yml +++ b/subworkflows/nf-core/abundance_differential_filter/meta.yml @@ -133,7 +133,7 @@ output: authors: - "@pinin4fjords" - "@bjlang" - - "@araiz2001" + - "@caraiz2001" - "@suzannejin" maintainers: - "@pinin4fjords" diff --git a/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_basic.config b/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_basic.config index 508fa04aedc..d6918e56f6a 100644 --- a/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_basic.config +++ b/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_basic.config @@ -1,10 +1,14 @@ process { withName: 'DESEQ2_DIFFERENTIAL' { - ext.args = { "--round_digits 5 --blocking_variables $meta.blocking --vs_method rlog" } + ext.args = { [ + "--round_digits 5", + "--vs_method rlog", + (meta.blocking == null) ? "" : "--blocking_variables $meta.blocking" + ].join(' ').trim() } ext.prefix = { "${meta.id}_${meta.method}" } } withName: 'DESEQ2_NORM' { - ext.prefix = { "${meta.id}_${meta.method}_voom_norm" } + ext.prefix = { "${meta.id}_${meta.method}_norm" } } } diff --git a/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_limmavoom_basic.config b/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_limmavoom_basic.config index a2b6e9efbd9..14fcfefa6dd 100644 --- a/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_limmavoom_basic.config +++ b/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_limmavoom_basic.config @@ -1,6 +1,10 @@ process { withName: 'DESEQ2_DIFFERENTIAL' { - ext.args = { "--round_digits 5 --blocking_variables $meta.blocking --vs_method rlog" } + ext.args = { [ + "--round_digits 5", + "--vs_method rlog", + (meta.blocking == null) ? "" : "--blocking_variables $meta.blocking" + ].join(' ').trim() } ext.prefix = { "${meta.id}_${meta.method}" } } diff --git a/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_limmavoom_propd_basic.config b/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_limmavoom_propd_basic.config index 8bd211bad64..dda5df4bcd4 100644 --- a/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_limmavoom_propd_basic.config +++ b/subworkflows/nf-core/abundance_differential_filter/tests/deseq2_limmavoom_propd_basic.config @@ -1,6 +1,10 @@ process { withName: 'DESEQ2_DIFFERENTIAL' { - ext.args = { "--round_digits 5 --blocking_variables $meta.blocking --vs_method rlog" } + ext.args = { [ + "--round_digits 5", + "--vs_method rlog", + (meta.blocking == null) ? "" : "--blocking_variables $meta.blocking" + ].join(' ').trim() } ext.prefix = { "${meta.id}_${meta.method}" } } diff --git a/subworkflows/nf-core/abundance_differential_filter/tests/main.nf.test b/subworkflows/nf-core/abundance_differential_filter/tests/main.nf.test index 8cbb8cf8767..500a2e800fe 100644 --- a/subworkflows/nf-core/abundance_differential_filter/tests/main.nf.test +++ b/subworkflows/nf-core/abundance_differential_filter/tests/main.nf.test @@ -16,7 +16,7 @@ nextflow_workflow { test("deseq2 - mouse - basic") { config './deseq2_basic.config' - tag "deseq2" + tag "deseq2_basic" when { workflow { @@ -74,7 +74,7 @@ nextflow_workflow { test("limma - basic - microarray") { config './limma_basic_microarray.config' - tag "limma" + tag "limma_basic_microarray" setup { run("UNTAR") { diff --git a/subworkflows/nf-core/abundance_differential_filter/tests/main.nf.test.snap b/subworkflows/nf-core/abundance_differential_filter/tests/main.nf.test.snap index dba530f24eb..6795359ae88 100644 --- a/subworkflows/nf-core/abundance_differential_filter/tests/main.nf.test.snap +++ b/subworkflows/nf-core/abundance_differential_filter/tests/main.nf.test.snap @@ -28,7 +28,7 @@ ] ], [ - + ], [ [ @@ -48,9 +48,9 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.10.2" + "nextflow": "24.10.3" }, - "timestamp": "2024-12-07T16:33:03.091762783" + "timestamp": "2025-01-14T16:51:17.162826924" }, "deseq2 and limma - mouse - basic": { "content": [ @@ -157,38 +157,26 @@ [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test_deseq2_norm.normalised_counts.tsv:md5,46ab7200c626649ab6256ed797ef5071" + "test_deseq2_norm.normalised_counts.tsv:md5,46ab7200c626649ab6256ed797ef5071" ], [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "limma" }, - "treatment_mCherry_hND6__test_limma_voom_norm.normalised_counts.tsv:md5,2aa4880ba5ae246a728b25f4316ca2ca" + "test_limma_voom_norm.normalised_counts.tsv:md5,2aa4880ba5ae246a728b25f4316ca2ca" ] ], [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test_deseq2_norm.rlog.tsv:md5,b1adc1fba6bd0c8b55973608f4b97030" + "test_deseq2_norm.rlog.tsv:md5,b1adc1fba6bd0c8b55973608f4b97030" ] ], [ @@ -246,9 +234,9 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.10.2" + "nextflow": "24.10.3" }, - "timestamp": "2024-12-07T16:34:54.548033825" + "timestamp": "2025-01-14T16:53:11.245100955" }, "limma - voom": { "content": [ @@ -283,14 +271,10 @@ [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "limma" }, - "treatment_mCherry_hND6__test_limma_voom_norm.normalised_counts.tsv:md5,2aa4880ba5ae246a728b25f4316ca2ca" + "test_limma_voom_norm.normalised_counts.tsv:md5,2aa4880ba5ae246a728b25f4316ca2ca" ] ], [ @@ -324,9 +308,9 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.10.2" + "nextflow": "24.10.3" }, - "timestamp": "2024-12-07T16:33:26.97858478" + "timestamp": "2025-01-14T16:51:32.460857013" }, "deseq2 + limma-voom + propd - mouse - basic": { "content": [ @@ -505,38 +489,26 @@ [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test_deseq2_norm.normalised_counts.tsv:md5,46ab7200c626649ab6256ed797ef5071" + "test_deseq2_norm.normalised_counts.tsv:md5,46ab7200c626649ab6256ed797ef5071" ], [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "limma" }, - "treatment_mCherry_hND6__test_limma_voom_norm.normalised_counts.tsv:md5,2aa4880ba5ae246a728b25f4316ca2ca" + "test_limma_voom_norm.normalised_counts.tsv:md5,2aa4880ba5ae246a728b25f4316ca2ca" ] ], [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test_deseq2_norm.rlog.tsv:md5,b1adc1fba6bd0c8b55973608f4b97030" + "test_deseq2_norm.rlog.tsv:md5,b1adc1fba6bd0c8b55973608f4b97030" ] ], [ @@ -596,9 +568,9 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.10.2" + "nextflow": "24.10.3" }, - "timestamp": "2024-12-13T16:07:08.941008861" + "timestamp": "2025-01-14T16:53:54.80697542" }, "stub": { "content": [ @@ -656,32 +628,24 @@ ] ], "2": [ - + ], "3": [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test.normalised_counts.tsv:md5,d41d8cd98f00b204e9800998ecf8427e" + "test.normalised_counts.tsv:md5,d41d8cd98f00b204e9800998ecf8427e" ] ], "4": [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test.rlog.tsv:md5,d41d8cd98f00b204e9800998ecf8427e" + "test.rlog.tsv:md5,d41d8cd98f00b204e9800998ecf8427e" ] ], "5": [ @@ -713,7 +677,7 @@ "versions.yml:md5,05e3901f6d78f8839a7e07f422e9bc03" ], "adjacency": [ - + ], "model": [ [ @@ -742,14 +706,10 @@ "normalised_matrix": [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test.normalised_counts.tsv:md5,d41d8cd98f00b204e9800998ecf8427e" + "test.normalised_counts.tsv:md5,d41d8cd98f00b204e9800998ecf8427e" ] ], "results_genewise": [ @@ -807,14 +767,10 @@ "variance_stabilised_matrix": [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test.rlog.tsv:md5,d41d8cd98f00b204e9800998ecf8427e" + "test.rlog.tsv:md5,d41d8cd98f00b204e9800998ecf8427e" ] ], "versions": [ @@ -825,9 +781,9 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.10.2" + "nextflow": "24.10.3" }, - "timestamp": "2024-12-13T15:08:45.989521056" + "timestamp": "2025-01-14T16:54:12.823125892" }, "deseq2 - mouse - basic": { "content": [ @@ -886,27 +842,19 @@ [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test_deseq2_voom_norm.normalised_counts.tsv:md5,46ab7200c626649ab6256ed797ef5071" + "test_deseq2_norm.normalised_counts.tsv:md5,46ab7200c626649ab6256ed797ef5071" ] ], [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test_deseq2_voom_norm.rlog.tsv:md5,b1adc1fba6bd0c8b55973608f4b97030" + "test_deseq2_norm.rlog.tsv:md5,b1adc1fba6bd0c8b55973608f4b97030" ] ], [ @@ -940,9 +888,9 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.10.2" + "nextflow": "24.10.3" }, - "timestamp": "2024-12-07T16:32:17.301539736" + "timestamp": "2025-01-14T16:50:35.085607799" }, "deseq2 - with transcript lengths": { "content": [ @@ -1001,27 +949,19 @@ [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test_deseq2_voom_norm.normalised_counts.tsv:md5,7050f44c460cc13e3f101d048d503527" + "test_deseq2_norm.normalised_counts.tsv:md5,7050f44c460cc13e3f101d048d503527" ] ], [ [ { - "id": "treatment_mCherry_hND6__test", - "variable": "treatment", - "reference": "mCherry", - "target": "hND6", - "blocking": "", + "id": "test", "method": "deseq2" }, - "treatment_mCherry_hND6__test_deseq2_voom_norm.rlog.tsv:md5,22a4b117246b2317e0f4daf7919703f2" + "test_deseq2_norm.rlog.tsv:md5,22a4b117246b2317e0f4daf7919703f2" ] ], [ @@ -1055,9 +995,9 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.10.2" + "nextflow": "24.10.3" }, - "timestamp": "2024-12-07T16:34:05.584119298" + "timestamp": "2025-01-14T16:52:07.822745077" }, "propd - mouse - basic": { "content": [ @@ -1144,8 +1084,8 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.10.2" + "nextflow": "24.10.3" }, - "timestamp": "2024-12-13T15:02:45.903371649" + "timestamp": "2025-01-14T16:52:25.336720308" } -} +} \ No newline at end of file From 070b1ad7a9732b2ddc66fbb1407da05af8ff8ff9 Mon Sep 17 00:00:00 2001 From: Michael L Heuer Date: Thu, 16 Jan 2025 07:10:34 -0600 Subject: [PATCH 2/2] Update seqkit to version 2.9.0 (#7314) * Update seqkit to version 2.9.0 * Add stub sections where missing * Update nf-test checksums --- modules/nf-core/seqkit/fx2tab/environment.yml | 2 +- modules/nf-core/seqkit/fx2tab/main.nf | 16 +++++- .../seqkit/fx2tab/tests/main.nf.test.snap | 34 ++++++------ modules/nf-core/seqkit/tab2fx/environment.yml | 2 +- modules/nf-core/seqkit/tab2fx/main.nf | 16 +++++- .../seqkit/tab2fx/tests/main.nf.test.snap | 54 +++++++++---------- 6 files changed, 74 insertions(+), 50 deletions(-) diff --git a/modules/nf-core/seqkit/fx2tab/environment.yml b/modules/nf-core/seqkit/fx2tab/environment.yml index 41f3e7de43d..1f93892f485 100644 --- a/modules/nf-core/seqkit/fx2tab/environment.yml +++ b/modules/nf-core/seqkit/fx2tab/environment.yml @@ -2,4 +2,4 @@ channels: - conda-forge - bioconda dependencies: - - bioconda::seqkit=2.8.1 + - bioconda::seqkit=2.9.0 diff --git a/modules/nf-core/seqkit/fx2tab/main.nf b/modules/nf-core/seqkit/fx2tab/main.nf index d96b0b9d370..7a3f4103391 100644 --- a/modules/nf-core/seqkit/fx2tab/main.nf +++ b/modules/nf-core/seqkit/fx2tab/main.nf @@ -4,8 +4,8 @@ process SEQKIT_FX2TAB { conda "${moduleDir}/environment.yml" container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ? - 'https://depot.galaxyproject.org/singularity/seqkit:2.8.1--h9ee0642_0' : - 'biocontainers/seqkit:2.8.1--h9ee0642_0' }" + 'https://depot.galaxyproject.org/singularity/seqkit:2.9.0--h9ee0642_0' : + 'biocontainers/seqkit:2.9.0--h9ee0642_0' }" input: tuple val(meta), path(fastx) @@ -34,4 +34,16 @@ process SEQKIT_FX2TAB { seqkit: \$( seqkit | sed '3!d; s/Version: //' ) END_VERSIONS """ + + stub: + def prefix = task.ext.prefix ?: "${meta.id}" + def suffix = task.ext.suffix ?: "txt.zst" + """ + touch ${prefix}.${suffix} + + cat <<-END_VERSIONS > versions.yml + "${task.process}": + seqkit: \$( seqkit | sed '3!d; s/Version: //' ) + END_VERSIONS + """ } diff --git a/modules/nf-core/seqkit/fx2tab/tests/main.nf.test.snap b/modules/nf-core/seqkit/fx2tab/tests/main.nf.test.snap index 29421657250..38c0b645ee2 100644 --- a/modules/nf-core/seqkit/fx2tab/tests/main.nf.test.snap +++ b/modules/nf-core/seqkit/fx2tab/tests/main.nf.test.snap @@ -7,30 +7,30 @@ { "id": "test" }, - "test.txt.zst:md5,08902131ebe68052a97178bc426bf944" + "test.txt.zst:md5,d41d8cd98f00b204e9800998ecf8427e" ] ], "1": [ - "versions.yml:md5,ba37c06c2d66e54301b2cd35ae47d0e8" + "versions.yml:md5,b35c25f76ae716eb6bed4f18abf12d50" ], "text": [ [ { "id": "test" }, - "test.txt.zst:md5,08902131ebe68052a97178bc426bf944" + "test.txt.zst:md5,d41d8cd98f00b204e9800998ecf8427e" ] ], "versions": [ - "versions.yml:md5,ba37c06c2d66e54301b2cd35ae47d0e8" + "versions.yml:md5,b35c25f76ae716eb6bed4f18abf12d50" ] } ], "meta": { - "nf-test": "0.8.4", - "nextflow": "23.10.1" + "nf-test": "0.9.2", + "nextflow": "24.10.3" }, - "timestamp": "2024-05-07T16:01:39.484590737" + "timestamp": "2025-01-15T12:18:24.281141" }, "sarscov2 - fasta": { "content": [ @@ -44,7 +44,7 @@ ] ], "1": [ - "versions.yml:md5,ba37c06c2d66e54301b2cd35ae47d0e8" + "versions.yml:md5,b35c25f76ae716eb6bed4f18abf12d50" ], "text": [ [ @@ -55,15 +55,15 @@ ] ], "versions": [ - "versions.yml:md5,ba37c06c2d66e54301b2cd35ae47d0e8" + "versions.yml:md5,b35c25f76ae716eb6bed4f18abf12d50" ] } ], "meta": { - "nf-test": "0.8.4", - "nextflow": "23.10.1" + "nf-test": "0.9.2", + "nextflow": "24.10.3" }, - "timestamp": "2024-05-07T16:01:21.332957847" + "timestamp": "2025-01-15T12:18:14.007765" }, "sarscov2 - fastq": { "content": [ @@ -77,7 +77,7 @@ ] ], "1": [ - "versions.yml:md5,ba37c06c2d66e54301b2cd35ae47d0e8" + "versions.yml:md5,b35c25f76ae716eb6bed4f18abf12d50" ], "text": [ [ @@ -88,14 +88,14 @@ ] ], "versions": [ - "versions.yml:md5,ba37c06c2d66e54301b2cd35ae47d0e8" + "versions.yml:md5,b35c25f76ae716eb6bed4f18abf12d50" ] } ], "meta": { - "nf-test": "0.8.4", - "nextflow": "23.10.1" + "nf-test": "0.9.2", + "nextflow": "24.10.3" }, - "timestamp": "2024-05-07T16:01:29.885155029" + "timestamp": "2025-01-15T12:18:19.228692" } } \ No newline at end of file diff --git a/modules/nf-core/seqkit/tab2fx/environment.yml b/modules/nf-core/seqkit/tab2fx/environment.yml index 41f3e7de43d..1f93892f485 100644 --- a/modules/nf-core/seqkit/tab2fx/environment.yml +++ b/modules/nf-core/seqkit/tab2fx/environment.yml @@ -2,4 +2,4 @@ channels: - conda-forge - bioconda dependencies: - - bioconda::seqkit=2.8.1 + - bioconda::seqkit=2.9.0 diff --git a/modules/nf-core/seqkit/tab2fx/main.nf b/modules/nf-core/seqkit/tab2fx/main.nf index 9532cfc5918..9cdee7d30ba 100644 --- a/modules/nf-core/seqkit/tab2fx/main.nf +++ b/modules/nf-core/seqkit/tab2fx/main.nf @@ -4,8 +4,8 @@ process SEQKIT_TAB2FX { conda "${moduleDir}/environment.yml" container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ? - 'https://depot.galaxyproject.org/singularity/seqkit:2.8.1--h9ee0642_0' : - 'biocontainers/seqkit:2.8.1--h9ee0642_0' }" + 'https://depot.galaxyproject.org/singularity/seqkit:2.9.0--h9ee0642_0' : + 'biocontainers/seqkit:2.9.0--h9ee0642_0' }" input: tuple val(meta), path(text) @@ -34,4 +34,16 @@ process SEQKIT_TAB2FX { seqkit: \$( seqkit | sed '3!d; s/Version: //' ) END_VERSIONS """ + + stub: + def prefix = task.ext.prefix ?: "${meta.id}" + def suffix = task.ext.suffix ?: "fa.zst" + """ + touch ${prefix}.${suffix} + + cat <<-END_VERSIONS > versions.yml + "${task.process}": + seqkit: \$( seqkit | sed '3!d; s/Version: //' ) + END_VERSIONS + """ } diff --git a/modules/nf-core/seqkit/tab2fx/tests/main.nf.test.snap b/modules/nf-core/seqkit/tab2fx/tests/main.nf.test.snap index 857a2b2e953..91c6fbbb5c2 100644 --- a/modules/nf-core/seqkit/tab2fx/tests/main.nf.test.snap +++ b/modules/nf-core/seqkit/tab2fx/tests/main.nf.test.snap @@ -7,30 +7,30 @@ { "id": "test" }, - "test.fa.zst:md5,04d45a85c10933605cb5a289552c83a0" + "test.fa.zst:md5,d41d8cd98f00b204e9800998ecf8427e" ] ], "1": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ], "fastx": [ [ { "id": "test" }, - "test.fa.zst:md5,04d45a85c10933605cb5a289552c83a0" + "test.fa.zst:md5,d41d8cd98f00b204e9800998ecf8427e" ] ], "versions": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ] } ], "meta": { - "nf-test": "0.8.4", - "nextflow": "23.10.1" + "nf-test": "0.9.2", + "nextflow": "24.10.3" }, - "timestamp": "2024-05-08T08:24:24.025365917" + "timestamp": "2025-01-15T12:20:30.19388" }, "fastq_gz": { "content": [ @@ -44,7 +44,7 @@ ] ], "1": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ], "fastx": [ [ @@ -55,15 +55,15 @@ ] ], "versions": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ] } ], "meta": { - "nf-test": "0.8.4", - "nextflow": "23.10.1" + "nf-test": "0.9.2", + "nextflow": "24.10.3" }, - "timestamp": "2024-05-08T08:24:12.779036251" + "timestamp": "2025-01-15T12:20:25.318142" }, "fasta_gz": { "content": [ @@ -77,7 +77,7 @@ ] ], "1": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ], "fastx": [ [ @@ -88,15 +88,15 @@ ] ], "versions": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ] } ], "meta": { - "nf-test": "0.8.4", - "nextflow": "23.10.1" + "nf-test": "0.9.2", + "nextflow": "24.10.3" }, - "timestamp": "2024-05-08T08:24:00.497912668" + "timestamp": "2025-01-15T12:20:19.111781" }, "fasta": { "content": [ @@ -110,7 +110,7 @@ ] ], "1": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ], "fastx": [ [ @@ -121,15 +121,15 @@ ] ], "versions": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ] } ], "meta": { - "nf-test": "0.8.4", - "nextflow": "23.10.1" + "nf-test": "0.9.2", + "nextflow": "24.10.3" }, - "timestamp": "2024-05-08T08:23:31.940090506" + "timestamp": "2025-01-15T12:20:06.405339" }, "fastq": { "content": [ @@ -143,7 +143,7 @@ ] ], "1": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ], "fastx": [ [ @@ -154,14 +154,14 @@ ] ], "versions": [ - "versions.yml:md5,60fb327ac9a1ed20945fbb049faa7e36" + "versions.yml:md5,d01878090b875a05b111ee8a68405491" ] } ], "meta": { - "nf-test": "0.8.4", - "nextflow": "23.10.1" + "nf-test": "0.9.2", + "nextflow": "24.10.3" }, - "timestamp": "2024-05-08T08:23:46.059347765" + "timestamp": "2025-01-15T12:20:12.813847" } } \ No newline at end of file