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

Unified Diff: cc/test/pixel_comparator.h

Issue 12558003: cc: Made image comparison for pixel tests error tolerant. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase to tip of tree. Added discard_alpha flag. Created 7 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: cc/test/pixel_comparator.h
diff --git a/cc/test/pixel_comparator.h b/cc/test/pixel_comparator.h
new file mode 100644
index 0000000000000000000000000000000000000000..fa2351ac58dd3c4ef07ac310fa8752156ffa6d00
--- /dev/null
+++ b/cc/test/pixel_comparator.h
@@ -0,0 +1,71 @@
+// Copyright (c) 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CC_TEST_PIXEL_COMPARATOR_H_
+#define CC_TEST_PIXEL_COMPARATOR_H_
+
+#include "base/compiler_specific.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+
+namespace cc {
+
+// Interface for pixel comparators.
+class PixelComparator {
+ public:
+ virtual bool Compare(const SkBitmap& actual_bmp,
+ const SkBitmap& expected_bmp) const = 0;
+
+ protected:
+ virtual ~PixelComparator() {}
+};
+
+// Exact pixel comparator. Counts the number of pixel with an error.
+class ExactPixelComparator : public PixelComparator {
+ public:
+ ExactPixelComparator(const bool discard_alpha);
danakj 2013/03/28 22:17:25 explicit. this should be covered by presubmit lin
ernstm 2013/03/28 23:10:26 Done.
+ // Returns true if the two bitmaps are identical. Otherwise, returns false
+ // and report the number of pixels with an error on LOG(ERROR). Differences
+ // in the alpha channel are ignored.
+ virtual bool Compare(const SkBitmap& actual_bmp,
+ const SkBitmap& expected_bmp) const OVERRIDE;
+
+ private:
+ // Exclude alpha channel from comparison?
+ bool discard_alpha_;
+};
+
+// Fuzzy pixel comparator. Counts small and arbitrary errors separately and
+// computes average and maximum absolute errors per color channel.
+class FuzzyPixelComparator : public PixelComparator {
+ public:
+ FuzzyPixelComparator(const bool discard_alpha,
+ const float error_pixels_percentage_limit,
+ const float small_error_pixels_percentage_limit,
+ const float avg_abs_error_limit,
+ const int max_abs_error_limit,
+ const int small_error_threshold);
+ // Computes error metrics and returns true if the errors don't exceed the
+ // specified limits. Otherwise, returns false and reports the error metrics on
+ // LOG(ERROR). Differences in the alpha channel are ignored.
+ virtual bool Compare(const SkBitmap& actual_bmp,
+ const SkBitmap& expected_bmp) const OVERRIDE;
+
+ private:
+ // Exclude alpha channel from comparison?
+ bool discard_alpha_;
+ // Limit for percentage of pixels with an error
danakj 2013/03/28 22:17:25 nit: periods at end of sentences while you're fixi
ernstm 2013/03/28 23:10:26 Done.
+ float error_pixels_percentage_limit_;
+ // Limit for percentage of pixels with a small error
+ float small_error_pixels_percentage_limit_;
+ // Limit for average absolute error (excluding identical pixels)
+ float avg_abs_error_limit_;
+ // Limit for largest absolute error
+ int max_abs_error_limit_;
+ // Threshold for small errors
+ int small_error_threshold_;
+};
+
+} // namespace cc
+
+#endif // CC_TEST_PIXEL_COMPARATOR_H_

Powered by Google App Engine
This is Rietveld 408576698