mirror of
https://github.com/MillironX/nf-core_modules.git
synced 2025-01-02 20:52:07 -05:00
Remove bcftools and ivar module customisations (#1217)
* Remove customisation from bcftools modules * Add save_mpileup option to bcftools/mpileup * Remove params.save_mpileup from ivar/consensus * Update meta.ymls
This commit is contained in:
parent
4e9cc84514
commit
bb90e4fb78
12 changed files with 112 additions and 32 deletions
|
@ -18,9 +18,12 @@ process BCFTOOLS_CONSENSUS {
|
||||||
def args = task.ext.args ?: ''
|
def args = task.ext.args ?: ''
|
||||||
def prefix = task.ext.prefix ?: "${meta.id}"
|
def prefix = task.ext.prefix ?: "${meta.id}"
|
||||||
"""
|
"""
|
||||||
cat $fasta | bcftools consensus $vcf $args > ${prefix}.fa
|
cat $fasta \\
|
||||||
header=\$(head -n 1 ${prefix}.fa | sed 's/>//g')
|
| bcftools \\
|
||||||
sed -i 's/\${header}/${meta.id}/g' ${prefix}.fa
|
consensus \\
|
||||||
|
$vcf \\
|
||||||
|
$args \\
|
||||||
|
> ${prefix}.fa
|
||||||
|
|
||||||
cat <<-END_VERSIONS > versions.yml
|
cat <<-END_VERSIONS > versions.yml
|
||||||
"${task.process}":
|
"${task.process}":
|
||||||
|
|
|
@ -9,12 +9,14 @@ process BCFTOOLS_MPILEUP {
|
||||||
|
|
||||||
input:
|
input:
|
||||||
tuple val(meta), path(bam)
|
tuple val(meta), path(bam)
|
||||||
path fasta
|
path fasta
|
||||||
|
val save_mpileup
|
||||||
|
|
||||||
output:
|
output:
|
||||||
tuple val(meta), path("*.gz") , emit: vcf
|
tuple val(meta), path("*.gz") , emit: vcf
|
||||||
tuple val(meta), path("*.tbi") , emit: tbi
|
tuple val(meta), path("*.tbi") , emit: tbi
|
||||||
tuple val(meta), path("*stats.txt"), emit: stats
|
tuple val(meta), path("*stats.txt"), emit: stats
|
||||||
|
tuple val(meta), path("*.mpileup") , emit: mpileup, optional: true
|
||||||
path "versions.yml" , emit: versions
|
path "versions.yml" , emit: versions
|
||||||
|
|
||||||
script:
|
script:
|
||||||
|
@ -22,13 +24,16 @@ process BCFTOOLS_MPILEUP {
|
||||||
def args2 = task.ext.args2 ?: ''
|
def args2 = task.ext.args2 ?: ''
|
||||||
def args3 = task.ext.args3 ?: ''
|
def args3 = task.ext.args3 ?: ''
|
||||||
def prefix = task.ext.prefix ?: "${meta.id}"
|
def prefix = task.ext.prefix ?: "${meta.id}"
|
||||||
|
def mpileup = save_mpileup ? "| tee ${prefix}.mpileup" : ""
|
||||||
"""
|
"""
|
||||||
echo "${meta.id}" > sample_name.list
|
echo "${meta.id}" > sample_name.list
|
||||||
|
|
||||||
bcftools mpileup \\
|
bcftools \\
|
||||||
|
mpileup \\
|
||||||
--fasta-ref $fasta \\
|
--fasta-ref $fasta \\
|
||||||
$args \\
|
$args \\
|
||||||
$bam \\
|
$bam \\
|
||||||
|
$mpileup \\
|
||||||
| bcftools call --output-type v $args2 \\
|
| bcftools call --output-type v $args2 \\
|
||||||
| bcftools reheader --samples sample_name.list \\
|
| bcftools reheader --samples sample_name.list \\
|
||||||
| bcftools view --output-file ${prefix}.vcf.gz --output-type z $args3
|
| bcftools view --output-file ${prefix}.vcf.gz --output-type z $args3
|
||||||
|
|
|
@ -26,6 +26,10 @@ input:
|
||||||
type: file
|
type: file
|
||||||
description: FASTA reference file
|
description: FASTA reference file
|
||||||
pattern: "*.{fasta,fa}"
|
pattern: "*.{fasta,fa}"
|
||||||
|
- save_mpileup:
|
||||||
|
type: boolean
|
||||||
|
description: Save mpileup file generated by bcftools mpileup
|
||||||
|
patter: "*.mpileup"
|
||||||
output:
|
output:
|
||||||
- meta:
|
- meta:
|
||||||
type: map
|
type: map
|
||||||
|
|
|
@ -9,7 +9,8 @@ process IVAR_CONSENSUS {
|
||||||
|
|
||||||
input:
|
input:
|
||||||
tuple val(meta), path(bam)
|
tuple val(meta), path(bam)
|
||||||
path fasta
|
path fasta
|
||||||
|
val save_mpileup
|
||||||
|
|
||||||
output:
|
output:
|
||||||
tuple val(meta), path("*.fa") , emit: fasta
|
tuple val(meta), path("*.fa") , emit: fasta
|
||||||
|
@ -21,14 +22,16 @@ process IVAR_CONSENSUS {
|
||||||
def args = task.ext.args ?: ''
|
def args = task.ext.args ?: ''
|
||||||
def args2 = task.ext.args2 ?: ''
|
def args2 = task.ext.args2 ?: ''
|
||||||
def prefix = task.ext.prefix ?: "${meta.id}"
|
def prefix = task.ext.prefix ?: "${meta.id}"
|
||||||
def save_mpileup = params.save_mpileup ? "tee ${prefix}.mpileup |" : ""
|
def mpileup = save_mpileup ? "| tee ${prefix}.mpileup" : ""
|
||||||
"""
|
"""
|
||||||
samtools mpileup \\
|
samtools \\
|
||||||
|
mpileup \\
|
||||||
--reference $fasta \\
|
--reference $fasta \\
|
||||||
$args2 \\
|
$args2 \\
|
||||||
$bam | \\
|
$bam \\
|
||||||
$save_mpileup \\
|
$mpileup \\
|
||||||
ivar consensus \\
|
| ivar \\
|
||||||
|
consensus \\
|
||||||
$args \\
|
$args \\
|
||||||
-p $prefix
|
-p $prefix
|
||||||
|
|
||||||
|
|
|
@ -25,6 +25,10 @@ input:
|
||||||
type: file
|
type: file
|
||||||
description: The reference sequence used for mapping and generating the BAM file
|
description: The reference sequence used for mapping and generating the BAM file
|
||||||
pattern: "*.fa"
|
pattern: "*.fa"
|
||||||
|
- save_mpileup:
|
||||||
|
type: boolean
|
||||||
|
description: Save mpileup file generated by ivar consensus
|
||||||
|
patter: "*.mpileup"
|
||||||
output:
|
output:
|
||||||
- meta:
|
- meta:
|
||||||
type: map
|
type: map
|
||||||
|
|
|
@ -23,14 +23,16 @@ process IVAR_VARIANTS {
|
||||||
def args2 = task.ext.args2 ?: ''
|
def args2 = task.ext.args2 ?: ''
|
||||||
def prefix = task.ext.prefix ?: "${meta.id}"
|
def prefix = task.ext.prefix ?: "${meta.id}"
|
||||||
def features = gff ? "-g $gff" : ""
|
def features = gff ? "-g $gff" : ""
|
||||||
def mpileup = save_mpileup ? "tee ${prefix}.mpileup |" : ""
|
def mpileup = save_mpileup ? "| tee ${prefix}.mpileup" : ""
|
||||||
"""
|
"""
|
||||||
samtools mpileup \\
|
samtools \\
|
||||||
|
mpileup \\
|
||||||
$args2 \\
|
$args2 \\
|
||||||
--reference $fasta \\
|
--reference $fasta \\
|
||||||
$bam | \\
|
$bam \\
|
||||||
$mpileup \\
|
$mpileup \\
|
||||||
ivar variants \\
|
| ivar \\
|
||||||
|
variants \\
|
||||||
$args \\
|
$args \\
|
||||||
$features \\
|
$features \\
|
||||||
-r $fasta \\
|
-r $fasta \\
|
||||||
|
|
|
@ -32,6 +32,7 @@ input:
|
||||||
- save_mpileup:
|
- save_mpileup:
|
||||||
type: boolean
|
type: boolean
|
||||||
description: Save mpileup file generated by ivar variants
|
description: Save mpileup file generated by ivar variants
|
||||||
|
patter: "*.mpileup"
|
||||||
output:
|
output:
|
||||||
- meta:
|
- meta:
|
||||||
type: map
|
type: map
|
||||||
|
|
|
@ -5,11 +5,13 @@ nextflow.enable.dsl = 2
|
||||||
include { BCFTOOLS_CONSENSUS } from '../../../../modules/bcftools/consensus/main.nf'
|
include { BCFTOOLS_CONSENSUS } from '../../../../modules/bcftools/consensus/main.nf'
|
||||||
|
|
||||||
workflow test_bcftools_consensus {
|
workflow test_bcftools_consensus {
|
||||||
input = [ [ id:'test' ], // meta map
|
|
||||||
[ file(params.test_data['sarscov2']['illumina']['test_vcf_gz'], checkIfExists: true) ],
|
input = [
|
||||||
[ file(params.test_data['sarscov2']['illumina']['test_vcf_gz_tbi'], checkIfExists: true) ],
|
[ id:'test' ], // meta map
|
||||||
[ file(params.test_data['sarscov2']['genome']['genome_fasta'], checkIfExists: true) ]
|
file(params.test_data['sarscov2']['illumina']['test_vcf_gz'], checkIfExists: true),
|
||||||
]
|
file(params.test_data['sarscov2']['illumina']['test_vcf_gz_tbi'], checkIfExists: true),
|
||||||
|
file(params.test_data['sarscov2']['genome']['genome_fasta'], checkIfExists: true)
|
||||||
|
]
|
||||||
|
|
||||||
BCFTOOLS_CONSENSUS ( input )
|
BCFTOOLS_CONSENSUS ( input )
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,9 +5,25 @@ nextflow.enable.dsl = 2
|
||||||
include { BCFTOOLS_MPILEUP } from '../../../../modules/bcftools/mpileup/main.nf'
|
include { BCFTOOLS_MPILEUP } from '../../../../modules/bcftools/mpileup/main.nf'
|
||||||
|
|
||||||
workflow test_bcftools_mpileup {
|
workflow test_bcftools_mpileup {
|
||||||
input = [ [ id:'test' ], // meta map
|
|
||||||
[ file(params.test_data['sarscov2']['illumina']['test_paired_end_sorted_bam'], checkIfExists: true) ]]
|
|
||||||
fasta = [ file(params.test_data['sarscov2']['genome']['genome_fasta'], checkIfExists: true) ]
|
|
||||||
|
|
||||||
BCFTOOLS_MPILEUP ( input, fasta )
|
input = [
|
||||||
|
[ id:'test' ], // meta map
|
||||||
|
[ file(params.test_data['sarscov2']['illumina']['test_paired_end_sorted_bam'], checkIfExists: true) ]
|
||||||
|
]
|
||||||
|
fasta = file(params.test_data['sarscov2']['genome']['genome_fasta'], checkIfExists: true)
|
||||||
|
save_mpileup = false
|
||||||
|
|
||||||
|
BCFTOOLS_MPILEUP ( input, fasta, save_mpileup )
|
||||||
|
}
|
||||||
|
|
||||||
|
workflow test_bcftools_save_mpileup {
|
||||||
|
|
||||||
|
input = [
|
||||||
|
[ id:'test' ], // meta map
|
||||||
|
[ file(params.test_data['sarscov2']['illumina']['test_paired_end_sorted_bam'], checkIfExists: true) ]
|
||||||
|
]
|
||||||
|
fasta = file(params.test_data['sarscov2']['genome']['genome_fasta'], checkIfExists: true)
|
||||||
|
save_mpileup = true
|
||||||
|
|
||||||
|
BCFTOOLS_MPILEUP ( input, fasta, save_mpileup )
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,3 +10,18 @@
|
||||||
md5sum: ae0f17dcc2cb27034d848699b824c516
|
md5sum: ae0f17dcc2cb27034d848699b824c516
|
||||||
- path: output/bcftools/test.vcf.gz
|
- path: output/bcftools/test.vcf.gz
|
||||||
md5sum: e9e520663875c66296f3bff0fa226c40
|
md5sum: e9e520663875c66296f3bff0fa226c40
|
||||||
|
|
||||||
|
- name: bcftools mpileup test_bcftools_save_mpileup
|
||||||
|
command: nextflow run ./tests/modules/bcftools/mpileup -entry test_bcftools_save_mpileup -c ./tests/config/nextflow.config -c ./tests/modules/bcftools/mpileup/nextflow.config
|
||||||
|
tags:
|
||||||
|
- bcftools/mpileup
|
||||||
|
- bcftools
|
||||||
|
files:
|
||||||
|
- path: output/bcftools/test.bcftools_stats.txt
|
||||||
|
md5sum: 72c506e633413c6b439f95336933984e
|
||||||
|
- path: output/bcftools/test.vcf.gz.tbi
|
||||||
|
md5sum: ae0f17dcc2cb27034d848699b824c516
|
||||||
|
- path: output/bcftools/test.vcf.gz
|
||||||
|
md5sum: e9e520663875c66296f3bff0fa226c40
|
||||||
|
- path: output/bcftools/test.mpileup
|
||||||
|
md5sum: fe0e45a57ffdfb253ed6794f8356a3f0
|
||||||
|
|
|
@ -2,14 +2,28 @@
|
||||||
|
|
||||||
nextflow.enable.dsl = 2
|
nextflow.enable.dsl = 2
|
||||||
|
|
||||||
params.save_mpileup = true
|
|
||||||
include { IVAR_CONSENSUS } from '../../../../modules/ivar/consensus/main.nf'
|
include { IVAR_CONSENSUS } from '../../../../modules/ivar/consensus/main.nf'
|
||||||
|
|
||||||
workflow test_ivar_consensus {
|
workflow test_ivar_consensus {
|
||||||
input = [ [ id:'test'],
|
|
||||||
file(params.test_data['sarscov2']['illumina']['test_paired_end_bam'], checkIfExists: true)
|
|
||||||
]
|
|
||||||
fasta = file(params.test_data['sarscov2']['genome']['genome_fasta'], checkIfExists: true)
|
|
||||||
|
|
||||||
IVAR_CONSENSUS ( input, fasta )
|
input = [
|
||||||
|
[ id:'test'],
|
||||||
|
file(params.test_data['sarscov2']['illumina']['test_paired_end_bam'], checkIfExists: true)
|
||||||
|
]
|
||||||
|
fasta = file(params.test_data['sarscov2']['genome']['genome_fasta'], checkIfExists: true)
|
||||||
|
save_mpileup = false
|
||||||
|
|
||||||
|
IVAR_CONSENSUS ( input, fasta, save_mpileup)
|
||||||
|
}
|
||||||
|
|
||||||
|
workflow test_ivar_consensus_mpileup {
|
||||||
|
|
||||||
|
input = [
|
||||||
|
[ id:'test'],
|
||||||
|
file(params.test_data['sarscov2']['illumina']['test_paired_end_bam'], checkIfExists: true)
|
||||||
|
]
|
||||||
|
fasta = file(params.test_data['sarscov2']['genome']['genome_fasta'], checkIfExists: true)
|
||||||
|
save_mpileup = true
|
||||||
|
|
||||||
|
IVAR_CONSENSUS ( input, fasta, save_mpileup)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,16 @@
|
||||||
- name: ivar consensus
|
- name: ivar consensus test_ivar_consensus
|
||||||
command: nextflow run ./tests/modules/ivar/consensus -entry test_ivar_consensus -c ./tests/config/nextflow.config -c ./tests/modules/ivar/consensus/nextflow.config
|
command: nextflow run ./tests/modules/ivar/consensus -entry test_ivar_consensus -c ./tests/config/nextflow.config -c ./tests/modules/ivar/consensus/nextflow.config
|
||||||
|
tags:
|
||||||
|
- ivar
|
||||||
|
- ivar/consensus
|
||||||
|
files:
|
||||||
|
- path: output/ivar/test.fa
|
||||||
|
md5sum: 9e21a64818f4302b4dece5480fa5e8b8
|
||||||
|
- path: output/ivar/test.qual.txt
|
||||||
|
md5sum: 68b329da9893e34099c7d8ad5cb9c940
|
||||||
|
|
||||||
|
- name: ivar consensus test_ivar_consensus_mpileup
|
||||||
|
command: nextflow run ./tests/modules/ivar/consensus -entry test_ivar_consensus_mpileup -c ./tests/config/nextflow.config -c ./tests/modules/ivar/consensus/nextflow.config
|
||||||
tags:
|
tags:
|
||||||
- ivar
|
- ivar
|
||||||
- ivar/consensus
|
- ivar/consensus
|
||||||
|
|
Loading…
Reference in a new issue