forked from milaboratory/mixcr
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathitests.sh
executable file
·172 lines (145 loc) · 4.82 KB
/
itests.sh
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
#!/bin/bash
set -eo pipefail
# "Integration" tests for MiXCR
# Test standard analysis pipeline results
# Linux readlink -f alternative for Mac OS X
function readlinkUniversal() {
targetFile=$1
cd $(dirname $targetFile)
targetFile=$(basename $targetFile)
# iterate down a (possible) chain of symlinks
while [ -L "$targetFile" ]; do
targetFile=$(readlink $targetFile)
cd $(dirname $targetFile)
targetFile=$(basename $targetFile)
done
# compute the canonicalized name by finding the physical path
# for the directory we're in and appending the target file.
phys_dir=$(pwd -P)
result=$phys_dir/$targetFile
echo $result
}
os=$(uname)
delta=100
dir=""
case $os in
Darwin)
dir=$(dirname "$(readlinkUniversal "$0")")
;;
Linux)
dir="$(dirname "$(readlink -f "$0")")"
;;
FreeBSD)
dir=$(dirname "$(readlinkUniversal "$0")")
;;
*)
echo "Unknown OS."
exit 1
;;
esac
declare -a all_tests
while read -r tst; do
all_tests=( "${all_tests[@]}" "$tst" )
done < <(find itests -name '*.sh' | sed 's/\itests\///' | sed 's/\.sh//' | grep -v 'ignored' | sort)
tests=()
create_standard_results=false
run_tests=false
while [[ $# -gt 0 ]]; do
key="$1"
shift
case $key in
std)
create_standard_results=true
;;
test)
run_tests=true
;;
case*)
tests=("${tests[@]}" "$key")
;;
*)
echo "Unknown option $key"
exit 1
;;
esac
done
# set to all tests if user didn't provide any specific test cases to run
if [[ ${#tests[@]} -eq 0 ]]; then
tests=("${all_tests[@]}")
fi
rm -rf ${dir}/test_target
mkdir ${dir}/test_target
PATH=${dir}:${PATH}
which mixcr
mixcr -v
function go_assemble {
mixcr assemble -r $1.clns.report $1.vdjca $1.clns
for c in TCR IG TRB TRA TRG TRD IGH IGL IGK ALL; do
mixcr exportClones -c ${c} $1.clns $1.clns.${c}.txt
done
}
if [[ $create_standard_results == true ]]; then
for s in sample_IGH test; do
mixcr align -s hs -r ${s}_paired.vdjca.report ${s}_R1.fastq ${s}_R2.fastq ${s}_paired.vdjca
go_assemble ${s}_paired
mixcr align -s hs -r ${s}_single.vdjca.report ${s}_R1.fastq ${s}_single.vdjca
go_assemble ${s}_single
mixcr align -s hs -p kAligner2 -r ${s}_paired.vdjca.report ${s}_R1.fastq ${s}_R2.fastq ${s}_paired2.vdjca
go_assemble ${s}_paired2
mixcr align -s hs -p kAligner2 -r ${s}_single.vdjca.report ${s}_R1.fastq ${s}_single2.vdjca
go_assemble ${s}_single2
done
fi
function run_test() {
cd ${dir}/test_target
find . -type f -not -name '*.error' -delete
echo "========================"
echo "Running: $1"
echo "========================"
if ../itests/${1}; then
echo "========================"
echo "$1 executed successfully"
else
echo "========================"
echo "$1 executed with error"
touch "${1}".error
fi
echo "========================"
}
if [[ $run_tests == true ]]; then
cd ${dir}/test_target
files=`ls ../src/test/resources/sequences/*.fastq`
for file in $files; do
filename=${file#../src/test/resources/sequences/*}
ln -s -f ../src/test/resources/sequences/$filename ../test_target/$filename
done
ln -s -f ../src/test/resources/sequences/big/CD4M1_test_R1.fastq.gz ${dir}/test_target/CD4M1_test_R1.fastq.gz
ln -s -f ../src/test/resources/sequences/big/CD4M1_test_R2.fastq.gz ${dir}/test_target/CD4M1_test_R2.fastq.gz
ln -s -f ../src/test/resources/sequences/big/single_cell_vdj_t_subset_R1.fastq.gz ${dir}/test_target/single_cell_vdj_t_subset_R1.fastq.gz
ln -s -f ../src/test/resources/sequences/big/single_cell_vdj_t_subset_R2.fastq.gz ${dir}/test_target/single_cell_vdj_t_subset_R2.fastq.gz
ln -s -f ../src/test/resources/sequences/big/trees_samples ${dir}/test_target/trees_samples
ln -s -f ../src/test/resources/sequences/big/regression ${dir}/test_target/regression
ln -s -f ../src/test/resources/sequences/umi_ig_data_2_subset_R1.fastq.gz ${dir}/test_target/umi_ig_data_2_subset_R1.fastq.gz
ln -s -f ../src/test/resources/sequences/umi_ig_data_2_subset_R2.fastq.gz ${dir}/test_target/umi_ig_data_2_subset_R2.fastq.gz
ln -s -f ../src/test/resources/bam/unsorted.bam ${dir}/test_target/unsorted.bam
ln -s -f ../src/test/resources/library_for_alleles_test.json ${dir}/test_target/library_for_alleles_test.json
ln -s -f ../src/test/resources/sligtly_broken_library_for_alleles_test.json ${dir}/test_target/sligtly_broken_library_for_alleles_test.json
cd ${dir}
echo "======================================="
echo "The following tests are to be executed:"
for testName in "${tests[@]}"; do
echo "${testName}.sh"
done
echo "======================================="
for testName in "${tests[@]}"; do
run_test "${testName}.sh"
done
if ls "${dir}"/test_target/*.error 1>/dev/null 2>&1; then
ls -1 "${dir}"/test_target/*.error
echo "There are tests with errors."
exit 1
else
echo "All tests finished successfully."
exit 0
fi
fi