forked from nasa/astrobee
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_tests.sh
executable file
·52 lines (41 loc) · 1.79 KB
/
run_tests.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
#!/bin/bash
#
# Copyright (c) 2017, United States Government, as represented by the
# Administrator of the National Aeronautics and Space Administration.
#
# All rights reserved.
#
# The Astrobee platform is licensed under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with the
# License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
# This script is intended to be run from within your docker
# container. It closely mimics test_astrobee.Dockerfile and the
# testing phase of the GitHub CI.
script_folder=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
catkin_ws=$( cd -- "${script_folder}/../.." &> /dev/null && pwd )
set -e
set -x
# The package argument is optional. Default is to test all packages.
package=$1
cd ${catkin_ws}
# compile the tests
catkin build --no-status --force-color ${package} --make-args tests
# run the tests and build the formal test results
{ catkin build --no-status --force-color ${package} --make-args test -j1 || true; }
set +x
{ source devel/setup.sh || true; }
set -x
# collect the test results to determine global success/failure
{ success="true" && catkin_test_results build/${package} || success="false" || true; }
# if any tests failed, re-run in a different way that provides more debug output
{ [ "$success" = "true" ] || catkin run_tests --no-status --force-color -j1 ${package} || true; }
# return global success/failure
[ "$success" = "true" ]