-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Update version to 0.4.1-dev * Update CircleCI badge in README to monitor develop branch * Add Singularity deffile for stag-mwc env * Add Singularity image for main env up to kraken2 * Add link to Singularity bind docs * Add stag-mwc-main singularity image to all rules that require it * Add Singularity images for biobakery and assembly * Set rule threads from cluster_config if defined * Update CHANGELOG * Docs: Update module intro paragraph, closes #151 * Add {cluster.extra} to slurm-submit.py script call * Update CHANGELOG * Fix typo in kraken2 rules * the host removal script was ignoring it's flag in config.yaml * Update CHANGELOG * Update CHANGELOG * Tweak docs, update changelog, prepare for release * Amrplusplus (#156) * amrplusplus * amrplusplus scripts * added scripts * changed input in config.yaml Co-authored-by: Fredrik Boulund <[email protected]> * default db empty Co-authored-by: Fredrik Boulund <[email protected]> * db -> megares Co-authored-by: Fredrik Boulund <[email protected]> * annotation --> megares_annotation Co-authored-by: Fredrik Boulund <[email protected]> * added amrplusplus to circleci * updated CHANGELOG.md * updated amrplusplus in config.yaml * added amrplusplus to modules.rst * updated amrplusplus.smk * added license and removed bin dir * updated modules.rst * added align_to_amr * fixed default database * amrplusplus db empty in conf * indentations * clarification regarding database * Update docs/source/modules.rst Co-authored-by: Fredrik Boulund <[email protected]> * Update rules/antibiotic_resistance/amrplusplus.smk Co-authored-by: Fredrik Boulund <[email protected]> * Update docs/source/modules.rst grammar Co-authored-by: Fredrik Boulund <[email protected]> * Update CHANGELOG.md Co-authored-by: Fredrik Boulund <[email protected]> * added bwa to stag-mwc.yaml * added conda environment * amrplusplus exectuable with conda * amrplusplus executable with conda * samtools version 1.10 * amrplusplus conda executable * added amrplusplus.yaml to not break stag-mwc.yaml dependencies * removed amrplusplus dependencies because they broke it * now using amrplusplus.yaml for conda instead of stag-mwc.yaml Co-authored-by: Fredrik Boulund <[email protected]> Co-authored-by: Aron Arzoomand <[email protected]> * Change report generation call (#161) * Change report generation call Ignore additional arguments to snakemake when creating report, Intended to avoid shell escaping issue with complex arguments to e.g. Singularity, issue #160 * removed snakemake_call * added report generation workaround * report generation Co-authored-by: Fredrik Boulund <[email protected]> * report generation Co-authored-by: Fredrik Boulund <[email protected]> * indentation Co-authored-by: Aron Arzoomand <[email protected]> * Slurm profile for CTMR UCP environment (#159) * First draft for CTMR UCP cluster profile * Remove references to rackham profile, remove account check * Updated resource requests for all rules * Final tweaks * Rename ctmr_ucp profile to ctmr_gandalf * Fix yml-yaml typo * Fix incorrectly named singularity images * Remove --use prefix for argument to metawrap * Add missing singularity container to create_kaiju_krona_plot * added dbdir and threads for align_to_amr * Disable area plot for Kaiju * Minor updates to docs (#162) * Update badge URL in README Co-authored-by: Kristaps <[email protected]> Co-authored-by: Aron Arzoomand <[email protected]> Co-authored-by: Aron Arzoomand <[email protected]> Co-authored-by: AroArz <[email protected]>
- Loading branch information
1 parent
0c46f88
commit b9b0df2
Showing
44 changed files
with
1,123 additions
and
77 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
jobscript: "cluster_configs/ctmr_gandalf/slurm-jobscript.sh" | ||
cluster: "cluster_configs/ctmr_gandalf/slurm-submit.py --time {cluster.time} --error {cluster.stderr} --output {cluster.stdout} --job-name '{cluster.jobname}' {cluster.extra}" | ||
cluster-status: "cluster_configs/ctmr_gandalf/slurm-status.py" | ||
cluster-config: "cluster_configs/ctmr_gandalf/ctmr_gandalf.yaml" | ||
max-jobs-per-second: 10 | ||
max-status-checks-per-second: 10 | ||
local-cores: 1 | ||
jobs: 999 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
# Cluster config file for StaG-mwc for use on CTMR UCP | ||
__default__: | ||
account: "bio" | ||
partition: "ctmr" | ||
extra: "" | ||
time: "03:00:00" | ||
n: 2 | ||
stderr: "slurm_logs/slurm-{rule}-{wildcards}.stderr" | ||
stdout: "slurm_logs/slurm-{rule}-{wildcards}.stdout" | ||
jobname: "[{rule}]: {wildcards}" | ||
|
||
|
||
############################# | ||
# Pre-processing | ||
############################# | ||
fastp: | ||
n: 8 | ||
time: "01:00:00" | ||
remove_host: | ||
n: 8 | ||
time: "01:00:00" | ||
bbcountunique: | ||
n: 4 | ||
time: "00:45:00" | ||
|
||
############################# | ||
# Naive comparisons | ||
############################# | ||
sketch: | ||
n: 8 | ||
time: "00:20:00" | ||
|
||
############################# | ||
# Taxonomic profiling | ||
############################# | ||
kaiju: | ||
n: 10 | ||
time: "02:00:00" | ||
kraken2: | ||
n: 10 | ||
time: "02:00:00" | ||
metaphlan2: | ||
n: 8 | ||
time: "01:30:00" | ||
bracken: | ||
n: 2 | ||
time: "01:00:00" | ||
|
||
############################# | ||
# Functional profiling | ||
############################# | ||
humann2: | ||
n: 12 | ||
time: "12:00:00" | ||
|
||
############################# | ||
# Antibiotic resistance | ||
############################# | ||
groot_align: | ||
n: 8 | ||
time: "01:00:00" | ||
align_to_amr: | ||
n: 10 | ||
time: "04:00:00" | ||
|
||
############################# | ||
# Mappers | ||
############################# | ||
bbmap: | ||
n: 10 | ||
time: "02:00:00" | ||
bowtie2: | ||
n: 10 | ||
time: "02:00:00" | ||
|
||
############################# | ||
# Assembly | ||
############################# | ||
assembly: | ||
n: 20 | ||
time: "05:00:00" | ||
assembly: | ||
n: 20 | ||
time: "05:00:00" | ||
consolidate_bins: | ||
n: 20 | ||
time: "05:00:00" | ||
blobology: | ||
n: 20 | ||
time: "05:00:00" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
#!/bin/bash | ||
# properties = {properties} | ||
{exec_job} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
#!/usr/bin/env python3 | ||
import re | ||
import subprocess as sp | ||
import shlex | ||
import sys | ||
import time | ||
import logging | ||
logger = logging.getLogger("__name__") | ||
|
||
STATUS_ATTEMPTS = 20 | ||
|
||
jobid = sys.argv[1] | ||
|
||
for i in range(STATUS_ATTEMPTS): | ||
try: | ||
sacct_res = sp.check_output(shlex.split("sacct -P -b -j {} -n".format(jobid))) | ||
res = {x.split("|")[0]: x.split("|")[1] for x in sacct_res.decode().strip().split("\n")} | ||
break | ||
except sp.CalledProcessError as e: | ||
logger.error("sacct process error") | ||
logger.error(e) | ||
except IndexError as e: | ||
pass | ||
# Try getting job with scontrol instead in case sacct is misconfigured | ||
try: | ||
sctrl_res = sp.check_output(shlex.split("scontrol -o show job {}".format(jobid))) | ||
m = re.search("JobState=(\w+)", sctrl_res.decode()) | ||
res = {jobid: m.group(1)} | ||
break | ||
except sp.CalledProcessError as e: | ||
logger.error("scontrol process error") | ||
logger.error(e) | ||
if i >= STATUS_ATTEMPTS - 1: | ||
print("failed") | ||
exit(0) | ||
else: | ||
time.sleep(1) | ||
|
||
status = res[jobid] | ||
|
||
if (status.startswith("BOOT_FAIL")): | ||
print("failed") | ||
elif (status.startswith("CANCELLED")): | ||
print("failed") | ||
elif (status.startswith("COMPLETED")): | ||
print("success") | ||
elif (status.startswith("DEADLINE")): | ||
print("failed") | ||
elif (status.startswith("FAILED")): | ||
print("failed") | ||
elif (status.startswith("NODE_FAIL")): | ||
print("failed") | ||
elif (status.startswith("PREEMPTED")): | ||
print("failed") | ||
elif (status.startswith("TIMEOUT")): | ||
print("failed") | ||
# Unclear whether SUSPENDED should be treated as running or failed | ||
elif (status.startswith("SUSPENDED")): | ||
print("failed") | ||
else: | ||
print("running") |
Oops, something went wrong.