Home | History | Annotate | Download | only in skqp
      1 SkQP
      2 ====
      3 
      4 SkQP (Skia Quality Program) is a component of the Android CTS (Compatablity
      5 Test Suite) that tests an Android device's GPU and OpenGLES & Vulkan drivers
      6 using Skia's existing unit & rendering tests.
      7 
      8 See https://skia.org/dev/testing/skqp for pre-build APKs.
      9 
     10 How to build and run the SkQP tests
     11 -----------------------------------
     12 
     13 1.  Get the dependencies:
     14 
     15     -   You will need Java JDK 8, `git`, and `python`.
     16 
     17     -   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 
     19             git clone 'https://chromium.googlesource.com/chromium/tools/depot_tools.git'
     20             export PATH="${PWD}/depot_tools:${PATH}"
     21 
     22     -   Install the [Android NDK](https://developer.android.com/ndk/downloads/).
     23 
     24             ( cd ~; unzip ~/Downloads/android-ndk-*.zip )
     25             ANDROID_NDK=$(ls -d ~/android-ndk-*)   # Or wherever you installed the Android NDK.
     26 
     27     -   Install the [Android SDK](https://developer.android.com/studio/#command-tools).
     28         Set the `ANDROID_HOME` environment variable.
     29 
     30             mkdir ~/android-sdk
     31             ( cd ~/android-sdk; unzip ~/Downloads/sdk-tools-*.zip )
     32             yes | ~/android-sdk/tools/bin/sdkmanager --licenses
     33             export ANDROID_HOME=~/android-sdk  # Or wherever you installed the Android SDK.
     34 
     35         Put `adb` in your `PATH`.
     36 
     37             export PATH="${PATH}:${ANDROID_HOME}/platform-tools"
     38 
     39 2.  Get the right version of Skia:
     40 
     41         git clone https://skia.googlesource.com/skia.git
     42         cd skia
     43         git checkout origin/skqp/dev  # or whatever release tag you need
     44 
     45 3.  Download dependencies and the model:
     46 
     47         python tools/skqp/download_model
     48         python tools/skqp/setup_resources
     49         python tools/git-sync-deps
     50 
     51 4.  Configure the build:
     52 
     53         python tools/skqp/generate_gn_args out/skqp-arm "$ANDROID_NDK" \
     54                --arch arm \
     55                --api_level 26
     56         bin/gn gen out/skqp-arm
     57 
     58     If you want to test another architecture, replace `arm` with `x86`, `x64`
     59     or `arm64`. Run 'python tools/skqp/generate_gn_args -h' for
     60     all options.
     61 
     62 5.  Build, install, and run.
     63 
     64         platform_tools/android/bin/android_build_app -C out/skqp-arm skqp
     65         adb install -r out/skqp-arm/skqp.apk
     66         adb logcat -c
     67         adb shell am instrument -w org.skia.skqp
     68 
     69 6.  Monitor the output with:
     70 
     71         adb logcat org.skia.skqp skia "*:S"
     72 
     73     Note the test's output path on the device.  It will look something like this:
     74 
     75         01-23 15:22:12.688 27158 27173 I org.skia.skqp:
     76         output written to "/storage/emulated/0/Android/data/org.skia.skqp/files/output"
     77 
     78 7.  Retrieve and view the report with:
     79 
     80         OUTPUT_LOCATION="/storage/emulated/0/Android/data/org.skia.skqp/files/output"
     81         adb pull $OUTPUT_LOCATION /tmp/
     82         tools/skqp/sysopen.py /tmp/output/skqp_report/report.html
     83 
     84 Running a single test
     85 ---------------------
     86 
     87 To run a single test, for example `gles/aarectmodes`:
     88 
     89     adb shell am instrument -e class 'org.skia.skqp.SkQPRunner#gles/aarectmodes' -w org.skia.skqp
     90 
     91 Unit tests can be run with the `unitTest/` prefix:
     92 
     93     adb shell am instrument -e class 'org.skia.skqp.SkQPRunner#unitTest/GrSurface -w org.skia.skqp
     94 
     95 Run as a non-APK executable
     96 ---------------------------
     97 
     98 1.  Follow steps 1-3 as above.
     99 
    100 2.  Build the SkQP program, load files on the device, and run skqp:
    101 
    102         ninja -C out/skqp-arm skqp
    103         python tools/skqp/run_skqp_exe out/skqp-arm
    104 
    105