Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(775)

Side by Side Diff: gm/rebaseline_server/compare_rendered_pictures_test.py

Issue 479613002: Add ability to output ImageBaseGSUrl to render_picture and use in rebaseline server (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Addressing comments Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 #!/usr/bin/python 1 #!/usr/bin/python
2 2
3 """ 3 """
4 Copyright 2014 Google Inc. 4 Copyright 2014 Google Inc.
5 5
6 Use of this source code is governed by a BSD-style license that can be 6 Use of this source code is governed by a BSD-style license that can be
7 found in the LICENSE file. 7 found in the LICENSE file.
8 8
9 Test compare_rendered_pictures.py 9 Test compare_rendered_pictures.py
10 10
(...skipping 14 matching lines...) Expand all
25 25
26 # Must fix up PYTHONPATH before importing from within Skia 26 # Must fix up PYTHONPATH before importing from within Skia
27 import rs_fixpypath # pylint: disable=W0611 27 import rs_fixpypath # pylint: disable=W0611
28 28
29 # Imports from within Skia 29 # Imports from within Skia
30 import base_unittest 30 import base_unittest
31 import compare_rendered_pictures 31 import compare_rendered_pictures
32 import find_run_binary 32 import find_run_binary
33 import gm_json 33 import gm_json
34 import imagediffdb 34 import imagediffdb
35 import imagepairset
35 import results 36 import results
36 37
37 38
38 class CompareRenderedPicturesTest(base_unittest.TestCase): 39 class CompareRenderedPicturesTest(base_unittest.TestCase):
39 40
40 def test_endToEnd(self): 41 def test_endToEnd(self):
41 """Generate two sets of SKPs, run render_pictures over both, and compare 42 """Generate two sets of SKPs, run render_pictures over both, and compare
42 the results.""" 43 the results."""
43 setA_subdir = 'before_patch' 44 setA_subdir = 'before_patch'
44 setB_subdir = 'after_patch' 45 setB_subdir = 'after_patch'
(...skipping 26 matching lines...) Expand all
71 results_obj._setA_descriptions[results.KEY__SET_DESCRIPTIONS__DIR] = [ 72 results_obj._setA_descriptions[results.KEY__SET_DESCRIPTIONS__DIR] = [
72 'before-patch-fake-dir'] 73 'before-patch-fake-dir']
73 results_obj._setB_descriptions[results.KEY__SET_DESCRIPTIONS__DIR] = [ 74 results_obj._setB_descriptions[results.KEY__SET_DESCRIPTIONS__DIR] = [
74 'after-patch-fake-dir'] 75 'after-patch-fake-dir']
75 76
76 gm_json.WriteToFile( 77 gm_json.WriteToFile(
77 results_obj.get_packaged_results_of_type( 78 results_obj.get_packaged_results_of_type(
78 results.KEY__HEADER__RESULTS_ALL), 79 results.KEY__HEADER__RESULTS_ALL),
79 os.path.join(self.output_dir_actual, 'compare_rendered_pictures.json')) 80 os.path.join(self.output_dir_actual, 'compare_rendered_pictures.json'))
80 81
82 def test_endToEnd_withImageBaseGSUrl(self):
83 """Generate two sets of SKPs, run render_pictures over both, and compare
84 the results."""
85 setA_subdir = 'before_patch'
86 setB_subdir = 'after_patch'
87 imageA_gs_base = 'superman/kent-camera/pictures'
88 imageB_gs_base = 'batman/batarang/pictures'
89 self._generate_skps_and_run_render_pictures(
90 subdir=setA_subdir, skpdict={
91 'changed.skp': 200,
92 'unchanged.skp': 100,
93 'only-in-before.skp': 128,
94 },
95 image_base_gs_url='gs://%s' % imageA_gs_base)
96 self._generate_skps_and_run_render_pictures(
97 subdir=setB_subdir, skpdict={
98 'changed.skp': 201,
99 'unchanged.skp': 100,
100 'only-in-after.skp': 128,
101 },
102 image_base_gs_url='gs://%s' % imageB_gs_base)
103
104 results_obj = compare_rendered_pictures.RenderedPicturesComparisons(
105 setA_dir=os.path.join(self.temp_dir, setA_subdir),
106 setB_dir=os.path.join(self.temp_dir, setB_subdir),
107 setA_section=gm_json.JSONKEY_ACTUALRESULTS,
108 setB_section=gm_json.JSONKEY_ACTUALRESULTS,
109 image_diff_db=imagediffdb.ImageDiffDB(self.temp_dir),
110 image_base_gs_url='gs://fakebucket/fake/path',
111 diff_base_url='/static/generated-images')
112 results_obj.get_timestamp = mock_get_timestamp
113
114 output_dict = results_obj.get_packaged_results_of_type(
115 results.KEY__HEADER__RESULTS_ALL)
116 # Assert that the baseURLs are as expected.
117 self.assertEquals(
118 output_dict[imagepairset.KEY__ROOT__IMAGESETS]
119 [imagepairset.KEY__IMAGESETS__SET__IMAGE_A]
120 [imagepairset.KEY__IMAGESETS__FIELD__BASE_URL],
121 'http://storage.cloud.google.com/%s' % imageA_gs_base)
122 self.assertEquals(
123 output_dict[imagepairset.KEY__ROOT__IMAGESETS]
124 [imagepairset.KEY__IMAGESETS__SET__IMAGE_B]
125 [imagepairset.KEY__IMAGESETS__FIELD__BASE_URL],
126 'http://storage.cloud.google.com/%s' % imageB_gs_base)
127
128 gm_json.WriteToFile(
129 output_dict,
130 os.path.join(self.output_dir_actual,
131 'compare_rendered_pictures.json'))
epoger 2014/08/21 18:25:06 Where is the expectation for this test? If you do
rmistry 2014/08/21 19:07:01 I wanted to add a new test so that the case where
132
81 def test_repo_url(self): 133 def test_repo_url(self):
82 """Use repo: URL to specify summary files.""" 134 """Use repo: URL to specify summary files."""
83 base_repo_url = 'repo:gm/rebaseline_server/testdata/inputs/skp-summaries' 135 base_repo_url = 'repo:gm/rebaseline_server/testdata/inputs/skp-summaries'
84 results_obj = compare_rendered_pictures.RenderedPicturesComparisons( 136 results_obj = compare_rendered_pictures.RenderedPicturesComparisons(
85 setA_dir=posixpath.join(base_repo_url, 'expectations'), 137 setA_dir=posixpath.join(base_repo_url, 'expectations'),
86 setB_dir=posixpath.join(base_repo_url, 'actuals'), 138 setB_dir=posixpath.join(base_repo_url, 'actuals'),
87 setA_section=gm_json.JSONKEY_EXPECTEDRESULTS, 139 setA_section=gm_json.JSONKEY_EXPECTEDRESULTS,
88 setB_section=gm_json.JSONKEY_ACTUALRESULTS, 140 setB_section=gm_json.JSONKEY_ACTUALRESULTS,
89 image_diff_db=imagediffdb.ImageDiffDB(self.temp_dir), 141 image_diff_db=imagediffdb.ImageDiffDB(self.temp_dir),
90 image_base_gs_url='gs://fakebucket/fake/path', 142 image_base_gs_url='gs://fakebucket/fake/path',
91 diff_base_url='/static/generated-images') 143 diff_base_url='/static/generated-images')
92 results_obj.get_timestamp = mock_get_timestamp 144 results_obj.get_timestamp = mock_get_timestamp
93 145
94 # Overwrite elements within the results that change from one test run 146 # Overwrite elements within the results that change from one test run
95 # to the next. 147 # to the next.
96 # pylint: disable=W0212 148 # pylint: disable=W0212
97 results_obj._setA_descriptions\ 149 results_obj._setA_descriptions\
98 [results.KEY__SET_DESCRIPTIONS__REPO_REVISION] = 'fake-repo-revision' 150 [results.KEY__SET_DESCRIPTIONS__REPO_REVISION] = 'fake-repo-revision'
99 results_obj._setB_descriptions\ 151 results_obj._setB_descriptions\
100 [results.KEY__SET_DESCRIPTIONS__REPO_REVISION] = 'fake-repo-revision' 152 [results.KEY__SET_DESCRIPTIONS__REPO_REVISION] = 'fake-repo-revision'
101 153
102 gm_json.WriteToFile( 154 gm_json.WriteToFile(
103 results_obj.get_packaged_results_of_type( 155 results_obj.get_packaged_results_of_type(
104 results.KEY__HEADER__RESULTS_ALL), 156 results.KEY__HEADER__RESULTS_ALL),
105 os.path.join(self.output_dir_actual, 'compare_rendered_pictures.json')) 157 os.path.join(self.output_dir_actual, 'compare_rendered_pictures.json'))
106 158
107 def _generate_skps_and_run_render_pictures(self, subdir, skpdict): 159 def _generate_skps_and_run_render_pictures(self, subdir, skpdict,
160 image_base_gs_url=None):
108 """Generate SKPs and run render_pictures on them. 161 """Generate SKPs and run render_pictures on them.
109 162
110 Args: 163 Args:
111 subdir: subdirectory (within self.temp_dir) to write all files into 164 subdir: subdirectory (within self.temp_dir) to write all files into
112 skpdict: {skpname: redvalue} dictionary describing the SKP files to render 165 skpdict: {skpname: redvalue} dictionary describing the SKP files to render
113 """ 166 """
114 out_path = os.path.join(self.temp_dir, subdir) 167 out_path = os.path.join(self.temp_dir, subdir)
115 os.makedirs(out_path) 168 os.makedirs(out_path)
116 for skpname, redvalue in skpdict.iteritems(): 169 for skpname, redvalue in skpdict.iteritems():
117 self._run_skpmaker( 170 self._run_skpmaker(
118 output_path=os.path.join(out_path, skpname), red=redvalue) 171 output_path=os.path.join(out_path, skpname), red=redvalue)
119 172
120 # TODO(epoger): Add --mode tile 256 256 --writeWholeImage to the unittest, 173 # TODO(epoger): Add --mode tile 256 256 --writeWholeImage to the unittest,
121 # and fix its result! (imageURLs within whole-image entries are wrong when 174 # and fix its result! (imageURLs within whole-image entries are wrong when
122 # I tried adding that) 175 # I tried adding that)
123 binary = find_run_binary.find_path_to_program('render_pictures') 176 binary = find_run_binary.find_path_to_program('render_pictures')
124 return subprocess.check_output([ 177 render_pictures_cmd = [
125 binary, 178 binary,
126 '--config', '8888', 179 '--config', '8888',
127 '-r', out_path, 180 '-r', out_path,
128 '--writeChecksumBasedFilenames', 181 '--writeChecksumBasedFilenames',
129 '--writeJsonSummaryPath', os.path.join(out_path, 'summary.json'), 182 '--writeJsonSummaryPath', os.path.join(out_path, 'summary.json'),
130 '--writePath', out_path]) 183 '--writePath', out_path]
184 if image_base_gs_url:
185 render_pictures_cmd.extend(['--imageBaseGSUrl', image_base_gs_url])
186 return subprocess.check_output(render_pictures_cmd)
131 187
132 def _run_skpmaker(self, output_path, red=0, green=0, blue=0, 188 def _run_skpmaker(self, output_path, red=0, green=0, blue=0,
133 width=640, height=400): 189 width=640, height=400):
134 """Runs the skpmaker binary to generate SKP with known characteristics. 190 """Runs the skpmaker binary to generate SKP with known characteristics.
135 191
136 Args: 192 Args:
137 output_path: Filepath to write the SKP into. 193 output_path: Filepath to write the SKP into.
138 red: Value of red color channel in image, 0-255. 194 red: Value of red color channel in image, 0-255.
139 green: Value of green color channel in image, 0-255. 195 green: Value of green color channel in image, 0-255.
140 blue: Value of blue color channel in image, 0-255. 196 blue: Value of blue color channel in image, 0-255.
(...skipping 14 matching lines...) Expand all
155 """Mock version of BaseComparisons.get_timestamp() for testing.""" 211 """Mock version of BaseComparisons.get_timestamp() for testing."""
156 return 12345678 212 return 12345678
157 213
158 214
159 def main(): 215 def main():
160 base_unittest.main(CompareRenderedPicturesTest) 216 base_unittest.main(CompareRenderedPicturesTest)
161 217
162 218
163 if __name__ == '__main__': 219 if __name__ == '__main__':
164 main() 220 main()
OLDNEW
« no previous file with comments | « gm/rebaseline_server/compare_rendered_pictures.py ('k') | gm/rebaseline_server/compare_to_expectations.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698