Home | History | Annotate | Download | only in valgrind
      1 # Copyright (C) 2014 The Android Open Source Project
      2 #
      3 # Licensed under the Apache License, Version 2.0 (the 'License');
      4 # you may not use this file except in compliance with the License.
      5 # You may obtain a copy of the License at
      6 #
      7 #      http://www.apache.org/licenses/LICENSE-2.0
      8 #
      9 # Unless required by applicable law or agreed to in writing, software
     10 # distributed under the License is distributed on an 'AS IS' BASIS,
     11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     12 # See the License for the specific language governing permissions and
     13 # limitations under the License.
     14 
     15 source $ANDROID_BUILD_TOP/build/envsetup.sh >/dev/null
     16 
     17 root_dir=`realpath \`dirname $0\`/../../`
     18 
     19 if [ -z "$ANDROID_SERIAL" ]; then
     20   echo "Please set up ANDORID_SERAL enviroment variable"
     21   exit -1
     22 fi
     23 
     24 if [ -z "$1" ]; then
     25   echo "Usage runtest.sh test-name"
     26   exit -1;
     27 fi
     28 
     29 test_name=$1
     30 product_out=$(cd $ANDROID_BUILD_TOP;get_build_var PRODUCT_OUT 2>/dev/null)
     31 test_local=$product_out/data/nativetest/$test_name/$test_name
     32 test_target=/data/nativetest/$test_name/$test_name
     33 
     34 cd $root_dir
     35 adb push $test_local $test_target
     36 
     37 logfile_native=$test_name.stdout.log
     38 logfile_valgrind=$test_name.stdout.vlog
     39 
     40 # reference point
     41 echo "Creating reference point log (run without valgrind)..."
     42 adb shell $test_target > $logfile_native
     43 # valgrind run
     44 echo "Running test under valgrind..."
     45 adb shell valgrind $test_target > $logfile_valgrind
     46 
     47 echo "Checking results..."
     48 diff $logfile_native $logfile_valgrind | grep -v "^> ==" | grep -v -e "^[0-9]" > $test_name.diff.log
     49 
     50 if [ -s $test_name.diff.log ]; then
     51   echo "Test $test_name FAILED, please check the diff below"
     52   cat $test_name.diff.log | sed "s/^< /expected: /" | sed "s/^> /actual  : /"
     53   exit -2
     54 fi
     55 
     56 echo "Test $test_name PASSED"
     57 
     58