-
Notifications
You must be signed in to change notification settings - Fork 30
100 lines (84 loc) · 2.99 KB
/
makefile.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
name: compile and e.coli
on:
push:
paths:
- '**.sm'
- '**.py'
- '**.sh'
- 'src/*'
- '.github/workflows/*.yml'
pull_request:
branches: [ master ]
jobs:
build_linux:
name: Linux
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Install Rust
uses: actions-rs/toolchain@v1
with:
toolchain: stable
- name: Compile
run: |
cd src
make -j 2
- name: Setup Python 3.8
uses: actions/setup-python@v2
with:
python-version: 3.8
- name: Setup Conda
uses: conda-incubator/setup-miniconda@v2
with:
auto-update-conda: true
mamba-version: "*"
channels: conda-forge,bioconda
python-version: 3.8
- name: Install snakemake-minimal
run: |
mamba install -c conda-forge -c bioconda snakemake-minimal MBG GraphAligner mashmap winnowmap
- name: Fetch Data
run: |
curl -L https://obj.umiacs.umd.edu/sergek/shared/ecoli_hifi_subset24x.fastq.gz -o hifi.fastq.gz
curl -L https://obj.umiacs.umd.edu/sergek/shared/ecoli_ont_subset50x.fastq.gz -o ont.fastq.gz
curl -L https://obj.umiacs.umd.edu/sergek/shared/ecoli-test-cache.tar -o cache.tar
tar -xf cache.tar
- name: Assemble
run: |
reportLogs() {
for fn in `find . -name \*err -print` ; do
echo ""
echo "==BEGIN $fn"
cat $fn
echo "==END $fn"
done
exit 1
}
export PATH=${PATH}:$CONDA/bin
rm -f mbg.sh
rm -f ga.sh
rm -f lib/verkko/bin/utgcns
echo > mbg.sh '#!/bin/sh'
echo >> mbg.sh 'xz -dc ../../cache/hifi-resolved.gfa.xz > hifi-resolved.gfa'
echo >> mbg.sh 'cp ../../cache/hifi_nodecov.csv hifi_nodecov.csv'
echo >> mbg.sh 'xz -dc ../../cache/paths.gaf.xz > paths.gaf'
echo > ga.sh '#!/bin/sh'
echo >> ga.sh 'if [ ! -e "graph" ] ; then'
echo >> ga.sh ' touch graph'
echo >> ga.sh ' touch empty.gaf'
echo >> ga.sh 'else'
echo >> ga.sh ' xz -dc ../../cache/aligned001.WORKING.gaf.xz > aligned001.WORKING.gaf'
echo >> ga.sh 'fi'
echo > lib/verkko/bin/utgcns '#!/bin/sh'
echo >> lib/verkko/bin/utgcns 'if [ ! -e part001.fasta ]; then'
echo >> lib/verkko/bin/utgcns 'cp ../../cache/part001.fasta packages/part001.fasta.WORKING'
echo >> lib/verkko/bin/utgcns 'fi'
echo >> lib/verkko/bin/utgcns ''
echo >> lib/verkko/bin/utgcns 'if [ ! -e part002.fasta ]; then'
echo >> lib/verkko/bin/utgcns 'cp ../../cache/part002.fasta packages/part002.fasta.WORKING'
echo >> lib/verkko/bin/utgcns 'fi'
chmod 755 mbg.sh
chmod 755 ga.sh
chmod 755 lib/verkko/bin/utgcns
./bin/verkko -d asm --no-correction --mbg $PWD/mbg.sh --graphaligner $PWD/ga.sh --hifi ./hifi.fastq.gz --nano ./ont.fastq.gz || reportLogs