add update_expected_results_from_jenkins.sh

Change-Id: Ib3ad8554fc59112c11325425ccd70ca1dbd8c123
This commit is contained in:
Neels Hofmeyr 2018-04-11 15:23:46 +02:00
parent fc0384a046
commit f77740b12a
1 changed files with 53 additions and 0 deletions

View File

@ -0,0 +1,53 @@
#!/bin/sh
# Download the latest junit xml results from the jenkins.osmocom.org workspaces.
# Usage:
# - have a clean git clone of osmo-ttcn3-hacks
# - have internet access to jenkins.osmocom.org
# - ./update_expected_results_from_jenkins.sh
# - git diff, make sure that you understand and approve of each and every change
# - git commit -a -m "update expected results"
not_found=""
if [ -n "$(git status | grep 'modified:')" ]; then
echo "Your git clone contains modifications! This is not recommended."
echo "Hit enter to continue anyway."
read enter_to_continue
fi
for target in */expected-results.xml; do
project="$(basename "$(dirname "$target")")"
# shims for naming exceptions
ws_path="ttcn3-${project}-test/ws/logs/${project}-tester"
if [ "x$project" = "xggsn_tests" ]; then
project="ggsn"
elif [ "x$project" = "xsysinfo" ]; then
ws_path="ttcn3-nitb-sysinfo/ws/logs/ttcn3-nitb-sysinfo"
fi
# find out the junit-NN.xml name
dir_url="https://jenkins.osmocom.org/jenkins/job/$ws_path/"
junit_file="$(wget -q -O - "$dir_url" | grep 'junit-xml-[0-9]*\.log' | tail -n 1 | sed 's/.*\(junit-xml-[0-9]*\.log\).*/\1/')"
# update
target_new="$target.new"
if ! wget -O "$target_new" "${dir_url}$junit_file"; then
not_found="$not_found $project"
rm -f "$target_new"
else
mv "$target_new" "$target"
fi
done
./mask_expected_results.sh
echo "
MAKE SURE THE RESULTING CHANGES ARE SANE BEFORE COMMITTING!
"
if [ -n "$not_found" ]; then
echo "Could not update: $not_found"
fi