You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

164 lines
6.1 KiB

#!/bin/sh
#
# Copyright 2005-2013 Intel Corporation. All Rights Reserved.
#
# This file is part of Threading Building Blocks.
#
# Threading Building Blocks is free software; you can redistribute it
# and/or modify it under the terms of the GNU General Public License
# version 2 as published by the Free Software Foundation.
#
# Threading Building Blocks is distributed in the hope that it will be
# useful, but WITHOUT ANY WARRANTY; without even the implied warranty
# of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Threading Building Blocks; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
#
# As a special exception, you may use this file as part of a free software
# library without restriction. Specifically, if other files instantiate
# templates or use macros or inline functions from this file, or you compile
# this file and link it with other files to produce an executable, this
# file does not by itself cause the resulting executable to be covered by
# the GNU General Public License. This exception does not however
# invalidate any other reasons why the executable file might be covered by
# the GNU General Public License.
# Usage:
# android.linux.launcher.sh [-v] [-u] [-l <library>] <executable> <arg1> <arg2> <argN>
# where: -l <library> specfies the library name to be assigned to LD_PRELOAD
# where: -v enables verbose output when running the test (where supported)
# where: -u is ignored on Android
#
# Libs and executable necessary for testing should be present in the current directory before running.
# ANDROID_SERIAL must be set to the connected Android target device name for file transfer and test runs.
# ANDROID_TEST_DIRECTORY may be set to the directory used for testing on the Android target device; otherwise,
# the default directory used is "/data/local/tmp/$(basename $PWD)".
# Note: Do not remove the redirections to '/dev/null' in the script, otherwise the nightly test system will fail.
do_cleanup()
{
adb pull $targetdir/events.txt events.txt > /dev/null 2>&1
# Remove target directory on the device
adb shell "rm -r ${targetdir}; mkdir -p ${targetdir}" > /dev/null 2>&1
}
do_trap_cleanup()
{
do_cleanup
exit -1
}
# Process the optional arguments if present
if [ "x$1" = "x-v" ]; then {
verb="$1"
shift 1
}; fi
if [ "x$1" = "x-u" ]; then {
shift 1
}; fi
if [ "x$1" = "x-l" ]; then {
ldpreload="$2"
shift 2
}; fi
# Collect the executable name
exename=$(basename $1)
shift
# Prepare the target directory on the device
currentdir=$(basename $PWD)
targetdir=${ANDROID_TEST_DIRECTORY:-/data/local/tmp/$currentdir}
do_cleanup
trap do_trap_cleanup INT # if someone hits control-c, cleanup the device
# Collect the list of files to transfer to the target device, starting with executable itself.
fnamelist="$exename"
# Add the C++ standard library from the NDK, which is required for all tests on Android.
if [ ! -z "${LIB_GNU_STL_ANDROID}" ]; then
fnamelist="$fnamelist ${LIB_GNU_STL_ANDROID}/libgnustl_shared.so"
else
fnamelist="$fnamelist libgnustl_shared.so"
fi
# Find the TBB libraries and add them to the list.
# Add TBB libraries from the current directory that contains libtbb* files
files="$(/bin/ls libtbb* 2> /dev/null)"
if [ ! -z "$files" ]; then fnamelist="$fnamelist $files"; fi
mallocfiles="$(/bin/ls libtbbmalloc* 2> /dev/null)"
if [ ! -z "$mallocfiles" ]; then {
#TODO: any better workaround instead calling echo
#(without echo there is error: /system/bin/sh: libtbbmalloc_proxy.so: not found)
ldpreload="$ldpreload $(echo $mallocfiles)"
}; fi
if [ ! -z "$ldpreload" ]; then ldpreload="export LD_PRELOAD=$ldpreload;"; fi
# Add any libraries built for specific tests.
exeroot=${exename%\.*}
files="$(/bin/ls ${exeroot}*.so ${exeroot}*.so.* 2> /dev/null)"
if [ ! -z "$files" ]; then {
fnamelist="$fnamelist $files"
}; fi
# TODO: Add extra libraries from the Intel(R) Compiler for certain tests
# found=$(echo $exename | egrep 'test_malloc_atexit\|test_malloc_lib_unload' 2> /dev/null)
# if [ ! -z $found ] ; then
# fnamelist="$fnamelist ${compiler_path_lib}/libimf.so \
# ${compiler_path_lib}/libsvml.so \
# ${compiler_path_lib}/libintlc.so.5"
# fi
# Transfer collected executable and library files to the target device.
transfers_ok=1
for fullname in $fnamelist; do {
if [ -r $fullname ]; then {
# Transfer the executable and libraries to top-level target directory
adb push $fullname ${targetdir}/$(basename $fullname) > /dev/null 2>&1
}; else {
echo "Error: required file ${currentdir}/${fullname} for test $exename not available for transfer."
transfers_ok=0
}; fi
}; done
if [ "${transfers_ok}" = "0" ]; then {
do_cleanup
exit -1
}; fi
# Transfer input files used by example codes by scanning the executable argument list.
for fullname in "$@"; do {
if [ -r $fullname ]; then {
directory=$(dirname $fullname)
filename=$(basename $fullname)
# strip leading "." from fullname if present
if [ "$directory" = "\." ]; then {
directory=""
fullname=$filename
}; fi
# Create the target directory to hold input file if necessary
if [ ! -z $directory ]; then {
adb shell "mkdir $directory" > /dev/null 2>&1
}; fi
# Transfer the input file to corresponding directory on target device
adb push $fullname ${targetdir}/$fullname > /dev/null 2>&1
}; fi
}; done
# The return_code file is the best way found to return the status of the test execution when using adb shell.
(adb shell "cd $targetdir; $ldpreload export LD_LIBRARY_PATH=.; ./$exename $verb $*; echo \$? > return_code") | sed -e "s/\\r$//"
# Capture the return code string and remove the trailing \r from the return_code file contents
exitcode=`(adb shell "cat $targetdir/return_code 2> /dev/null") | sed -e "s/\\r$//"`
do_cleanup
# Return the exit code of the test.
exit $exitcode