Magisk/scripts/cuttlefish.sh

121 lines
3.0 KiB
Bash
Raw Normal View History

2024-07-20 03:10:18 -07:00
#!/usr/bin/env bash
set -xe
. scripts/test_common.sh
2024-07-22 03:39:04 -07:00
cvd_args="-daemon -enable_sandbox=false -memory_mb=8192 -report_anonymous_usage_stats=n -cpus=$core_count"
2024-07-20 03:10:18 -07:00
magisk_args='-init_boot_image=magisk_patched.img'
cleanup() {
print_error "! An error occurred"
run_cvd_bin stop_cvd || true
rm -f magisk_patched.img*
}
run_cvd_bin() {
local exe=$1
shift
HOME=$CF_HOME $CF_HOME/bin/$exe "$@"
}
setup_env() {
2024-08-16 15:58:21 -07:00
curl -LO https://github.com/topjohnwu/magisk-files/releases/download/files/cuttlefish-base_0.9.30_amd64.deb
2024-07-22 03:39:04 -07:00
sudo dpkg -i ./cuttlefish-base_*_*64.deb || sudo apt-get install -f
rm cuttlefish-base_*_*64.deb
2024-07-20 03:10:18 -07:00
echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules
sudo udevadm control --reload-rules
sudo udevadm trigger
sudo usermod -aG kvm,cvdnetwork,render $USER
yes | "$sdk" --licenses > /dev/null
2024-12-23 19:49:21 -08:00
"$sdk" --channel=3 platform-tools
adb kill-server
adb start-server
2024-07-20 03:10:18 -07:00
}
download_cf() {
2024-07-22 03:39:04 -07:00
local branch=$1
2024-08-15 22:51:40 -07:00
local device=$2
2024-07-22 03:39:04 -07:00
if [ -z $branch ]; then
branch='aosp-main'
fi
2024-08-15 22:51:40 -07:00
if [ -z $device ]; then
device='aosp_cf_x86_64_phone'
2024-07-22 03:39:04 -07:00
fi
2024-08-15 22:51:40 -07:00
local target="${device}-trunk_staging-userdebug"
2024-07-22 03:39:04 -07:00
local build_id=$(curl -sL https://ci.android.com/builds/branches/${branch}/status.json | \
jq -r ".targets[] | select(.name == \"$target\") | .last_known_good_build")
local sys_img_url="https://ci.android.com/builds/submitted/${build_id}/${target}/latest/raw/${device}-img-${build_id}.zip"
local host_pkg_url="https://ci.android.com/builds/submitted/${build_id}/${target}/latest/raw/cvd-host_package.tar.gz"
2024-08-15 22:51:40 -07:00
print_title "* Download $target ($build_id) images"
2024-07-22 03:39:04 -07:00
curl -L $sys_img_url -o aosp_cf_phone-img.zip
2024-07-20 03:10:18 -07:00
curl -LO $host_pkg_url
rm -rf $CF_HOME
mkdir -p $CF_HOME
tar xvf cvd-host_package.tar.gz -C $CF_HOME
2024-07-22 03:39:04 -07:00
unzip aosp_cf_phone-img.zip -d $CF_HOME
rm -f cvd-host_package.tar.gz aosp_cf_phone-img.zip
2024-07-20 03:10:18 -07:00
}
test_cf() {
local variant=$1
run_cvd_bin stop_cvd || true
print_title "* Testing $variant builds"
timeout $boot_timeout bash -c "run_cvd_bin launch_cvd $cvd_args $magisk_args -resume=false"
adb wait-for-device
2024-12-20 01:55:22 -08:00
run_setup $variant
2024-07-20 03:10:18 -07:00
adb reboot
sleep 5
run_cvd_bin stop_cvd || true
timeout $boot_timeout bash -c "run_cvd_bin launch_cvd $cvd_args $magisk_args"
adb wait-for-device
2024-12-20 01:55:22 -08:00
run_tests
2024-07-20 03:10:18 -07:00
}
2024-12-20 01:55:22 -08:00
test_main() {
2024-07-20 03:10:18 -07:00
# Launch stock cuttlefish
run_cvd_bin launch_cvd $cvd_args -resume=false
adb wait-for-device
# Patch and test debug build
./build.py avd_patch -s "$CF_HOME/init_boot.img" magisk_patched.img
test_cf debug
# Patch and test release build
./build.py -r avd_patch -s "$CF_HOME/init_boot.img" magisk_patched.img
test_cf release
# Cleanup
run_cvd_bin stop_cvd || true
rm -f magisk_patched.img*
}
if [ -z $CF_HOME ]; then
print_error "! Environment variable CF_HOME is required"
exit 1
fi
case "$1" in
setup )
setup_env
;;
download )
2024-07-22 03:39:04 -07:00
download_cf $2 $3
2024-07-20 03:10:18 -07:00
;;
test )
trap cleanup EXIT
export -f run_cvd_bin
2024-12-20 01:55:22 -08:00
test_main
2024-07-20 03:10:18 -07:00
trap - EXIT
;;
* )
exit 1
;;
esac