Mercurial > repos > galaxyp > openms_openmsdatabasesinfo
comparison test-data.sh @ 0:a7ff1eeba91f draft
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/openms commit 3d1e5f37fd16524a415f707772eeb7ead848c5e3
author | galaxyp |
---|---|
date | Thu, 01 Dec 2022 19:23:33 +0000 |
parents | |
children | ea9291282c0f |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:a7ff1eeba91f |
---|---|
1 #!/usr/bin/env bash | |
2 | |
3 VERSION=2.8 | |
4 FILETYPES="aux/filetypes.txt" | |
5 CONDAPKG="https://anaconda.org/bioconda/openms/2.8.0/download/linux-64/openms-2.8.0-h7ca0330_0.tar.bz2" | |
6 | |
7 # import the magic | |
8 . ./generate-foo.sh | |
9 | |
10 # install conda | |
11 if [ -z "$tmp" ]; then | |
12 tmp=$(mktemp -d) | |
13 created="yes" | |
14 fi | |
15 | |
16 export OPENMSGIT="$tmp/OpenMS$VERSION.0-git" | |
17 export OPENMSPKG="$tmp/OpenMS$VERSION-pkg/" | |
18 export OPENMSENV="OpenMS$VERSION-env" | |
19 | |
20 if [ -z "$CTDCONVERTER" ]; then | |
21 export CTDCONVERTER="$tmp/CTDConverter" | |
22 fi | |
23 | |
24 if [[ -z "$1" ]]; then | |
25 autotests="/dev/null" | |
26 else | |
27 autotests="$1" | |
28 fi | |
29 | |
30 if type conda > /dev/null; then | |
31 true | |
32 else | |
33 wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh | |
34 bash Miniconda3-latest-Linux-x86_64.sh -b -p "$tmp/miniconda" | |
35 source "$tmp/miniconda/bin/activate" | |
36 fi | |
37 eval "$(conda shell.bash hook)" | |
38 | |
39 | |
40 ############################################################################### | |
41 ## get | |
42 ## - conda environment (for executing the binaries) and | |
43 ## - the git clone of OpenMS (for generating the tests) | |
44 ############################################################################### | |
45 | |
46 echo "Clone OpenMS $VERSION sources" | |
47 if [[ ! -d $OPENMSGIT ]]; then | |
48 # TODO >2.8 reenable original release branch .. also in else branch | |
49 # the plus branch contains commits from https://github.com/OpenMS/OpenMS/pull/5920 and https://github.com/OpenMS/OpenMS/pull/5917 | |
50 # git clone -b release/$VERSION.0 https://github.com/OpenMS/OpenMS.git $OPENMSGIT | |
51 git clone -b release/$VERSION.0-plus https://github.com/bernt-matthias/OpenMS.git $OPENMSGIT | |
52 cd $OPENMSGIT | |
53 git submodule init | |
54 git submodule update | |
55 cd - | |
56 else | |
57 cd $OPENMSGIT | |
58 git pull origin release/$VERSION.0-plus | |
59 cd - | |
60 fi | |
61 | |
62 echo "Create OpenMS $VERSION conda env" | |
63 # TODO currently add lxml (needed by CTDConverter) | |
64 # TODO for some reason a to recent openjdk is used | |
65 if conda env list | grep "$OPENMSENV"; then | |
66 true | |
67 else | |
68 conda create -y --quiet --override-channels --channel iuc --channel conda-forge --channel bioconda --channel defaults -n $OPENMSENV openms=$VERSION openms-thirdparty=$VERSION omssa=2.1.9 ctdopts=1.5 lxml | |
69 # chmod -R u-w $OPENMSENV | |
70 fi | |
71 ############################################################################### | |
72 ## get the | |
73 ## - conda package (for easy access and listing of the OpenMS binaries), | |
74 ############################################################################### | |
75 echo "Download OpenMS $VERSION package $CONDAPKG" | |
76 | |
77 if [[ ! -d $OPENMSPKG ]]; then | |
78 mkdir $OPENMSPKG | |
79 wget -q -P $OPENMSPKG/ "$CONDAPKG" | |
80 tar -xf $OPENMSPKG/"$(basename $CONDAPKG)" -C $OPENMSPKG/ | |
81 rm $OPENMSPKG/"$(basename $CONDAPKG)" | |
82 fi | |
83 | |
84 ############################################################################### | |
85 ## Get python libaries for CTD -> Galaxy conversion | |
86 ## TODO fix to main repo OR conda packkage if PRs are merged | |
87 ############################################################################### | |
88 echo "Clone CTDConverter" | |
89 if [[ ! -d $CTDCONVERTER ]]; then | |
90 #git clone https://github.com/WorkflowConversion/CTDConverter.git CTDConverter | |
91 git clone -b topic/fix-selects2 https://github.com/bernt-matthias/CTDConverter.git $CTDCONVERTER | |
92 else | |
93 cd $CTDCONVERTER | |
94 git pull origin topic/fix-selects2 | |
95 cd - | |
96 fi | |
97 conda activate $OPENMSENV | |
98 cd $CTDCONVERTER | |
99 python -m pip install . --no-deps | |
100 cd - | |
101 conda deactivate | |
102 | |
103 | |
104 # ############################################################################### | |
105 # ## copy all the test data files to test-data | |
106 # ## most of it (outputs) will be overwritten later, but its needed for | |
107 # ## prepare_test_data | |
108 # ############################################################################### | |
109 echo "Get test data" | |
110 find test-data -type f,l,d ! -name "*fa" ! -name "*loc" ! -name "test-data" -delete | |
111 | |
112 cp $(find $OPENMSGIT/src/tests/topp/ -type f | grep -Ev "third_party_tests.cmake|CMakeLists.txt|check_ini") test-data/ | |
113 cp -r $OPENMSGIT/share/OpenMS/MAPPING/ test-data/ | |
114 cp -r $OPENMSGIT/share/OpenMS/CHEMISTRY test-data/ | |
115 cp -r $OPENMSGIT/share/OpenMS/examples/ test-data/ | |
116 if [ ! -f test-data/MetaboliteSpectralDB.mzML ]; then | |
117 wget -nc https://abibuilder.cs.uni-tuebingen.de/archive/openms/Tutorials/Data/latest/Example_Data/Metabolomics/databases/MetaboliteSpectralDB.mzML | |
118 mv MetaboliteSpectralDB.mzML test-data/ | |
119 fi | |
120 ln -fs TOFCalibration_ref_masses test-data/TOFCalibration_ref_masses.txt | |
121 ln -fs TOFCalibration_const test-data/TOFCalibration_const.csv | |
122 | |
123 if [ ! -d test-data/pepnovo_models/ ]; then | |
124 mkdir -p /tmp/pepnovo | |
125 wget -nc http://proteomics.ucsd.edu/Software/PepNovo/PepNovo.20120423.zip | |
126 unzip PepNovo.20120423.zip -d /tmp/pepnovo/ | |
127 mv /tmp/pepnovo/Models test-data/pepnovo_models/ | |
128 rm PepNovo.20120423.zip | |
129 rm -rf /tmp/pepnovo | |
130 fi | |
131 ############################################################################### | |
132 ## generate ctd files using the binaries in the conda package | |
133 ############################################################################### | |
134 echo "Create CTD files" | |
135 conda activate $OPENMSENV | |
136 rm -rf ctd | |
137 mkdir -p ctd | |
138 | |
139 for i in $OPENMSPKG/bin/* | |
140 do | |
141 b=$(basename $i) | |
142 echo $b | |
143 $b -write_ctd ctd/ | |
144 sed -i -e 's/²/^2/' ctd/$b.ctd | |
145 done | |
146 ############################################################################### | |
147 ## fix ini files: OpenMS test data contains ini files with outdated ini files. | |
148 ## e.g. variables might be in different nodes, outdated variables present, new | |
149 ## variables missing, ... | |
150 ## OpenMS tools fix this on the fly (so its no problem for the OpenMS tests) | |
151 ## but it is for the generation of the tests | |
152 ## see https://github.com/OpenMS/OpenMS/issues/4462 | |
153 ############################################################################### | |
154 echo "Update test INI files" | |
155 for ini in test-data/*ini | |
156 do | |
157 tool=$(cat $ini | grep 'NODE name="' | head -n 1 | sed 's/.*name="\([^"]\+\)".*/\1/') | |
158 bin=$(which $tool) | |
159 if [[ -z $bin ]]; then | |
160 >&2 echo "missing binary to convert $ini" | |
161 continue | |
162 fi | |
163 cp $ini $ini.backup | |
164 $bin -ini $ini -write_ini $ini > $ini.stdout 2> $ini.stderr | |
165 if [[ "$?" -ne "0" ]]; then | |
166 >&2 echo "could not convert $ini" | |
167 fi | |
168 done | |
169 | |
170 ############################################################################### | |
171 ## create script to create results for the tests and run it | |
172 ############################################################################### | |
173 echo "Create test shell script" | |
174 | |
175 echo -n "" > prepare_test_data.sh | |
176 echo 'export COMET_BINARY="comet"' >> prepare_test_data.sh | |
177 echo 'export CRUX_BINARY="crux"' >> prepare_test_data.sh | |
178 echo 'export FIDOCHOOSEPARAMS_BINARY="FidoChooseParameters"' >> prepare_test_data.sh | |
179 echo 'export FIDO_BINARY="Fido"' >> prepare_test_data.sh | |
180 echo 'export LUCIPHOR_BINARY="$(dirname $(realpath $(which luciphor2)))/luciphor2.jar"' >> prepare_test_data.sh | |
181 | |
182 echo 'export MARACLUSTER_BINARY="'"$OPENMSGIT"'/THIRDPARTY/Linux/64bit/MaRaCluster/maracluster"'>> prepare_test_data.sh | |
183 echo 'export MSFRAGGER_BINARY="/home/berntm/Downloads/MSFragger-20171106/MSFragger-20171106.jar"'>> prepare_test_data.sh | |
184 echo 'export MSGFPLUS_BINARY="$(msgf_plus -get_jar_path)"' >> prepare_test_data.sh | |
185 echo 'export MYRIMATCH_BINARY="myrimatch"'>> prepare_test_data.sh | |
186 echo 'export NOVOR_BINARY="/home/berntm/Downloads/novor/lib/novor.jar"' >> prepare_test_data.sh | |
187 echo 'export OMSSA_BINARY="$(dirname $(realpath $(which omssacl)))/omssacl"'>> prepare_test_data.sh | |
188 echo 'export PERCOLATOR_BINARY="percolator"'>> prepare_test_data.sh | |
189 echo 'export SIRIUS_BINARY="$(which sirius)"' >> prepare_test_data.sh | |
190 echo 'export SPECTRAST_BINARY="'"$OPENMSGIT"'/THIRDPARTY/Linux/64bit/SpectraST/spectrast"' >> prepare_test_data.sh | |
191 echo 'export XTANDEM_BINARY="xtandem"' >> prepare_test_data.sh | |
192 echo 'export THERMORAWFILEPARSER_BINARY="ThermoRawFileParser.exe"' >> prepare_test_data.sh | |
193 | |
194 prepare_test_data >> prepare_test_data.sh #tmp_test_data.sh | |
195 | |
196 ## prepare_test_data > tmp_test_data.sh | |
197 ## # remove calls not needed for the tools listed in any .list file | |
198 ## echo LIST $LIST | |
199 ## if [ ! -z "$LIST" ]; then | |
200 ## REX=$(echo $LIST | sed 's/ /\n/g' | sed 's@.*/\([^/]\+\).xml$@\1@' | tr '\n' '|' | sed 's/|$//') | |
201 ## else | |
202 ## REX=".*" | |
203 ## fi | |
204 ## echo REX $REX | |
205 ## cat tmp_test_data.sh | egrep "($REX)" >> prepare_test_data.sh | |
206 ## rm tmp_test_data.sh | |
207 | |
208 echo "Execute test shell script" | |
209 chmod u+x prepare_test_data.sh | |
210 cd ./test-data || exit | |
211 ../prepare_test_data.sh | |
212 cd - || exit | |
213 | |
214 | |
215 # ############################################################################### | |
216 # ## create/update test data for the manually generated tests | |
217 # ## - run convert once with the manual tests only and | |
218 # ## - update test-data (needs to run 2x) | |
219 # ############################################################################### | |
220 echo "Execute test shell script for manually curated tests" | |
221 chmod u+x prepare_test_data_manual.sh | |
222 cd ./test-data || exit | |
223 ../prepare_test_data_manual.sh | |
224 cd - || exit | |
225 | |
226 | |
227 ############################################################################### | |
228 ## auto generate tests | |
229 ############################################################################### | |
230 | |
231 echo "Write test macros to $autotests" | |
232 echo "<macros>" > "$autotests" | |
233 | |
234 for i in $(ls ctd/*ctd) | |
235 do | |
236 b=$(basename "$i" .ctd) | |
237 get_tests2 "$b" >> "$autotests" | |
238 done | |
239 echo "</macros>" >> "$autotests" | |
240 | |
241 # echo "Create test data links" | |
242 # Breaks DecoyDatabase | |
243 # link_tmp_files | |
244 | |
245 # tests for tools using output_prefix parameters can not be auto generated | |
246 # hence we output the tests for manual curation in macros_test.xml | |
247 # and remove them from the autotests | |
248 # -> OpenSwathFileSplitter IDRipper MzMLSplitter SeedListGenerator | |
249 # TODO reevaluate in >2.8 | |
250 # - https://github.com/OpenMS/OpenMS/pull/5873 | |
251 # - https://github.com/OpenMS/OpenMS/pull/5912 | |
252 # | |
253 # Furthermore we remove tests for tools without binaries in conda | |
254 # -> MSFragger MaRaClusterAdapter NovorAdapter | |
255 # | |
256 # not able to specify composite test data | |
257 # -> SpectraSTSearchAdapter | |
258 if [[ ! -z "$1" ]]; then | |
259 echo "" > macros_discarded_auto.xml | |
260 for i in OpenSwathFileSplitter IDRipper MzMLSplitter SeedListGenerator MSFraggerAdapter MaRaClusterAdapter NovorAdapter SpectraSTSearchAdapter | |
261 do | |
262 echo "<xml name=\"manutest_$i\">" >> macros_discarded_auto.xml | |
263 xmlstarlet sel -t -c "/macros/xml[@name='autotest_$i']/test" macros_autotest.xml >> macros_discarded_auto.xml | |
264 echo "</xml>" >> macros_discarded_auto.xml | |
265 xmlstarlet ed -d "/macros/xml[@name='autotest_$i']/test" macros_autotest.xml > tmp | |
266 mv tmp macros_autotest.xml | |
267 done | |
268 >&2 echo "discarded autogenerated macros for curation in macros_discarded_auto.xml" | |
269 fi | |
270 conda deactivate | |
271 | |
272 ## remove broken symlinks in test-data | |
273 find test-data/ -xtype l -delete | |
274 | |
275 if [ ! -z "$created" ]; then | |
276 echo "Removing temporary directory" | |
277 rm -rf "$tmp" | |
278 fi |