2
0
mirror of https://gitlab.com/Nanolx/NanoDroid synced 2024-11-16 00:12:46 +00:00
NanoDroid/systest/SysTest

395 lines
10 KiB
Plaintext
Raw Normal View History

2018-11-18 09:16:24 +00:00
#!/sbin/sh
##########################################################################################
#
# NanoDroid System Testing Script
# by Nanolx
#
##########################################################################################
2019-10-08 18:59:21 +00:00
VERSION=22.5.99999999
TMPDIR=/dev/tmp
LOGFILE="/data/media/0/nanodroid_logs/NanoDroid-SysTest-$(date +%Y%m%d-%H.%M.%S).log"
2018-11-18 09:16:24 +00:00
##########################################################################################
# Generic Functions
##########################################################################################
show_banner () {
ui_print " "
ui_print "*******************"
ui_print " NanoDroid SysTest "
ui_print " ${VERSION} "
ui_print "*******************"
ui_print " "
}
2018-11-18 09:16:24 +00:00
ui_print() {
${BOOTMODE} && echo "${1}" || \
echo -e "ui_print ${1}\nui_print" >> /proc/self/fd/${OUTFD}
2018-11-18 09:16:24 +00:00
}
is_mounted () {
if [ ! -z "$2" ]; then
cat /proc/mounts | grep $1 | grep $2, >/dev/null
else
cat /proc/mounts | grep $1 >/dev/null
fi
return $?
}
# taken from Magisk, with minor modifications for NanoDroid
mount_partitions () {
DEVICE_AB=FALSE
2018-12-28 21:24:12 +00:00
VENDOR_COMPAT=FALSE
2018-11-18 09:16:24 +00:00
2019-10-08 18:48:26 +00:00
SYSTEM_AS_ROOT=$(getprop ro.build.system_root_image)
SYSTEM_BLOCK=/dev/block/bootdevice/by-name/system
2018-11-18 09:16:24 +00:00
2019-10-08 18:48:26 +00:00
RUNTIME_APEX=""
APEX_LOOP=""
2019-10-08 18:48:26 +00:00
if [ "${SYSTEM_AS_ROOT}" == "true" ]; then
SLOT=$(grep_cmdline androidboot.slot_suffix)
if [ -n "${SLOT}" ]; then
DEVICE_AB=TRUE
SYSTEM_BLOCK=/dev/block/bootdevice/by-name/system${SLOT}
fi
SYSTEM_MOUNT=/system_root
else
SYSTEM_MOUNT=/system
2018-11-18 09:16:24 +00:00
fi
2019-10-08 18:48:26 +00:00
is_mounted /data || mount /data || error "failed to mount /data!"
mount -o bind /dev/urandom /dev/random
! is_mounted ${SYSTEM_MOUNT} && mount -o rw ${SYSTEM_BLOCK} ${SYSTEM_MOUNT} || mount -o rw,remount ${SYSTEM_MOUNT}
2019-05-11 19:46:10 +00:00
if [ -f /system/init.rc ]; then
2019-07-27 18:32:07 +00:00
[ -L /system_root ] && rm -f /system_root
2019-10-08 18:48:26 +00:00
mkdir -p /system_root 2>/dev/null
2018-11-18 09:16:24 +00:00
mount --move /system /system_root
mount -o bind /system_root/system /system
fi
[ ! -f /system/build.prop ] && error "failed to mount /system (unsupported A/B device?)"
2019-10-08 18:48:26 +00:00
if [ -f /system/apex/com.android.runtime.apex ]; then
RUNTIME_APEX="/system/apex/com.android.runtime.apex"
elif [ -f /system/apex/com.android.runtime.release.apex ]; then
RUNTIME_APEX="/system/apex/com.android.runtime.release.apex"
fi
if [ -n "${RUNTIME_APEX}" ]; then
mkdir -p /dev/tmp/apex
unzip "${RUNTIME_APEX}" -d /dev/tmp/apex
mkdir -p /apex/com.android.runtime
mount -oloop,ro /dev/tmp/apex/apex_payload.img /apex/com.android.runtime
APEX_LOOP=$(mount | awk '/com.android.runtime/{print $1}')
fi
! is_mounted /vendor && mount /vendor
2018-11-18 09:16:24 +00:00
if [ -L /system/vendor ]; then
if ! is_mounted /vendor; then
2019-10-08 18:48:26 +00:00
vendor_tmp=$(find /dev/block -type l -iname vendor${SLOT} | head -n 1)
VENDORBLOCK=$(readlink -f ${vendor_tmp})
2019-05-11 19:46:10 +00:00
mount -o ro ${VENDORBLOCK} /vendor
2018-11-18 09:16:24 +00:00
fi
elif [ -d /system/vendor ]; then
### XXX work-around required for some ROMs
2018-12-28 21:24:12 +00:00
VENDOR_COMPAT=TRUE
2019-10-08 18:48:26 +00:00
echo " xxx compat /vendor link created!"
2018-11-18 09:16:24 +00:00
ln -sf /system/vendor /vendor >/dev/null
fi
2019-10-08 18:48:26 +00:00
mount | awk '{print $1 " on " $3 " params: " $6}'
2018-11-18 09:16:24 +00:00
}
2019-10-08 18:48:26 +00:00
2018-11-18 09:16:24 +00:00
error () {
ui_print " "
ui_print " !! ${@}"
ui_print " "
exit 1
}
##########################################################################################
# check if ROM has native fake signature spoofing support
# by @ale5000
##########################################################################################
check_fake_package_signature () {
PERMISSION=android.permission.FAKE_PACKAGE_SIGNATURE
PERMISSION_OD=$(echo -n "${PERMISSION}" | od -A n -t x1 | tr -d '\n' | sed -e 's/^ //g;s/ /00/g')
HAS_FAKESIGN=false
FW_RES_DIR="${TMPDIR}/framework-res"
FW_RES_FILE="${FW_RES_DIR}/AndroidManifest.xml"
if [ ! -f ${FW_RES_FILE} ]; then
mkdir -p "${FW_RES_DIR}"
unzip -oq /system/framework/framework-res.apk -d "${FW_RES_DIR}"
fi
grep -qF "${PERMISSION}" "${FW_RES_FILE}" && HAS_FAKESIGN=true
od -A n -t x1 "${FW_RES_FILE}" | tr -d ' \n' | grep -qF "${PERMISSION_OD}" && HAS_FAKESIGN=true
${HAS_FAKESIGN} && return 0 || return 1
}
##########################################################################################
# check if Bromite System WebView is supported
##########################################################################################
check_bromite_webview_support () {
WEBVIEW_PKG="com.android.webview"
HAS_WEBVIEW=false
FW_RES_DIR="${TMPDIR}/framework-res"
FW_RES_FILE="${FW_RES_DIR}/res/xml/config_webview_packages.xml"
if [ ! -f ${FW_RES_FILE} ]; then
mkdir -p "${FW_RES_DIR}"
unzip -oq /system/framework/framework-res.apk -d "${FW_RES_DIR}"
fi
grep -qF "${WEBVIEW_PKG}" "${FW_RES_FILE}" && HAS_WEBVIEW=true
${HAS_WEBVIEW} && return 0 || return 1
}
2018-11-18 09:16:24 +00:00
##########################################################################################
# Device Functions
##########################################################################################
detect_outfd () {
if [ -z $OUTFD ] || readlink /proc/$$/fd/$OUTFD | grep -q /tmp; then
# We will have to manually find out OUTFD
for FD in `ls /proc/$$/fd`; do
if readlink /proc/$$/fd/$FD | grep -q pipe; then
if ps | grep -v grep | grep -q " 3 $FD "; then
OUTFD=$FD
break
fi
fi
done
fi
}
detect_bootmode () {
[ -z ${BOOTMODE} ] && BOOTMODE=false
${BOOTMODE} || ps | grep zygote | grep -qv grep && BOOTMODE=true
${BOOTMODE} || ps -A | grep zygote | grep -qv grep && BOOTMODE=true
}
grep_prop() {
[ -f /vendor/build.prop ] && \
FILES="/system/build.prop /vendor/build.prop" || \
FILES="/system/build.prop"
sed -n "s/^${1}=//p" ${FILES} | head -n 1
2018-11-18 09:16:24 +00:00
}
grep_cmdline() {
local REGEX="s/^${1}=//p"
sed -E 's/ +/\n/g' /proc/cmdline | \
sed -n "${REGEX}" 2>/dev/null
}
system_test () {
ABI=$(grep_prop ro.product.cpu.abi | cut -c-3)
ABI2=$(grep_prop ro.product.cpu.abi2 | cut -c-3)
ABILONG=$(grep_prop ro.product.cpu.abi)
ARCH=arm
[ "$ABI" = "x86" ] && ARCH=x86
[ "$ABI2" = "x86" ] && ARCH=x86
[ "$ABILONG" = "arm64-v8a" ] && ARCH=arm64
[ "$ABILONG" = "x86_64" ] && ARCH=x86_64
case ${ARCH} in
arm | arm64 )
BB=${TMPDIR}/busybox.arm
FILE=${TMPDIR}/file.arm
2018-11-18 09:16:24 +00:00
;;
x86 | x86_64 )
BB=${TMPDIR}/busybox.x86
FILE=${TMPDIR}/file.x86
2018-11-18 09:16:24 +00:00
;;
esac
OLD_PATH=${PATH}
mkdir -p ${TMPDIR}/busybox
2018-12-28 21:31:40 +00:00
ln -s ${BB} ${TMPDIR}/busybox/busybox
2018-12-28 21:31:40 +00:00
chmod 0755 ${BB}
${BB} --install -s ${TMPDIR}/busybox/
export PATH="${TMPDIR}/busybox:${PATH}"
2018-11-18 09:16:24 +00:00
chmod 0755 "${FILE}"
DALVIKVM_BIN=$(ls -l /system/bin/dalvikvm | awk '{print $NF}')
DALVIKVM_ARCH=$("${FILE}" -m "${TMPDIR}/magic.mgc" -L /system/bin/dalvikvm)
2018-11-18 09:16:24 +00:00
case ${DALVIKVM_BIN} in
dalvikvm32 )
LD="/system/lib:/vendor/lib:/system/vendor/lib"
;;
dalvikvm64 )
LD="/system/lib64:/vendor/lib64:/system/vendor/lib64"
;;
2018-11-18 09:16:24 +00:00
dalvikvm )
case ${DALVIKVM_ARCH} in
*32-bit* )
LD="/system/lib:/vendor/lib:/system/vendor/lib"
;;
*64-bit* )
LD="/system/lib64:/vendor/lib64:/system/vendor/lib64"
;;
esac
;;
esac
SERVICES_JAR_DEX=$(unzip -lq /system/framework/services.jar | grep classes.dex)
if [ -n "$(find '/system/framework/' -name 'services.vdex')" ]; then
ROM_DEX_STATUS=VDEX
elif [ -n "$(find '/system/framework/' -name 'services.odex')" ]; then
ROM_DEX_STATUS=ODEX
else ROM_DEX_STATUS=UNKOWN
fi
[ "${SERVICES_JAR_DEX}" ] && ROM_DEX_STATUS=DEODEX
2018-11-19 17:49:25 +00:00
}
2018-11-18 09:16:24 +00:00
2018-11-19 17:49:25 +00:00
add_log () {
echo "${@}" >> ${LOGFILE}
}
2018-11-18 09:16:24 +00:00
2018-11-19 17:49:25 +00:00
store_results () {
2019-05-13 17:51:25 +00:00
mkdir -p "$(dirname "${LOGFILE}")"
2018-11-19 17:49:25 +00:00
add_log "NanoDroid System Test Results"
add_log "============================="
add_log ""
add_log "CPU and ABI details"
add_log "==================="
add_log ""
add_log "ARCH=${ARCH}"
add_log "ABI=${ABI}"
add_log "ABI2=${ABI2}"
add_log "ABILONG=${ABILONG}"
add_log ""
add_log "Mounted Partitions"
add_log "=================="
add_log ""
add_log "DEVICE_AB=${DEVICE_AB}"
2018-12-28 21:24:12 +00:00
add_log "VENDOR_COMPAT=${VENDOR_COMPAT}"
add_log "SYSTEM_AS_ROOT=${SYSTEM_AS_ROOT}"
add_log "SYSTEMBLOCK=${SYSTEMBLOCK}"
add_log "VENDORBLOCK=${VENDORBLOCK}"
2018-12-28 21:25:39 +00:00
add_log ""
mount | sed '/magisk/d' | awk '{print $1 " on " $3 " params: " $6}' >> ${LOGFILE}
2018-11-19 17:49:25 +00:00
if [ ! ${BOOTMODE} ]; then
add_log ""
add_log "TWRP usuable space for Installer"
add_log "================================"
add_log ""
add_log $(df /dev 2>/dev/null | awk '/tmpfs/{print $4}')
fi
2018-11-19 17:49:25 +00:00
add_log ""
add_log "DalvikVM, LD_LIBRARY_PATH and DEX status"
add_log "========================================"
add_log ""
add_log "DALVIKVM_BIN=${DALVIKVM_BIN}"
add_log "DALVIKVM_ARCH=${DALVIKVM_ARCH}"
2018-11-19 18:00:49 +00:00
add_log "LD_LIBRARY_PATH=${LD}"
2018-11-19 17:49:25 +00:00
add_log "ROM_DEX_STATUS=${ROM_DEX_STATUS}"
2019-10-08 18:48:26 +00:00
add_log "RUNTIME_APEX=${RUNTIME_APEX}"
2018-11-19 17:49:25 +00:00
add_log ""
add_log "Generic System Properties"
add_log "========================="
add_log ""
2018-11-18 09:16:24 +00:00
for prop in ro.build.description ro.build.display.id ro.build.flavor ro.build.product \
ro.build.tags ro.build.type ro.build.version.sdk ro.build.version.security_patch \
ro.product.cpu.abi ro.product.cpu.abilist ro.product.cpu.abilist32 \
ro.product.cpu.abilist64 ro.product.model ro.product.vendor.device; do
2018-11-19 17:49:25 +00:00
add_log "${prop}=$(grep_prop ${prop})"
2018-11-18 09:16:24 +00:00
done
add_log ""
2019-06-13 18:15:40 +00:00
add_log "Native Signature Spoofing support"
add_log "================================="
add_log ""
check_fake_package_signature && add_log "NATIVE_SIGSPOOF=TRUE" || add_log "NATIVE_SIGSPOOF=FALSE"
add_log ""
2019-06-13 19:30:43 +00:00
add_log "Bromite System WebView support"
add_log "=============================="
add_log ""
check_bromite_webview_support && add_log "WEBVIEW_SUPPORT=TRUE" || add_log "WEBVIEW_SUPPORT=FALSE"
2018-11-19 17:49:25 +00:00
add_log ""
2019-06-13 19:30:43 +00:00
add_log "Magisk installation status"
add_log "=========================="
2018-11-19 17:49:25 +00:00
add_log ""
if [ -f /data/adb/magisk/util_functions.sh ]; then
add_log "MAGISK=TRUE"
. /data/adb/magisk/util_functions.sh
add_log "MAGISK_VERSION=${MAGISK_VER_CODE}"
if [ ${MAGISK_VER_CODE} -gt 18100 ]; then
add_log "MAGISK_IMAGELESS=TRUE"
else add_log "MAGISK_IMAGELESS=FALSE"
fi
else
add_log "MAGISK=FALSE"
add_Log "MAGISK_VERSION=NONE"
add_log "MAGISK_IMAGELESS=FALSE"
fi
2018-11-18 09:16:24 +00:00
2018-11-19 17:49:25 +00:00
add_log ""
add_log "Installed Google packages"
add_log "=== packages.list ======="
add_log ""
grep google /data/system/packages.list | sort >> ${LOGFILE}
2018-11-19 17:49:25 +00:00
add_log ""
add_log "=== packages.xml ========"
add_log ""
grep 'package .*google' /data/system/packages.xml | sort >> ${LOGFILE}
2018-11-18 09:16:24 +00:00
2018-11-19 17:49:25 +00:00
add_log ""
add_log "Content of /system/app"
add_log "======================"
add_log ""
find /system/app -type f -name '*.apk' | sort >> ${LOGFILE}
2018-11-19 17:49:25 +00:00
add_log ""
add_log "Content of /system/priv-app"
2019-06-16 17:07:19 +00:00
add_log "==========================="
2018-11-19 17:49:25 +00:00
add_log ""
find /system/priv-app -type f -name '*.apk' | sort >> ${LOGFILE}
2018-12-28 21:33:06 +00:00
2019-05-11 19:59:04 +00:00
chown root:sdcard_rw ${LOGFILE}
chmod 0644 ${LOGFILE}
2018-12-28 21:33:06 +00:00
export PATH=${OLD_PATH}
2018-11-18 09:16:24 +00:00
}