1*c8dee2aaSAndroid Build Coastguard WorkerSkQP 2*c8dee2aaSAndroid Build Coastguard Worker==== 3*c8dee2aaSAndroid Build Coastguard Worker 4*c8dee2aaSAndroid Build Coastguard WorkerSkQP (Skia Quality Program) is a component of the Android CTS (Compatablity 5*c8dee2aaSAndroid Build Coastguard WorkerTest Suite) that tests an Android device's GPU and OpenGLES & Vulkan drivers 6*c8dee2aaSAndroid Build Coastguard Workerusing Skia's existing unit & rendering tests. 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard WorkerSee https://skia.org/dev/testing/skqp for pre-build APKs. 9*c8dee2aaSAndroid Build Coastguard Worker 10*c8dee2aaSAndroid Build Coastguard WorkerHow to build and run the SkQP tests 11*c8dee2aaSAndroid Build Coastguard Worker----------------------------------- 12*c8dee2aaSAndroid Build Coastguard Worker 13*c8dee2aaSAndroid Build Coastguard Worker1. Get the dependencies: 14*c8dee2aaSAndroid Build Coastguard Worker 15*c8dee2aaSAndroid Build Coastguard Worker - You will need Java JDK 8, `git`, and `python`. 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker - 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`. 18*c8dee2aaSAndroid Build Coastguard Worker 19*c8dee2aaSAndroid Build Coastguard Worker git clone 'https://chromium.googlesource.com/chromium/tools/depot_tools.git' 20*c8dee2aaSAndroid Build Coastguard Worker export PATH="${PWD}/depot_tools:${PATH}" 21*c8dee2aaSAndroid Build Coastguard Worker 22*c8dee2aaSAndroid Build Coastguard Worker - Install the [Android NDK](https://developer.android.com/ndk/downloads/). 23*c8dee2aaSAndroid Build Coastguard Worker 24*c8dee2aaSAndroid Build Coastguard Worker ( cd ~; unzip ~/Downloads/android-ndk-*.zip ) 25*c8dee2aaSAndroid Build Coastguard Worker ANDROID_NDK_HOME=$(ls -d ~/android-ndk-*) # Or wherever you installed the Android NDK. 26*c8dee2aaSAndroid Build Coastguard Worker 27*c8dee2aaSAndroid Build Coastguard Worker - Install the [Android SDK](https://developer.android.com/studio/#command-tools). 28*c8dee2aaSAndroid Build Coastguard Worker Set the `ANDROID_HOME` environment variable. 29*c8dee2aaSAndroid Build Coastguard Worker 30*c8dee2aaSAndroid Build Coastguard Worker mkdir ~/android-sdk 31*c8dee2aaSAndroid Build Coastguard Worker ( cd ~/android-sdk; unzip ~/Downloads/sdk-tools-*.zip ) 32*c8dee2aaSAndroid Build Coastguard Worker yes | ~/android-sdk/tools/bin/sdkmanager --licenses 33*c8dee2aaSAndroid Build Coastguard Worker export ANDROID_HOME=~/android-sdk # Or wherever you installed the Android SDK. 34*c8dee2aaSAndroid Build Coastguard Worker 35*c8dee2aaSAndroid Build Coastguard Worker Put `adb` in your `PATH`. 36*c8dee2aaSAndroid Build Coastguard Worker 37*c8dee2aaSAndroid Build Coastguard Worker export PATH="${PATH}:${ANDROID_HOME}/platform-tools" 38*c8dee2aaSAndroid Build Coastguard Worker 39*c8dee2aaSAndroid Build Coastguard Worker2. Get the right version of Skia: 40*c8dee2aaSAndroid Build Coastguard Worker 41*c8dee2aaSAndroid Build Coastguard Worker git clone https://skia.googlesource.com/skia.git 42*c8dee2aaSAndroid Build Coastguard Worker cd skia 43*c8dee2aaSAndroid Build Coastguard Worker git checkout origin/skqp/dev # or whatever release tag you need 44*c8dee2aaSAndroid Build Coastguard Worker 45*c8dee2aaSAndroid Build Coastguard Worker3. Build the APK: 46*c8dee2aaSAndroid Build Coastguard Worker 47*c8dee2aaSAndroid Build Coastguard Worker tools/git-sync-deps 48*c8dee2aaSAndroid Build Coastguard Worker tools/skqp/make_universal_apk 49*c8dee2aaSAndroid Build Coastguard Worker 50*c8dee2aaSAndroid Build Coastguard Worker4. Build, install, and run. 51*c8dee2aaSAndroid Build Coastguard Worker 52*c8dee2aaSAndroid Build Coastguard Worker adb install -r out/skqp/skqp-universal-debug.apk 53*c8dee2aaSAndroid Build Coastguard Worker adb logcat -c 54*c8dee2aaSAndroid Build Coastguard Worker adb shell am instrument -w org.skia.skqp 55*c8dee2aaSAndroid Build Coastguard Worker 56*c8dee2aaSAndroid Build Coastguard Worker5. Monitor the output with: 57*c8dee2aaSAndroid Build Coastguard Worker 58*c8dee2aaSAndroid Build Coastguard Worker adb logcat TestRunner org.skia.skqp skia "*:S" 59*c8dee2aaSAndroid Build Coastguard Worker 60*c8dee2aaSAndroid Build Coastguard Worker Note the test's output path on the device. It will look something like this: 61*c8dee2aaSAndroid Build Coastguard Worker 62*c8dee2aaSAndroid Build Coastguard Worker 01-23 15:22:12.688 27158 27173 I org.skia.skqp: 63*c8dee2aaSAndroid Build Coastguard Worker output written to "/storage/emulated/0/Android/data/org.skia.skqp/files/output" 64*c8dee2aaSAndroid Build Coastguard Worker 65*c8dee2aaSAndroid Build Coastguard Worker6. Retrieve and view the report with: 66*c8dee2aaSAndroid Build Coastguard Worker 67*c8dee2aaSAndroid Build Coastguard Worker OUTPUT_LOCATION="/storage/emulated/0/Android/data/org.skia.skqp/files/output" 68*c8dee2aaSAndroid Build Coastguard Worker adb pull $OUTPUT_LOCATION /tmp/ 69*c8dee2aaSAndroid Build Coastguard Worker bin/sysopen /tmp/output/skqp_report/report.html 70*c8dee2aaSAndroid Build Coastguard Worker 71*c8dee2aaSAndroid Build Coastguard WorkerRunning a single test 72*c8dee2aaSAndroid Build Coastguard Worker--------------------- 73*c8dee2aaSAndroid Build Coastguard Worker 74*c8dee2aaSAndroid Build Coastguard WorkerTo run a single test, for example `gles_aarectmodes`: 75*c8dee2aaSAndroid Build Coastguard Worker 76*c8dee2aaSAndroid Build Coastguard Worker adb shell am instrument -e class 'org.skia.skqp.SkQPRunner#gles_aarectmodes' -w org.skia.skqp 77*c8dee2aaSAndroid Build Coastguard Worker 78*c8dee2aaSAndroid Build Coastguard WorkerUnit tests can be run with the `unitTest_` prefix: 79*c8dee2aaSAndroid Build Coastguard Worker 80*c8dee2aaSAndroid Build Coastguard Worker adb shell am instrument -e class 'org.skia.skqp.SkQPRunner#unitTest_GrSurface -w org.skia.skqp 81*c8dee2aaSAndroid Build Coastguard Worker 82*c8dee2aaSAndroid Build Coastguard WorkerRun as a non-APK executable 83*c8dee2aaSAndroid Build Coastguard Worker--------------------------- 84*c8dee2aaSAndroid Build Coastguard Worker 85*c8dee2aaSAndroid Build Coastguard Worker1. Follow steps 1-3 as above. 86*c8dee2aaSAndroid Build Coastguard Worker 87*c8dee2aaSAndroid Build Coastguard Worker2. Build the SkQP program, load files on the device, and run skqp: 88*c8dee2aaSAndroid Build Coastguard Worker 89*c8dee2aaSAndroid Build Coastguard Worker ninja -C out/skqp/arm skqp 90*c8dee2aaSAndroid Build Coastguard Worker python tools/skqp/run_skqp_exe out/skqp/arm 91