forked from fkanehiro/hrpsys-base
-
Notifications
You must be signed in to change notification settings - Fork 7
/
.travis.sh
executable file
·428 lines (353 loc) · 21.7 KB
/
.travis.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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
#!/bin/bash
set -x
function error {
travis_time_end 31
mkdir -p ${HOME}/.ros/test_results || echo "OK"
find ${HOME}/.ros/test_results -type f -exec echo "=== {} ===" \; -exec\
cat {} \;
for file in ${HOME}/.ros/log/rostest-*; do echo "=== $file ==="; cat \$\
file; done
exit 1
}
trap error ERR
function travis_time_start {
set +x
TRAVIS_START_TIME=$(date +%s%N)
TRAVIS_TIME_ID=$(cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 8 | head -n 1)
TRAVIS_FOLD_NAME=$1
echo -e "\e[0Ktraivs_fold:start:$TRAVIS_FOLD_NAME"
echo -e "\e[0Ktraivs_time:start:$TRAVIS_TIME_ID"
set -x
}
function travis_time_end {
set +x
_COLOR=${1:-32}
TRAVIS_END_TIME=$(date +%s%N)
TIME_ELAPSED_SECONDS=$(( ($TRAVIS_END_TIME - $TRAVIS_START_TIME)/1000000000 ))
echo -e "traivs_time:end:$TRAVIS_TIME_ID:start=$TRAVIS_START_TIME,finish=$TRAVIS_END_TIME,duration=$(($TRAVIS_END_TIME - $TRAVIS_START_TIME))\n\e[0K"
echo -e "traivs_fold:end:$TRAVIS_FOLD_NAME"
echo -e "\e[0K\e[${_COLOR}mFunction $TRAVIS_FOLD_NAME takes $(( $TIME_ELAPSED_SECONDS / 60 )) min $(( $TIME_ELAPSED_SECONDS % 60 )) sec\e[0m"
set -x
}
export DEBIAN_FRONTEND=noninteractive
apt-get update -q=5
apt-get install -q=5 -y wget sudo git sed
apt-get install -q=5 -y software-properties-common # apt-add-repository
apt-get install -q=5 -y lsb-release
apt-get install -q=5 -y tzdata
lsb_release -a
echo $ROS_DISTRO
echo $DISTRO
travis_time_start mongo_hack
# MongoDB hack
dpkg -s mongodb || echo "ok"; export HAVE_MONGO_DB=$?
# Remove configuration file for mongodb using --purge option (reported in https://github.com/fkanehiro/hrpsys-base/pull/900#issuecomment-162392884)
if [ $HAVE_MONGO_DB == 0 ]; then sudo apt-get remove --purge -qq -y mongodb mongodb-10gen || echo "ok"; fi
if [ $HAVE_MONGO_DB == 0 ]; then sudo apt-get install -qq -y mongodb-clients mongodb-server -o Dpkg::Options::="--force-confdef" || echo "ok"; fi # default actions
travis_time_end
travis_time_start setup_ros
export CI_SOURCE_PATH=$(pwd)
export REPOSITORY_NAME=${PWD##*/}
echo "Testing branch $TRAVIS_BRANCH of $REPOSITORY_NAME"
sudo -E sh -c 'echo "deb http://packages.ros.org/ros-shadow-fixed/ubuntu ${DISTRO} main" > /etc/apt/sources.list.d/ros-latest.list'
wget http://packages.ros.org/ros.key -O - | sudo apt-key add -
sudo apt-get update -qq
travis_time_end
travis_time_start disable_ssl
# disable ssl
git config --global http.sslVerify false
travis_time_end
case $TEST_PACKAGE in
hrpsys)
case $TEST_TYPE in
python)
travis_time_start install_python
#http://askubuntu.com/questions/204510/how-to-install-python-2-5-4
sudo apt-add-repository -y ppa:deadsnakes
sudo apt-get update -qq
sudo apt-get install -qq -y --force-yes python2.5 python2.7 python3.4
travis_time_end
travis_time_start check_python
for code in python/*.py; do
python2.5 -m py_compile $code
python2.7 -m py_compile $code
python3.4 -m py_compile $code
done
travis_time_end
;;
iob)
travis_time_start install_wget
sudo apt-get install -qq -y cproto wget diffstat
travis_time_end
travis_time_start iob_test
wget https://github.com/fkanehiro/hrpsys-base/raw/315.1.9/lib/io/iob.h -O iob.h.315.1.9
echo -e "#define pid_t int\n#define size_t int\n#include \"lib/io/iob.h\"" | cproto -x - | sort > iob.h.current
echo -e "#define pid_t int\n#define size_t int\n#include \"iob.h.315.1.9\"" | cproto -x - | sort > iob.h.stable
cat iob.h.current
cat iob.h.stable
diff iob.h.stable iob.h.current || exit 1
travis_time_end
;;
stable_rtc)
travis_time_start install_openrtm
sudo apt-get install -qq -y omniidl diffstat wget ros-${ROS_DISTRO}-openrtm-aist
source /opt/ros/${ROS_DISTRO}/setup.bash
## check stableRTCList
sed -i 's@^from@#from@g' python/hrpsys_config.py
sed -i 's@^import@#import@' python/hrpsys_config.py
sed -i 's@^_EPS@#_EPS@' python/hrpsys_config.py
sed -i 's@=nshost@=None@' python/hrpsys_config.py
sed -i 's@initCORBA@#initCORBA@' python/hrpsys_config.py
if [ "`python -c "import python.hrpsys_config; hcf=python.hrpsys_config.HrpsysConfigurator(); print [ x[1] for x in hcf.getRTCList()]" | tail -1`" != "['SequencePlayer', 'StateHolder', 'ForwardKinematics', 'CollisionDetector', 'SoftErrorLimiter', 'DataLogger']" ]; then
exit 1
fi
travis_time_end
travis_time_start check_idl
## check idl
mkdir stable_idl
for idl_file in SequencePlayerService.idl StateHolderService.idl ForwardKinematicsService.idl CollisionDetectorService.idl SoftErrorLimiterService.idl DataLoggerService.idl ExecutionProfileService.idl HRPDataTypes.idl RobotHardwareService.idl ; do
wget https://github.com/fkanehiro/hrpsys-base/raw/315.1.9/idl/${idl_file} -O stable_idl/${idl_file}
omniidl -bcxx -I/opt/ros/${ROS_DISTRO}/include/openrtm-1.1/rtm/idl/ idl/${idl_file}
omniidl -bcxx -I/opt/ros/${ROS_DISTRO}/include/openrtm-1.1/rtm/idl/ -C stable_idl stable_idl/${idl_file}
sk_file=$(basename ${idl_file} .idl)SK.cc
cat ${sk_file}
cat stable_idl/${sk_file}
diff stable_idl/${sk_file} ${sk_file} | tee >(cat - 1>&2) | diffstat | grep -c deletion && exit 1
done
echo "ok"
travis_time_end
;;
*)
travis_time_start install_libs
# COMPILE_ONLY
sudo apt-get install -qq -y freeglut3-dev python-tk jython doxygen graphviz libboost-all-dev libsdl1.2-dev libglew1.6-dev libqhull-dev libirrlicht-dev libxmu-dev libcv-dev libhighgui-dev libopencv-contrib-dev
travis_time_end
travis_time_start install_openhrp3
sudo apt-get install -qq -y ros-${ROS_DISTRO}-openhrp3
source /opt/ros/${ROS_DISTRO}/setup.bash
if [ "$USE_SRC_OPENHRP3" == true ] ; then
sudo dpkg -r --force-depends ros-${ROS_DISTRO}-openhrp3
mkdir -p ~/build_openhrp3
cd ~/build_openhrp3
git clone http://github.com/fkanehiro/openhrp3
sed -i 's/COLLADA_DOM_FOUND/0/' openhrp3/sample/CMakeLists.txt
cd openhrp3 && cmake . ${COMPILE_OPTION} && make && sudo make install
fi
mkdir -p ~/build
travis_time_end
travis_time_start compile_hrpsys
cd ~/build && cmake ${CI_SOURCE_PATH} ${COMPILE_OPTION} && make
# Check make test by passing PATH to bin directory
PATH=$PATH:~/build/bin make test
travis_time_end
;;
esac
;;
*)
travis_time_start install_libs
# COMPILE
sudo apt-get install -qq -y freeglut3-dev python-tk jython doxygen libboost-all-dev libsdl1.2-dev libglew1.6-dev libqhull-dev libirrlicht-dev libxmu-dev libcv-dev libhighgui-dev libopencv-contrib-dev
# check rtmros_common
if [ "$TEST_PACKAGE" == "hrpsys-base" ]; then
TEST_PACKAGE="hrpsys"
fi
travis_time_end
travis_time_start install_$TEST_PACKAGE
pkg=$TEST_PACKAGE
sudo apt-get install -qq -y python-wstool ros-${ROS_DISTRO}-catkin ros-${ROS_DISTRO}-mk ros-${ROS_DISTRO}-rostest ros-${ROS_DISTRO}-rtmbuild ros-${ROS_DISTRO}-roslint > /dev/null
sudo apt-get install -qq -y ros-${ROS_DISTRO}-pcl-ros ros-${ROS_DISTRO}-moveit-commander ros-${ROS_DISTRO}-rqt-robot-dashboard > /dev/null
sudo apt-get install -qq -y ros-${ROS_DISTRO}-$pkg
source /opt/ros/${ROS_DISTRO}/setup.bash
travis_time_end
travis_time_start setup_catkin_ws
# set hrpsys in catkin workspace
mkdir -p ~/catkin_ws/src
cd ~/catkin_ws/src
wstool init
ln -sf ${CI_SOURCE_PATH} hrpsys
sed -i "s@if(ENABLE_DOXYGEN)@if(0)@" hrpsys/CMakeLists.txt # disable doc generation
find hrpsys -name CMakeLists.txt -exec sed -i "s@PCL_FOUND@0@" {} \; # disable PCL
find hrpsys -name CMakeLists.txt -exec sed -i "s@OCTMAP_FOUND@0@" {} \; # disable OCTMAP
find hrpsys -name CMakeLists.txt -exec sed -i "s@IRRLIGHT_FOUND@0@" {} \; # disable IRRLIGHT
if [ "$USE_SRC_OPENHRP3" == true ] ; then
git clone http://github.com/fkanehiro/openhrp3/
sed -i 's/COLLADA_DOM_FOUND/0/' openhrp3/sample/CMakeLists.txt
fi
cd ~/catkin_ws
travis_time_end
if [ "$TEST_TYPE" == "work_with_downstream" ]; then
echo "
#
# check newer version of hrpsys works on current rtmros_common deb package
# [hrpsys:new] <-> [rtmros_common:old] + [hrpsys:old]
"
travis_time_start compile_and_install_downstream
sudo dpkg -r --force-depends ros-${ROS_DISTRO}-hrpsys
catkin_make_isolated --install
# you need to pretend this is catkin package since you only have hrpsys in catkin_ws
export ROS_PACKAGE_PATH=`pwd`/install_isolated/share:`pwd`/install_isolated/stacks:$ROS_PACKAGE_PATH
source install_isolated/setup.bash
travis_time_end
else
echo "
#
# check rtmros_common compiled on newer version of hrpsys works with deb version of hrpsys
# [hrpsys:old] <-> [rtmros_common:new] + [hrpsys:new]
"
travis_time_start setup_wstool_rtmros
# set up sorce code of downstream package
cd src
wstool set rtmros_common http://github.com/start-jsk/rtmros_common --git -y
wstool set rtmros_hironx http://github.com/start-jsk/rtmros_hironx --git -y
wstool set rtmros_nextage http://github.com/tork-a/rtmros_nextage --git -y
wstool update
sudo apt-get install -qq -y ros-${ROS_DISTRO}-urdf
sudo dpkg -r --force-depends ros-${ROS_DISTRO}-hrpsys
export ROS_LANG_DISABLE=genlisp
cd ..
# do not compile unstable rtc
sed -i -e 's/\(add_subdirectory(\(RobotHardware\|SequencePlayer\|StateHolder\|ForwardKinematics\|CollisionDetector\|SoftErrorLimiter\|DataLogger\))\)/#\1/' -e 's/add_subdirectory/#add_subdirectory/' -e 's/##add/add/' src/hrpsys/rtc/CMakeLists.txt
cat src/hrpsys/rtc/CMakeLists.txt
# do not copile hrpsys because we wan to use them
sed -i "1imacro(dummy_install)\nmessage(\"install(\${ARGN})\")\nendmacro()" src/hrpsys/CMakeLists.txt
sed -i "s@install(@dummy_install(@g" src/hrpsys/CMakeLists.txt
sed -i "\$iinstall(DIRECTORY test launch sample DESTINATION share/hrpsys USE_SOURCE_PERMISSIONS)" src/hrpsys/CMakeLists.txt
sed -i "\$iinstall(FILES package.xml DESTINATION share/hrpsys/)" src/hrpsys/CMakeLists.txt
sed -i "\$iinstall(CODE \"execute_process(COMMAND cmake -E make_directory share/hrpsys WORKING_DIRECTORY \$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/share/hrpsys)\")" src/hrpsys/CMakeLists.txt
sed -i "\$iinstall(CODE \"execute_process(COMMAND cmake -E create_symlink ../../../hrpsys/idl share/hrpsys/idl WORKING_DIRECTORY \$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/share/hrpsys)\")" src/hrpsys/CMakeLists.txt
sed -i "\$iinstall(CODE \"execute_process(COMMAND cmake -E create_symlink ../../../hrpsys/samples share/hrpsys/samples WORKING_DIRECTORY \$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/share/hrpsys)\")" src/hrpsys/CMakeLists.txt
cat src/hrpsys/CMakeLists.txt
travis_time_end
travis_time_start compile_new_version
catkin_make_isolated --install --only-pkg-with-deps `echo $pkg | sed s/-/_/g` | grep -v '^-- \(Up-to-date\|Installing\):' | grep -v 'Generating \(Python\|C++\) code from' | grep -v '^Compiling .*.py ...$' | uniq
rm -fr ./install_isolated/hrpsys/share/hrpsys ./install_isolated/hrpsys/lib/pkgconfig/hrpsys.pc
source install_isolated/setup.bash
travis_time_end
travis_time_start setup_old_hrpsys
# checkokut old hrpsys
mkdir -p ~/hrpsys_ws/src
cd ~/hrpsys_ws/src
wstool init .
wstool set hrpsys http://github.com/start-jsk/hrpsys -v 315.1.9 --git -y
wstool update
#
sed -i "1imacro(dummy_macro)\nmessage(\"dummy(\${ARGN})\")\nendmacro()" hrpsys/catkin.cmake
sed -i "s@install(DIRECTORY test share@dummy_macro(DIRECTORY test share@" hrpsys/catkin.cmake
sed -i "s@find_package(catkin REQUIRED COMPONENTS rostest mk openrtm_aist openhrp3)@find_package(catkin REQUIRED COMPONENTS rostest mk)\nset(openrtm_aist_PREFIX /opt/ros/${ROS_DISTRO}/)\nset(openhrp3_PREFIX /opt/ros/${ROS_DISTRO}/)@" hrpsys/catkin.cmake
cat hrpsys/catkin.cmake
sed -i "s@NUM_OF_CPUS = \$(shell grep -c '^processor' /proc/cpuinfo)@NUM_OF_CPUS = 2@" hrpsys/Makefile.hrpsys-base
sed -i "s@touch installed@@" hrpsys/Makefile.hrpsys-base
cat hrpsys/Makefile.hrpsys-base
# use git repository, instead of svn due to googlecode shoutdown
git clone http://github.com/fkanehiro/hrpsys-base ../build_isolated/hrpsys/build/hrpsys-base-source
(cd ../build_isolated/hrpsys/build/hrpsys-base-source; git checkout 315.1.9)
if [ "${ROS_DISTRO}" != "hydro" ]; then
# tmp fix to build old hrpsys
sudo ln -s /usr/lib/x86_64-linux-gnu/libboost_thread.so /usr/lib/x86_64-linux-gnu/libboost_thread-mt.so
sudo ln -s /usr/lib/x86_64-linux-gnu/libboost_system.so /usr/lib/x86_64-linux-gnu/libboost_system-mt.so
fi
# we use latest hrpsys_ocnfig.py for this case, so do not install them
sed -i -e 's/\(add_subdirectory(python)\)/#\1/' ../build_isolated/hrpsys/build/hrpsys-base-source/CMakeLists.txt
sed -i -e 's/\(add_subdirectory(test)\)/#\1/' ../build_isolated/hrpsys/build/hrpsys-base-source/CMakeLists.txt
find ../build_isolated/hrpsys/build/hrpsys-base-source -name CMakeLists.txt -exec sed -i "s@PCL_FOUND@0@" {} \; # disable PCL
find ../build_isolated/hrpsys/build/hrpsys-base-source -name CMakeLists.txt -exec sed -i "s@OCTOMAP_FOUND@0@" {} \; # disable OCTOMAP
find ../build_isolated/hrpsys/build/hrpsys-base-source -name CMakeLists.txt -exec sed -i "s@IRRLIGHT_FOUND@0@" {} \; # disable IRRLIGHT
sed -i "s@USE_HRPSYSUTIL@0@" ../build_isolated/hrpsys/build/hrpsys-base-source/rtc/CMakeLists.txt # disable HRPSYSUTIL APPs # this disables CollisionDetector
sed -i "\$aadd_subdirectory(CollisionDetector)" ../build_isolated/hrpsys/build/hrpsys-base-source/rtc/CMakeLists.txt
sed -i "s@NOT QNXNTO@1@" ../build_isolated/hrpsys/build/hrpsys-base-source/rtc/CMakeLists.txt # disable Joystick
sed -i "1imacro(dummy_macro)\nmessage(\"dummy(\${ARGN})\")\nendmacro()" ../build_isolated/hrpsys/build/hrpsys-base-source/util/simulator/CMakeLists.txt
sed -i "s@\(.*\)(hrpsysext@dummy_macro(hrpsysext@g" ../build_isolated/hrpsys/build/hrpsys-base-source/util/simulator/CMakeLists.txt
sed -i "s@install(TARGETS hrpsysext@dummy_macro(TARGETS hrpsysext@g" ../build_isolated/hrpsys/build/hrpsys-base-source/util/simulator/CMakeLists.txt
cat ../build_isolated/hrpsys/build/hrpsys-base-source/CMakeLists.txt
cat ../build_isolated/hrpsys/build/hrpsys-base-source/rtc/CMakeLists.txt
cd ~/hrpsys_ws
ls -al src
ls -al src/hrpsys
travis_time_end
travis_time_start compile_old_hrpsys
trap 0 ERR
need_compile=1
while [ $need_compile != 0 ]; do
catkin_make_isolated --merge
need_compile=$?
done
trap error ERR
travis_time_end
travis_time_start install_old_hrpsys
trap 0 ERR
need_compile=1
while [ $need_compile != 0 ]; do
catkin_make_isolated --install | grep -v '^-- \(Up-to-date\|Installing\):'
need_compile=${PIPESTATUS[0]}
done
trap error ERR
#cp ~/catkin_ws/src/hrpsys/package.xml install_isolated/share/hrpsys/ # old hrpsys did not do this
mkdir -p install_isolated/share/hrpsys/share/hrpsys/
cp -r ~/catkin_ws/install_isolated/share/hrpsys/idl install_isolated/share/hrpsys/share/hrpsys/
cp -r ~/catkin_ws/install_isolated/share/hrpsys/{test,launch,samples} install_isolated/share/hrpsys/ # cp latest script
source install_isolated/setup.bash
#echo $ROS_PACKAGE_PATH
#export ROS_PACKAGE_PATH=`pwd`/install_isolated:$ROS_PACKAGE_PATH # for hrpsys (plane cmake)
ls -al install_isolated/share/hrpsys
rospack profile
rospack find hrpsys
cd ~/catkin_ws
travis_time_end
fi
travis_time_start hot_fixes
rospack profile
if [ "${ROS_DISTRO}" == "hydro" ]; then
# https://github.com/fkanehiro/openhrp3/issues/46
ls -al /opt/ros/${ROS_DISTRO}/share/openhrp3/share/OpenHRP-3.1/sample/controller/SampleController || echo "ok"
sudo mkdir -p /opt/ros/${ROS_DISTRO}/share/openhrp3/share/OpenHRP-3.1/sample/controller/SampleController/etc/ || echo "ok"
sudo wget https://raw.githubusercontent.com/fkanehiro/openhrp3/master/sample/controller/SampleController/etc/Sample.pos -O /opt/ros/${ROS_DISTRO}/share/openhrp3/share/OpenHRP-3.1/sample/controller/SampleController/etc/Sample.pos || echo "ok"
sudo wget https://raw.githubusercontent.com/fkanehiro/openhrp3/master/sample/controller/SampleController/etc/Sample.vel -O /opt/ros/${ROS_DISTRO}/share/openhrp3/share/OpenHRP-3.1/sample/controller/SampleController/etc/Sample.vel || echo "ok"
# https://github.com/start-jsk/rtmros_hironx/issues/287
if [ -e /opt/ros/${ROS_DISTRO}/share/hironx_ros_bridge/test/test_hironx_ros_bridge.py ]; then
sudo sed -i "s@test_tf_and_controller@_test_tf_and_controller@" /opt/ros/${ROS_DISTRO}/share/hironx_ros_bridge/test/test_hironx_ros_bridge.py
fi
#https://github.com/start-jsk/rtmros_hironx/pull/358
if [ -e /opt/ros/${ROS_DISTRO}/lib/python2.7/dist-packages/hironx_ros_bridge/hironx_client.py ]; then
sudo wget https://raw.githubusercontent.com/k-okada/rtmros_hironx/stop_unfinished_battle/hironx_ros_bridge/src/hironx_ros_bridge/hironx_client.py -O /opt/ros/${ROS_DISTRO}/lib/python2.7/dist-packages/hironx_ros_bridge/hironx_client.py
fi
#https://github.com/start-jsk/rtmros_common/commit/51ec26b899f09304705fe0528a068e57b061b9b7
#https://github.com/start-jsk/rtmros_common/pull/880
#https://github.com/start-jsk/rtmros_common/pull/879
if [ -e /opt/ros/${ROS_DISTRO}/share/hrpsys_ros_bridge/test/test-samplerobot.test ]; then
sudo wget https://raw.githubusercontent.com/start-jsk/rtmros_common/1.3.1/hrpsys_ros_bridge/test/test-samplerobot.test -O /opt/ros/${ROS_DISTRO}/share/hrpsys_ros_bridge/test/test-samplerobot.test
fi
fi
travis_time_end
# Check make test
(cd ~/catkin_ws/build_isolated/hrpsys/install && make test)
# Check rostest
sudo /etc/init.d/omniorb4-nameserver stop || echo "stop omniserver just in case..."
export EXIT_STATUS=0;
pkg_path=`rospack find \`echo $pkg | sed s/-/_/g\``
if [ "`find $pkg_path/test -iname '*.test'`" == "" ]; then
echo "[$pkg] No tests ware found!!!"
else
for test_file in `find $pkg_path/test -iname "*.test" -print`; do
travis_time_start $(echo $test_file | sed 's@.*/\([a-zA-Z0-9-]*\).test$@\1@' | sed 's@-@_@g')
export TMP_EXIT_STATUS=0
rostest $test_file && travis_time_end || export TMP_EXIT_STATUS=$?
if [ "$TMP_EXIT_STATUS" != 0 ]; then
export EXIT_STATUS=$TMP_EXIT_STATUS
# Print results of rostest-*.xml files
find ~/.ros/test_results -type f -iname "*`basename $test_file .test`.xml" -print -exec echo "=== {} ===" \; -exec cat {} \;
# Print results of each rosunit-*.xml file
# Get rosunit*.xml file path from rostest-*.xml file by usig awk and cut.
# Files are assumed to include "xxx results are in [/home/xxx/rosunit-yy.xml]"
rosunit_xml_result_files=$(find ~/.ros/test_results -type f -iname "*`basename $test_file .test`.xml" -print -exec echo "=== {} ===" \; -exec cat {} \; | grep "results are in" | awk -F'results are in ' '{print $2}' | cut -d\[ -f2 | cut -d\] -f1)
if [ "${rosunit_xml_result_files}" != "" ]; then cat ${rosunit_xml_result_files}; fi
travis_time_end 31
fi
done
fi
travis_time_start end_tests
# for debugging
[ $TEST_PACKAGE == "hrpsys-ros-bridge" ] && rostest -t hrpsys_ros_bridge test-samplerobot.test
[ $EXIT_STATUS == 0 ] || exit 1
travis_time_end
;;
esac