aboutsummaryrefslogtreecommitdiffhomepage
path: root/tools
diff options
context:
space:
mode:
authorGravatar edisonn@google.com <edisonn@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-10-10 15:08:12 +0000
committerGravatar edisonn@google.com <edisonn@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-10-10 15:08:12 +0000
commitc2c4981d02d0e23907ed1280739afdd12711f1b5 (patch)
treef792e76f74ac49c6883822c6884648eda0fea556 /tools
parent41fe45b955dc2f572bb1b6598d3b2f9d0c0447a4 (diff)
Refactor test_pictures so we can add test_pdfs without code duplication.
Review URL: https://codereview.appspot.com/6611050 git-svn-id: http://skia.googlecode.com/svn/trunk@5878 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'tools')
-rw-r--r--tools/test_pictures.py121
-rw-r--r--tools/test_rendering.py118
2 files changed, 138 insertions, 101 deletions
diff --git a/tools/test_pictures.py b/tools/test_pictures.py
index d26d3b9c0c..b2397c4dda 100644
--- a/tools/test_pictures.py
+++ b/tools/test_pictures.py
@@ -16,96 +16,19 @@ import sys
import shutil
import tempfile
+# modules declared within this same directory
+import test_rendering
+
USAGE_STRING = 'Usage: %s input... expectedDir'
HELP_STRING = '''
-Compares the renderings of serialized SkPicture files and directories specified
-by input with the images in expectedDir. Note, files in directoriers are
-expected to end with .skp.
-'''
-
-def RunCommand(command):
- """Run a command.
-
- @param command the command as a single string
- """
- print 'running command [%s]...' % command
- os.system(command)
-
-
-def FindPathToProgram(program):
- """Return path to an existing program binary, or raise an exception if we
- cannot find one.
-
- @param program the name of the program that is being looked for
- """
- trunk_path = os.path.abspath(os.path.join(os.path.dirname(__file__),
- os.pardir))
- possible_paths = [os.path.join(trunk_path, 'out', 'Release', program),
- os.path.join(trunk_path, 'out', 'Debug', program),
- os.path.join(trunk_path, 'out', 'Release',
- program + ".exe"),
- os.path.join(trunk_path, 'out', 'Debug',
- program + ".exe")]
- for try_path in possible_paths:
- if os.path.isfile(try_path):
- return try_path
- raise Exception('cannot find %s in paths %s; maybe you need to '
- 'build %s?' % (program, possible_paths, program))
-
-
-def RenderImages(inputs, render_dir, options):
- """Renders the serialized SkPictures.
-
- Uses the render_pictures program to do the rendering.
-
- @param inputs the location(s) to read the serlialized SkPictures
- @param render_dir the location to write out the rendered images
- """
- renderer_path = FindPathToProgram('render_pictures')
- inputs_as_string = " ".join(inputs)
- command = '%s %s %s' % (renderer_path, inputs_as_string, render_dir)
-
- if (options.mode is not None):
- command += ' --mode %s' % ' '.join(options.mode)
-
- if (options.device is not None):
- command += ' --device %s' % options.device
-
- RunCommand(command)
-
-
-def DiffImages(expected_dir, comparison_dir, diff_dir):
- """Diffs the rendered SkPicture images with the baseline images.
-
- Uses the skdiff program to do the diffing.
-
- @param expected_dir the location of the baseline images.
- @param comparison_dir the location of the images to comapre with the
- baseline
- @param diff_dir the location to write out the diff results
- """
- skdiff_path = FindPathToProgram('skdiff')
- RunCommand('%s %s %s %s %s' %
- (skdiff_path, expected_dir, comparison_dir, diff_dir,
- '--noprintdirs'))
-
-
-def Cleanup(options, render_dir, diff_dir):
- """Deletes any temporary folders and files created.
-
- @param options The OptionParser object that parsed if render_dir or diff_dir
- was set
- @param render_dir the directory where the rendered images were written
- @param diff_dir the directory where the diff results were written
- """
- if (not options.render_dir):
- if (os.path.isdir(render_dir)):
- shutil.rmtree(render_dir)
- if (not options.diff_dir):
- if (os.path.isdir(diff_dir)):
- shutil.rmtree(diff_dir)
+Takes input SkPicture files and renders them as PNG files, and then compares
+those resulting PNG files against PNG files found in expectedDir.
+Each instance of "input" can be either a file (name must end in .skp), or a
+directory (in which case this script will process all .skp files within the
+directory).
+'''
def ModeParse(option, opt_str, value, parser):
"""Parses the --mode option of the commandline.
@@ -158,21 +81,17 @@ def Main(args):
inputs = arguments[1:-1]
expected_dir = arguments[-1]
- if (options.render_dir):
- render_dir = options.render_dir
- else:
- render_dir = tempfile.mkdtemp()
-
- if (options.diff_dir):
- diff_dir = options.diff_dir
- else:
- diff_dir = tempfile.mkdtemp()
-
- try:
- RenderImages(inputs, render_dir, options)
- DiffImages(expected_dir, render_dir, diff_dir)
- finally:
- Cleanup(options, render_dir, diff_dir)
+ extra_args = ''
+
+ if (options.mode is not None):
+ extra_args += ' --mode %s' % ' '.join(options.mode)
+
+ if (options.device is not None):
+ extra_args += ' --device %s' % options.device
+
+ test_rendering.TestRenderSkps(inputs, expected_dir, options.render_dir,
+ options.diff_dir, 'render_pictures',
+ extra_args)
if __name__ == '__main__':
Main(sys.argv)
diff --git a/tools/test_rendering.py b/tools/test_rendering.py
new file mode 100644
index 0000000000..35e6d94f4b
--- /dev/null
+++ b/tools/test_rendering.py
@@ -0,0 +1,118 @@
+'''
+Compares the rendererings of serialized SkPictures to expected result.
+
+Copyright 2012 Google Inc.
+
+Use of this source code is governed by a BSD-style license that can be
+found in the LICENSE file.
+'''
+# common Python modules
+import os
+import optparse
+import sys
+import shutil
+import tempfile
+
+USAGE_STRING = 'Usage: %s input... expectedDir render_app [reander_app_args]'
+HELP_STRING = '''
+
+Compares the renderings of serialized SkPicture files and directories specified
+by input with the files in expectedDir. Note, files in directoriers are
+expected to end with .skp.
+'''
+
+def RunCommand(command):
+ """Run a command.
+
+ @param command the command as a single string
+ """
+ print 'running command [%s]...' % command
+ os.system(command)
+
+
+def FindPathToProgram(program):
+ """Return path to an existing program binary, or raise an exception if we
+ cannot find one.
+
+ @param program the name of the program that is being looked for
+ """
+ trunk_path = os.path.abspath(os.path.join(os.path.dirname(__file__),
+ os.pardir))
+ possible_paths = [os.path.join(trunk_path, 'out', 'Release', program),
+ os.path.join(trunk_path, 'out', 'Debug', program),
+ os.path.join(trunk_path, 'out', 'Release',
+ program + ".exe"),
+ os.path.join(trunk_path, 'out', 'Debug',
+ program + ".exe")]
+ for try_path in possible_paths:
+ if os.path.isfile(try_path):
+ return try_path
+ raise Exception('cannot find %s in paths %s; maybe you need to '
+ 'build %s?' % (program, possible_paths, program))
+
+
+def RenderSkps(inputs, render_dir, render_app, args):
+ """Renders the serialized SkPictures.
+
+ Uses the render_pictures program to do the rendering.
+
+ @param inputs the location(s) to read the serlialized SkPictures
+ @param render_dir the location to write out the rendered images
+ """
+ renderer_path = FindPathToProgram(render_app)
+ inputs_as_string = " ".join(inputs)
+ command = '%s %s %s' % (renderer_path, inputs_as_string, render_dir)
+
+ command += args
+
+ RunCommand(command)
+
+
+def DiffRenderings(expected_dir, comparison_dir, diff_dir):
+ """Diffs the rendered SkPicture files with the baseline files.
+
+ Uses the skdiff program to do the diffing.
+
+ @param expected_dir the location of the baseline images.
+ @param comparison_dir the location of the images to comapre with the
+ baseline
+ @param diff_dir the location to write out the diff results
+ """
+ skdiff_path = FindPathToProgram('skdiff')
+ RunCommand('%s %s %s %s %s' %
+ (skdiff_path, expected_dir, comparison_dir, diff_dir,
+ '--noprintdirs'))
+
+
+def Cleanup(render_dir_option, diff_dir_option, render_dir, diff_dir):
+ """Deletes any temporary folders and files created.
+
+ @param foo_option The OptionParser parsed render_dir or diff_dir vars.
+ If these variables are not passed by user we ended up creating
+ temporary directories (render_dir, diff_dir) which we will remove.
+ @param render_dir the directory where the rendered images were written
+ @param diff_dir the directory where the diff results were written
+ """
+ if (not render_dir_option):
+ if (os.path.isdir(render_dir)):
+ shutil.rmtree(render_dir)
+ if (not diff_dir_option):
+ if (os.path.isdir(diff_dir)):
+ shutil.rmtree(diff_dir)
+
+def TestRenderSkps(inputs, expected_dir, render_dir_option, diff_dir_option,
+ render_app, render_args):
+ if (render_dir_option):
+ render_dir = render_dir_option
+ else:
+ render_dir = tempfile.mkdtemp()
+
+ if (diff_dir_option):
+ diff_dir = diff_dir_option
+ else:
+ diff_dir = tempfile.mkdtemp()
+ try:
+ RenderSkps(inputs, render_dir, render_app, render_args)
+ DiffRenderings(expected_dir, render_dir, diff_dir)
+ finally:
+ Cleanup(render_dir_option, diff_dir_option, render_dir, diff_dir)