blob: b3f23ce160b01d0e6cc6626a7c9305f3cb0952e0 [file] [log] [blame]
epoger@google.coma413a532012-11-12 18:04:51 +00001#!/bin/bash
2
3# Self-tests for gm, based on tools/tests/run.sh
epoger@google.com454008a2012-11-13 20:46:50 +00004#
5# These tests are run by the Skia_PerCommit_House_Keeping bot at every commit,
6# so make sure that they still pass when you make changes to gm!
7#
epoger@google.com0b62b3d2013-03-20 17:59:28 +00008# To generate new baselines when gm behavior changes, run gm/tests/rebaseline.sh
9#
commit-bot@chromium.orgc61c3c32013-03-01 15:32:34 +000010# TODO: because this is written as a shell script (instead of, say, Python)
11# it only runs on Linux and Mac.
epoger@google.com3aa33582013-01-02 15:53:25 +000012# See https://code.google.com/p/skia/issues/detail?id=677
13# ('make tools/tests/run.sh work cross-platform')
epoger@google.com454008a2012-11-13 20:46:50 +000014# Ideally, these tests should pass on all development platforms...
15# otherwise, how can developers be expected to test them before committing a
16# change?
epoger@google.coma413a532012-11-12 18:04:51 +000017
18# cd into .../trunk so all the paths will work
19cd $(dirname $0)/../..
20
21# TODO(epoger): make it look in Release and/or Debug
22GM_BINARY=out/Debug/gm
23
epoger@google.comfed9db62013-05-08 14:10:28 +000024# If WRITE_IMAGE_FILES is nonzero, then the self-test will pass --writePath
25# and --mismatchPath arguments to GM. Currently, for various reasons, we
26# cannot run these arguments on the production buildbots, so this should
27# only be set to nonzero for local testing.
28WRITE_IMAGE_FILES=0
29
epoger@google.com407f8da2013-01-18 19:19:47 +000030OUTPUT_ACTUAL_SUBDIR=output-actual
31OUTPUT_EXPECTED_SUBDIR=output-expected
scroggo@google.com09fd4d22013-03-20 14:20:18 +000032CONFIGS="--config 8888 565"
epoger@google.com407f8da2013-01-18 19:19:47 +000033
epoger@google.com0cc99cf2013-04-26 17:45:06 +000034ENCOUNTERED_ANY_ERRORS=0
35
epoger@google.coma413a532012-11-12 18:04:51 +000036# Compare contents of all files within directories $1 and $2,
37# EXCEPT for any dotfiles.
38# If there are any differences, a description is written to stdout and
39# we exit with a nonzero return value.
40# Otherwise, we write nothing to stdout and return.
41function compare_directories {
42 if [ $# != 2 ]; then
43 echo "compare_directories requires exactly 2 parameters, got $#"
44 exit 1
45 fi
46 diff -r --exclude=.* $1 $2
47 if [ $? != 0 ]; then
48 echo "failed in: compare_directories $1 $2"
epoger@google.com0cc99cf2013-04-26 17:45:06 +000049 ENCOUNTERED_ANY_ERRORS=1
epoger@google.coma413a532012-11-12 18:04:51 +000050 fi
51}
52
53# Run gm...
54# - with the arguments in $1
epoger@google.com407f8da2013-01-18 19:19:47 +000055# - writing stdout into $2/$OUTPUT_ACTUAL_SUBDIR/stdout
56# - writing json summary into $2/$OUTPUT_ACTUAL_SUBDIR/json-summary.txt
57# - writing return value into $2/$OUTPUT_ACTUAL_SUBDIR/return_value
58# Then compare all of those against $2/$OUTPUT_EXPECTED_SUBDIR .
epoger@google.coma413a532012-11-12 18:04:51 +000059function gm_test {
60 if [ $# != 2 ]; then
61 echo "gm_test requires exactly 2 parameters, got $#"
62 exit 1
63 fi
64 GM_ARGS="$1"
epoger@google.com407f8da2013-01-18 19:19:47 +000065 ACTUAL_OUTPUT_DIR="$2/$OUTPUT_ACTUAL_SUBDIR"
66 EXPECTED_OUTPUT_DIR="$2/$OUTPUT_EXPECTED_SUBDIR"
67 JSON_SUMMARY_FILE="$ACTUAL_OUTPUT_DIR/json-summary.txt"
epoger@google.coma413a532012-11-12 18:04:51 +000068
69 rm -rf $ACTUAL_OUTPUT_DIR
70 mkdir -p $ACTUAL_OUTPUT_DIR
epoger@google.comfed9db62013-05-08 14:10:28 +000071
scroggo@google.com09fd4d22013-03-20 14:20:18 +000072 COMMAND="$GM_BINARY $GM_ARGS --writeJsonSummaryPath $JSON_SUMMARY_FILE"
epoger@google.comfed9db62013-05-08 14:10:28 +000073 if [ $WRITE_IMAGE_FILES != 0 ]; then
74 COMMAND="$COMMAND --writePath $ACTUAL_OUTPUT_DIR/writePath --mismatchPath $ACTUAL_OUTPUT_DIR/mismatchPath"
75 fi
76
epoger@google.coma413a532012-11-12 18:04:51 +000077 echo "$COMMAND" >$ACTUAL_OUTPUT_DIR/command_line
epoger@google.com5efdd0c2013-03-13 14:18:40 +000078 $COMMAND >$ACTUAL_OUTPUT_DIR/stdout 2>$ACTUAL_OUTPUT_DIR/stderr
epoger@google.coma413a532012-11-12 18:04:51 +000079 echo $? >$ACTUAL_OUTPUT_DIR/return_value
80
epoger@google.com80d44782013-01-18 20:03:58 +000081 # Only compare selected lines in the stdout, to ignore any spurious lines
epoger@google.com407f8da2013-01-18 19:19:47 +000082 # as noted in http://code.google.com/p/skia/issues/detail?id=1068 .
83 #
84 # TODO(epoger): This is still hacky... we need to rewrite this script in
85 # Python soon, and make stuff like this more maintainable.
epoger@google.com5efdd0c2013-03-13 14:18:40 +000086 grep ^GM: $ACTUAL_OUTPUT_DIR/stdout >$ACTUAL_OUTPUT_DIR/stdout-tmp
epoger@google.com98204f92013-01-16 04:19:01 +000087 mv $ACTUAL_OUTPUT_DIR/stdout-tmp $ACTUAL_OUTPUT_DIR/stdout
epoger@google.com5efdd0c2013-03-13 14:18:40 +000088 grep ^GM: $ACTUAL_OUTPUT_DIR/stderr >$ACTUAL_OUTPUT_DIR/stderr-tmp
89 mv $ACTUAL_OUTPUT_DIR/stderr-tmp $ACTUAL_OUTPUT_DIR/stderr
epoger@google.com98204f92013-01-16 04:19:01 +000090
epoger@google.comfed9db62013-05-08 14:10:28 +000091 if [ $WRITE_IMAGE_FILES != 0 ]; then
92 for IMAGEFILE in $(ls $ACTUAL_OUTPUT_DIR/*/*/*.png); do
93 SUM=$(sum $IMAGEFILE)
94 echo "Replaced image bytes with a checksum, because of https://code.google.com/p/chromium/issues/detail?id=169600 ('gcl/upload.py fail to upload binary files to rietveld')" >$IMAGEFILE
95 echo $SUM >> $IMAGEFILE
96 done
97 for MISMATCHDIR in $(ls -d $ACTUAL_OUTPUT_DIR/mismatchPath/*); do
98 echo "Created additional file to make sure directory isn't empty, because self-test cannot handle empty directories." >$MISMATCHDIR/bogusfile
99 done
100 fi
101
epoger@google.coma413a532012-11-12 18:04:51 +0000102 compare_directories $EXPECTED_OUTPUT_DIR $ACTUAL_OUTPUT_DIR
103}
104
epoger@google.come460a472013-02-06 18:41:04 +0000105# Create input dir (at path $1) with expectations (both image and json)
106# that gm will match or mismatch as appropriate.
epoger@google.com407f8da2013-01-18 19:19:47 +0000107#
108# We used to check these files into SVN, but then we needed to rebasline them
109# when our drawing changed at all... so, as proposed in
110# http://code.google.com/p/skia/issues/detail?id=1068 , we generate them
111# new each time.
112function create_inputs_dir {
113 if [ $# != 1 ]; then
114 echo "create_inputs_dir requires exactly 1 parameter, got $#"
115 exit 1
116 fi
117 INPUTS_DIR="$1"
epoger@google.come460a472013-02-06 18:41:04 +0000118 IMAGES_DIR=$INPUTS_DIR/images
119 JSON_DIR=$INPUTS_DIR/json
120 mkdir -p $IMAGES_DIR $JSON_DIR
epoger@google.com407f8da2013-01-18 19:19:47 +0000121
epoger@google.come460a472013-02-06 18:41:04 +0000122 mkdir -p $IMAGES_DIR/identical-bytes
123 # Run GM to write out the images actually generated.
commit-bot@chromium.orgc61c3c32013-03-01 15:32:34 +0000124 $GM_BINARY --hierarchy --match selftest1 $CONFIGS \
epoger@google.come460a472013-02-06 18:41:04 +0000125 -w $IMAGES_DIR/identical-bytes
126 # Run GM again to read in those images and write them out as a JSON summary.
commit-bot@chromium.orgc61c3c32013-03-01 15:32:34 +0000127 $GM_BINARY --hierarchy --match selftest1 $CONFIGS \
epoger@google.come460a472013-02-06 18:41:04 +0000128 -r $IMAGES_DIR/identical-bytes \
scroggo@google.com09fd4d22013-03-20 14:20:18 +0000129 --writeJsonSummaryPath $JSON_DIR/identical-bytes.json
epoger@google.com407f8da2013-01-18 19:19:47 +0000130
epoger@google.come460a472013-02-06 18:41:04 +0000131 mkdir -p $IMAGES_DIR/identical-pixels
commit-bot@chromium.orgc61c3c32013-03-01 15:32:34 +0000132 $GM_BINARY --hierarchy --match selftest1 $CONFIGS \
epoger@google.come460a472013-02-06 18:41:04 +0000133 -w $IMAGES_DIR/identical-pixels
134 echo "more bytes that do not change the image pixels" \
commit-bot@chromium.orgc61c3c32013-03-01 15:32:34 +0000135 >> $IMAGES_DIR/identical-pixels/8888/selftest1.png
epoger@google.come460a472013-02-06 18:41:04 +0000136 echo "more bytes that do not change the image pixels" \
commit-bot@chromium.orgc61c3c32013-03-01 15:32:34 +0000137 >> $IMAGES_DIR/identical-pixels/565/selftest1.png
138 $GM_BINARY --hierarchy --match selftest1 $CONFIGS \
epoger@google.come460a472013-02-06 18:41:04 +0000139 -r $IMAGES_DIR/identical-pixels \
scroggo@google.com09fd4d22013-03-20 14:20:18 +0000140 --writeJsonSummaryPath $JSON_DIR/identical-pixels.json
epoger@google.come460a472013-02-06 18:41:04 +0000141
142 mkdir -p $IMAGES_DIR/different-pixels
commit-bot@chromium.orgc61c3c32013-03-01 15:32:34 +0000143 $GM_BINARY --hierarchy --match selftest2 $CONFIGS \
epoger@google.come460a472013-02-06 18:41:04 +0000144 -w $IMAGES_DIR/different-pixels
commit-bot@chromium.orgc61c3c32013-03-01 15:32:34 +0000145 mv $IMAGES_DIR/different-pixels/8888/selftest2.png \
146 $IMAGES_DIR/different-pixels/8888/selftest1.png
147 mv $IMAGES_DIR/different-pixels/565/selftest2.png \
148 $IMAGES_DIR/different-pixels/565/selftest1.png
149 $GM_BINARY --hierarchy --match selftest1 $CONFIGS \
epoger@google.come460a472013-02-06 18:41:04 +0000150 -r $IMAGES_DIR/different-pixels \
scroggo@google.com09fd4d22013-03-20 14:20:18 +0000151 --writeJsonSummaryPath $JSON_DIR/different-pixels.json
epoger@google.com407f8da2013-01-18 19:19:47 +0000152
epoger@google.come460a472013-02-06 18:41:04 +0000153 mkdir -p $IMAGES_DIR/empty-dir
epoger@google.com407f8da2013-01-18 19:19:47 +0000154}
155
epoger@google.coma413a532012-11-12 18:04:51 +0000156GM_TESTDIR=gm/tests
157GM_INPUTS=$GM_TESTDIR/inputs
158GM_OUTPUTS=$GM_TESTDIR/outputs
epoger@google.com37269602013-01-19 04:21:27 +0000159GM_TEMPFILES=$GM_TESTDIR/tempfiles
epoger@google.coma413a532012-11-12 18:04:51 +0000160
epoger@google.com407f8da2013-01-18 19:19:47 +0000161create_inputs_dir $GM_INPUTS
162
epoger@google.com570aafe2012-11-28 20:08:32 +0000163# Compare generated image against an input image file with identical bytes.
epoger@google.com51dbabe2013-04-10 15:24:53 +0000164gm_test "--verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/images/identical-bytes" "$GM_OUTPUTS/compared-against-identical-bytes-images"
165gm_test "--verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/json/identical-bytes.json" "$GM_OUTPUTS/compared-against-identical-bytes-json"
epoger@google.coma413a532012-11-12 18:04:51 +0000166
epoger@google.com570aafe2012-11-28 20:08:32 +0000167# Compare generated image against an input image file with identical pixels but different PNG encoding.
epoger@google.com51dbabe2013-04-10 15:24:53 +0000168gm_test "--verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/images/identical-pixels" "$GM_OUTPUTS/compared-against-identical-pixels-images"
169gm_test "--verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/json/identical-pixels.json" "$GM_OUTPUTS/compared-against-identical-pixels-json"
epoger@google.com570aafe2012-11-28 20:08:32 +0000170
171# Compare generated image against an input image file with different pixels.
epoger@google.com51dbabe2013-04-10 15:24:53 +0000172gm_test "--verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/images/different-pixels" "$GM_OUTPUTS/compared-against-different-pixels-images"
173gm_test "--verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/json/different-pixels.json" "$GM_OUTPUTS/compared-against-different-pixels-json"
epoger@google.coma413a532012-11-12 18:04:51 +0000174
epoger@google.comee8a8e32012-12-18 19:13:49 +0000175# Compare generated image against an empty "expected image" dir.
epoger@google.com51dbabe2013-04-10 15:24:53 +0000176gm_test "--verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/images/empty-dir" "$GM_OUTPUTS/compared-against-empty-dir"
177
epoger@google.com318a0592013-04-12 19:05:57 +0000178# Compare generated image against a nonexistent "expected image" dir.
179gm_test "--verbose --hierarchy --match selftest1 $CONFIGS -r ../path/to/nowhere" "$GM_OUTPUTS/compared-against-nonexistent-dir"
180
epoger@google.com51dbabe2013-04-10 15:24:53 +0000181# Compare generated image against an empty "expected image" dir, but NOT in verbose mode.
182gm_test "--hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/images/empty-dir" "$GM_OUTPUTS/nonverbose"
epoger@google.comee8a8e32012-12-18 19:13:49 +0000183
epoger@google.com9c56a8d2012-12-20 18:34:29 +0000184# If run without "-r", the JSON's "actual-results" section should contain
185# actual checksums marked as "failure-ignored", but the "expected-results"
186# section should be empty.
epoger@google.com51dbabe2013-04-10 15:24:53 +0000187gm_test "--verbose --hierarchy --match selftest1 $CONFIGS" "$GM_OUTPUTS/no-readpath"
epoger@google.com9c56a8d2012-12-20 18:34:29 +0000188
epoger@google.comcaac3db2013-04-04 19:23:11 +0000189# Test what happens if a subset of the renderModes fail (e.g. pipe)
epoger@google.com51dbabe2013-04-10 15:24:53 +0000190gm_test "--simulatePipePlaybackFailure --verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/json/identical-pixels.json" "$GM_OUTPUTS/pipe-playback-failure"
epoger@google.comcaac3db2013-04-04 19:23:11 +0000191
epoger@google.comc8263e72013-04-10 12:17:34 +0000192# Confirm that IntentionallySkipped tests are recorded as such.
epoger@google.com51dbabe2013-04-10 15:24:53 +0000193gm_test "--verbose --hierarchy --match selftest1 selftest2 $CONFIGS" "$GM_OUTPUTS/intentionally-skipped-tests"
epoger@google.comc8263e72013-04-10 12:17:34 +0000194
epoger@google.com5079d2c2013-04-12 14:11:21 +0000195# Ignore some error types (including ExpectationsMismatch)
196gm_test "--ignoreErrorTypes ExpectationsMismatch NoGpuContext --verbose --hierarchy --match selftest1 $CONFIGS -r $GM_INPUTS/json/different-pixels.json" "$GM_OUTPUTS/ignore-expectations-mismatch"
197
epoger@google.com0cc99cf2013-04-26 17:45:06 +0000198if [ $ENCOUNTERED_ANY_ERRORS == 0 ]; then
199 echo "All tests passed."
200 exit 0
201else
202 exit 1
203fi