60 lines
2 KiB
Bash
Executable file
60 lines
2 KiB
Bash
Executable file
# Copyright (C) 2014 The Android Open Source Project
|
|
#
|
|
# 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.
|
|
|
|
source $ANDROID_BUILD_TOP/build/envsetup.sh >/dev/null
|
|
|
|
root_dir=`realpath \`dirname $0\`/../../`
|
|
|
|
if [ -z "$ANDROID_SERIAL" ]; then
|
|
echo "Please set up ANDORID_SERAL enviroment variable"
|
|
exit -1
|
|
fi
|
|
|
|
if [ -z "$1" ]; then
|
|
echo "Usage runtest.sh test-name [64]"
|
|
exit -1;
|
|
fi
|
|
|
|
test_name=$1
|
|
product_out=$(cd $ANDROID_BUILD_TOP;get_build_var PRODUCT_OUT 2>/dev/null)
|
|
test_local=$product_out/data/nativetest$2/$test_name/$test_name
|
|
test_target=/data/nativetest$2/$test_name/$test_name
|
|
|
|
cd $root_dir
|
|
adb push $test_local $test_target
|
|
|
|
logfile_native=$test_name.stdout.log
|
|
logfile_valgrind=$test_name.stdout.vlog
|
|
|
|
# reference point
|
|
echo "Creating reference point log (run without valgrind)..."
|
|
adb shell $test_target > $logfile_native
|
|
# valgrind run
|
|
echo "Running test under valgrind..."
|
|
adb shell valgrind $test_target > $logfile_valgrind
|
|
|
|
echo "Checking results..."
|
|
dos2unix $logfile_native
|
|
dos2unix $logfile_valgrind
|
|
# TODO: remove last 3 grep -v; they are added to work around linker warning about unsupported DT_FLAGS_1
|
|
diff $logfile_native $logfile_valgrind | grep -v "^> ==" | grep -v -e "^[0-9]" | grep -v "WARNING: linker: Unsupported flags" | grep -v "^> $" | grep -v "^> 0x421==" > $test_name.diff.log
|
|
|
|
if [ -s $test_name.diff.log ]; then
|
|
echo "Test $test_name FAILED, please check the diff below"
|
|
cat $test_name.diff.log | sed "s/^< /expected: /" | sed "s/^> /actual : /"
|
|
exit -2
|
|
fi
|
|
|
|
echo "Test $test_name PASSED"
|
|
|