65a4178ff7
PLEASE NOTE: Instructions for running a single test have changed! No-Try: true Change-Id: I1923240e879daa7ff0556737ddd5aa3f58e0097c Reviewed-on: https://skia-review.googlesource.com/109566 Commit-Queue: Hal Canary <halcanary@google.com> Reviewed-by: Derek Sollenberger <djsollen@google.com>
105 lines
3.5 KiB
Markdown
105 lines
3.5 KiB
Markdown
SkQP
|
|
====
|
|
|
|
SkQP (Skia Quality Program) is a component of the Android CTS (Compatablity
|
|
Test Suite) that tests an Android device's GPU and OpenGLES & Vulkan drivers
|
|
using Skia's existing unit & rendering tests.
|
|
|
|
See https://skia.org/dev/testing/skqp for pre-build APKs.
|
|
|
|
How to build and run the SkQP tests
|
|
-----------------------------------
|
|
|
|
1. Get the dependencies:
|
|
|
|
- You will need Java JDK 8, `git`, and `python`.
|
|
|
|
- Install Chromium's [depot\_tools](http://commondatastorage.googleapis.com/chrome-infra-docs/flat/depot_tools/docs/html/depot_tools_tutorial.html). Add it to your `PATH`.
|
|
|
|
git clone 'https://chromium.googlesource.com/chromium/tools/depot_tools.git'
|
|
export PATH="${PWD}/depot_tools:${PATH}"
|
|
|
|
- Install the [Android NDK](https://developer.android.com/ndk/downloads/).
|
|
|
|
( cd ~; unzip ~/Downloads/android-ndk-*.zip )
|
|
ANDROID_NDK=$(ls -d ~/android-ndk-*) # Or wherever you installed the Android NDK.
|
|
|
|
- Install the [Android SDK](https://developer.android.com/studio/#command-tools).
|
|
Set the `ANDROID_HOME` environment variable.
|
|
|
|
mkdir ~/android-sdk
|
|
( cd ~/android-sdk; unzip ~/Downloads/sdk-tools-*.zip )
|
|
yes | ~/android-sdk/tools/bin/sdkmanager --licenses
|
|
export ANDROID_HOME=~/android-sdk # Or wherever you installed the Android SDK.
|
|
|
|
Put `adb` in your `PATH`.
|
|
|
|
export PATH="${PATH}:${ANDROID_HOME}/platform-tools"
|
|
|
|
2. Get the right version of Skia:
|
|
|
|
git clone https://skia.googlesource.com/skia.git
|
|
cd skia
|
|
git checkout origin/skqp/dev # or whatever release tag you need
|
|
|
|
3. Download dependencies and the model:
|
|
|
|
python tools/skqp/download_model
|
|
python tools/skqp/setup_resources
|
|
python tools/git-sync-deps
|
|
|
|
4. Configure the build:
|
|
|
|
python tools/skqp/generate_gn_args out/skqp-arm "$ANDROID_NDK" \
|
|
--arch arm \
|
|
--api_level 26
|
|
bin/gn gen out/skqp-arm
|
|
|
|
If you want to test another architecture, replace `arm` with `x86`, `x64`
|
|
or `arm64`. Run 'python tools/skqp/generate_gn_args -h' for
|
|
all options.
|
|
|
|
5. Build, install, and run.
|
|
|
|
platform_tools/android/bin/android_build_app -C out/skqp-arm skqp
|
|
adb install -r out/skqp-arm/skqp.apk
|
|
adb logcat -c
|
|
adb shell am instrument -w org.skia.skqp
|
|
|
|
6. Monitor the output with:
|
|
|
|
adb logcat org.skia.skqp skia "*:S"
|
|
|
|
Note the test's output path on the device. It will look something like this:
|
|
|
|
01-23 15:22:12.688 27158 27173 I org.skia.skqp:
|
|
output written to "/storage/emulated/0/Android/data/org.skia.skqp/files/output"
|
|
|
|
7. Retrieve and view the report with:
|
|
|
|
OUTPUT_LOCATION="/storage/emulated/0/Android/data/org.skia.skqp/files/output"
|
|
adb pull $OUTPUT_LOCATION /tmp/
|
|
tools/skqp/sysopen.py /tmp/output/skqp_report/report.html
|
|
|
|
Running a single test
|
|
---------------------
|
|
|
|
To run a single test, for example `gles/aarectmodes`:
|
|
|
|
adb shell am instrument -e class 'org.skia.skqp.SkQPRunner#gles/aarectmodes' -w org.skia.skqp
|
|
|
|
Unit tests can be run with the `unitTest/` prefix:
|
|
|
|
adb shell am instrument -e class 'org.skia.skqp.SkQPRunner#unitTest/GrSurface -w org.skia.skqp
|
|
|
|
Run as a non-APK executable
|
|
---------------------------
|
|
|
|
1. Follow steps 1-3 as above.
|
|
|
|
2. Build the SkQP program, load files on the device, and run skqp:
|
|
|
|
ninja -C out/skqp-arm skqp
|
|
python tools/skqp/run_skqp_exe out/skqp-arm
|
|
|