blob: ef9ec8b3a06b8c04c7414667bf034925010f1883 [file] [log] [blame]
#! /bin/bash
#
# Copyright (C) 2018 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.
# Push ART artifacts and its dependencies to a chroot directory for on-device testing.
set -e
. "$(dirname $0)/buildbot-utils.sh"
if [[ -z "$ART_TEST_ON_VM" ]]; then
# Setup as root, as some actions performed here require it.
adb root
adb wait-for-device
fi
if [[ -z "$ANDROID_BUILD_TOP" ]]; then
msgfatal 'ANDROID_BUILD_TOP environment variable is empty; did you forget to run `lunch`?'
elif [[ -z "$ANDROID_PRODUCT_OUT" ]]; then
msgfatal 'ANDROID_PRODUCT_OUT environment variable is empty; did you forget to run `lunch`?'
elif [[ -z "$ART_TEST_CHROOT" ]]; then
msgfatal 'ART_TEST_CHROOT environment variable is empty; ' \
'please set it before running this script.'
fi
# Sync relevant product directories
# ---------------------------------
(
cd $ANDROID_PRODUCT_OUT
for dir in system/* linkerconfig data; do
[ -d $dir ] || continue
if [ $dir == system/apex ]; then
# We sync the APEXes later.
continue
fi
msginfo "Syncing $dir directory..."
if [[ -n "$ART_TEST_ON_VM" ]]; then
$ART_RSYNC_CMD -R $dir "$ART_TEST_SSH_USER@$ART_TEST_SSH_HOST:$ART_TEST_CHROOT"
else
adb shell mkdir -p "$ART_TEST_CHROOT/$dir"
adb push $dir "$ART_TEST_CHROOT/$(dirname $dir)"
fi
done
)
# Overwrite the default public.libraries.txt file with a smaller one that
# contains only the public libraries pushed to the chroot directory.
if [[ -n "$ART_TEST_ON_VM" ]]; then
$ART_RSYNC_CMD "$ANDROID_BUILD_TOP/art/tools/public.libraries.buildbot.txt" \
"$ART_TEST_SSH_USER@$ART_TEST_SSH_HOST:$ART_TEST_CHROOT/system/etc/public.libraries.txt"
else
adb push "$ANDROID_BUILD_TOP/art/tools/public.libraries.buildbot.txt" \
"$ART_TEST_CHROOT/system/etc/public.libraries.txt"
fi
# Create the framework directory if it doesn't exist. Some gtests need it.
if [[ -n "$ART_TEST_ON_VM" ]]; then
$ART_SSH_CMD "$ART_CHROOT_CMD mkdir -p $ART_TEST_CHROOT/system/framework"
else
adb shell mkdir -p "$ART_TEST_CHROOT/system/framework"
fi
# APEX packages activation.
# -------------------------
if [[ -n "$ART_TEST_ON_VM" ]]; then
$ART_SSH_CMD "$ART_CHROOT_CMD mkdir -p $ART_TEST_CHROOT/apex"
else
adb shell mkdir -p "$ART_TEST_CHROOT/apex"
fi
# Manually "activate" the flattened APEX $1 by syncing it to /apex/$2 in the
# chroot. $2 defaults to $1.
activate_apex() {
local src_apex=${1}
local dst_apex=${2:-${src_apex}}
# Unpack the .apex or .capex file in the product directory, but if we already
# see a directory we assume buildbot-build.sh has already done it for us and
# just use it.
src_apex_path=$ANDROID_PRODUCT_OUT/system/apex/${src_apex}
if [ ! -d $src_apex_path ]; then
unset src_apex_file
if [ -f "${src_apex_path}.apex" ]; then
src_apex_file="${src_apex_path}.apex"
elif [ -f "${src_apex_path}.capex" ]; then
src_apex_file="${src_apex_path}.capex"
fi
if [ -z "${src_apex_file}" ]; then
msgerror "Failed to find .apex or .capex file to extract for ${src_apex_path}"
exit 1
fi
msginfo "Extracting APEX ${src_apex_file}..."
mkdir -p $src_apex_path
$ANDROID_HOST_OUT/bin/deapexer --debugfs_path $ANDROID_HOST_OUT/bin/debugfs_static \
--fsckerofs_path $ANDROID_HOST_OUT/bin/fsck.erofs \
--blkid_path $ANDROID_HOST_OUT/bin/blkid_static \
extract ${src_apex_file} $src_apex_path
fi
msginfo "Activating APEX ${src_apex} as ${dst_apex}..."
if [[ -n "$ART_TEST_ON_VM" ]]; then
$ART_RSYNC_CMD $src_apex_path/* \
"$ART_TEST_SSH_USER@$ART_TEST_SSH_HOST:$ART_TEST_CHROOT/apex/${dst_apex}"
else
adb shell rm -rf "$ART_TEST_CHROOT/apex/${dst_apex}"
adb push $src_apex_path "$ART_TEST_CHROOT/apex/${dst_apex}"
fi
}
# "Activate" the required APEX modules.
activate_apex com.android.art.testing com.android.art
activate_apex com.android.i18n
activate_apex com.android.runtime
activate_apex com.android.tzdata
activate_apex com.android.conscrypt
activate_apex com.android.os.statsd
if [[ "$TARGET_ARCH" = "riscv64" ]]; then
true # Skip boot image generation for RISC-V; it's not supported.
else
# Generate primary boot images on device for testing.
for b in {32,64}; do
basename="generate-boot-image$b"
bin_on_host="$ANDROID_PRODUCT_OUT/system/bin/$basename"
bin_on_device="/data/local/tmp/$basename"
output_dir="/system/framework/art_boot_images"
if [ -f $bin_on_host ]; then
msginfo "Generating the primary boot image ($b-bit)..."
if [[ -n "$ART_TEST_ON_VM" ]]; then
$ART_RSYNC_CMD "$bin_on_host" \
"$ART_TEST_SSH_USER@$ART_TEST_SSH_HOST:$ART_TEST_CHROOT$bin_on_device"
$ART_SSH_CMD "mkdir -p $ART_TEST_CHROOT$output_dir"
else
adb push "$bin_on_host" "$ART_TEST_CHROOT$bin_on_device"
adb shell mkdir -p "$ART_TEST_CHROOT$output_dir"
fi
# `compiler-filter=speed-profile` is required because OatDumpTest checks the compiled code in
# the boot image.
if [[ -n "$ART_TEST_ON_VM" ]]; then
$ART_SSH_CMD \
"$ART_CHROOT_CMD $bin_on_device --output-dir=$output_dir --compiler-filter=speed-profile"
else
adb shell chroot "$ART_TEST_CHROOT" \
"$bin_on_device" --output-dir=$output_dir --compiler-filter=speed-profile
fi
fi
done
fi