-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathvalidate.sh
executable file
·73 lines (71 loc) · 2.84 KB
/
validate.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
#!/bin/bash
V_VERSION="1.0.6"
V_URL="https://repo1.maven.org/maven2/de/isas/mztab/jmztabm-cli/$V_VERSION/jmztabm-cli-$V_VERSION-bin.zip"
V_DIR="../../../examples/2_0-Metabolomics_Release/"
# download and unzip validator
mkdir -p build/validation
cd build/validation
rm -rf *
wget $V_URL
if [ $? -ne 0 ]; then
echo -e "Failed to download validator cli distribution from $V_URL"
exit 1
fi
unzip jmztabm-cli-$V_VERSION-bin.zip
cd jmztabm-cli
if [ $? -ne 0 ]; then
echo "Failed to unzip distribution / cd into directory."
exit 2
fi
# alternatives: Warn or Error
V_LEVEL="Info"
V_FAILED=()
# run validation for all example files
for i in $(find "$V_DIR" -maxdepth 1 -iname '*.mztab'); do
echo -e "################################################################################"
if [[ $i == *"MouseLiver_negative"* ]]; then
echo -e "# Starting basic validation of $i on level $V_LEVEL"
java -jar jmztabm-cli-$V_VERSION.jar -c $i -level $V_LEVEL
else
echo -e "# Starting full validation of $i on level $V_LEVEL"
# semantic validation may take quite some time for larger files
java -jar jmztabm-cli-$V_VERSION.jar -c $i -s cv-mapping/mzTab-M-mapping.xml -level $V_LEVEL
fi
if [ $? -ne 0 ];
then
echo -e "# Validation of file $i failed! Please check console output for errors!"
V_FAILED+=($i)
else
echo -e "# Validation of file $i was successful. Please check console output for hints for improvment!"
fi
echo -e "################################################################################"
done
# TODO: once ols can resolved MS DIAL CV term properly, switch to semantic validation
for i in $(find "$V_DIR/msdial" -maxdepth 1 -iname '*.txt'); do
echo -e "################################################################################"
echo -e "# Starting basic validation of $i on level $V_LEVEL"
java -jar jmztabm-cli-$V_VERSION.jar -c $i -level $V_LEVEL
if [ $? -ne 0 ];
then
echo -e "# Validation of file $i failed! Please check console output for errors!"
V_FAILED+=($i)
else
echo -e "# Validation of file $i was successful. Please check console output for hints for improvment!"
fi
echo -e "################################################################################"
done
if [ ${#V_FAILED[@]} -ne 0 ]; then
echo -e "################################################################################"
echo -e "# Validation failed for ${#V_FAILED[@]} files! Please check the following files:"
for i in "${V_FAILED[@]}"
do
echo "# $i"
done
echo -e "################################################################################"
exit 3
else
echo -e "################################################################################"
echo -e "# Validation of all files successful!"
echo -e "################################################################################"
exit 0
fi