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