aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/ColorFilterTest.cpp
diff options
context:
space:
mode:
authorGravatar reed <reed@google.com>2015-03-05 07:21:02 -0800
committerGravatar Commit bot <commit-bot@chromium.org>2015-03-05 07:21:02 -0800
commitdc812222a7488d2a0e39b4a09c81c9f000d4b869 (patch)
tree3222fab65c26895e6a0ec1d84250ebb47b182350 /tests/ColorFilterTest.cpp
parent9ba3972ed93321ee606e2974e00a926cd871ddcc (diff)
add impl limit for number of leaf-nodes in composecolorfilter
Diffstat (limited to 'tests/ColorFilterTest.cpp')
-rw-r--r--tests/ColorFilterTest.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/tests/ColorFilterTest.cpp b/tests/ColorFilterTest.cpp
index f3f6a0a8e8..b2e37183b5 100644
--- a/tests/ColorFilterTest.cpp
+++ b/tests/ColorFilterTest.cpp
@@ -30,6 +30,26 @@ static SkColorFilter* reincarnate_colorfilter(SkFlattenable* obj) {
///////////////////////////////////////////////////////////////////////////////
+static SkColorFilter* make_filter() {
+ // pick a filter that cannot compose with itself via newComposed()
+ return SkColorFilter::CreateModeFilter(SK_ColorRED, SkXfermode::kColorBurn_Mode);
+}
+
+static void test_composecolorfilter_limit(skiatest::Reporter* reporter) {
+ // Test that CreateComposeFilter() has some finite limit (i.e. that the factory can return null)
+ const int way_too_many = 100;
+ SkAutoTUnref<SkColorFilter> parent(make_filter());
+ for (int i = 2; i < way_too_many; ++i) {
+ SkAutoTUnref<SkColorFilter> filter(make_filter());
+ parent.reset(SkColorFilter::CreateComposeFilter(parent, filter));
+ if (NULL == parent) {
+ REPORTER_ASSERT(reporter, i > 2); // we need to have succeeded at least once!
+ return;
+ }
+ }
+ REPORTER_ASSERT(reporter, false); // we never saw a NULL :(
+}
+
#define ILLEGAL_MODE ((SkXfermode::Mode)-1)
DEF_TEST(ColorFilter, reporter) {
@@ -89,6 +109,8 @@ DEF_TEST(ColorFilter, reporter) {
REPORTER_ASSERT(reporter, m2 == expectedMode);
}
}
+
+ test_composecolorfilter_limit(reporter);
}
///////////////////////////////////////////////////////////////////////////////