Index: tests/ImageFilterTest.cpp |
diff --git a/tests/ImageFilterTest.cpp b/tests/ImageFilterTest.cpp |
index 430481fcc6eda17fcfecff5281a4836fd4df9e2f..5e92ee35f73511b0591611777b655241a8a79a9f 100644 |
--- a/tests/ImageFilterTest.cpp |
+++ b/tests/ImageFilterTest.cpp |
@@ -133,7 +133,7 @@ static SkImageFilter* make_scale(float amount, SkImageFilter* input = NULL) { |
return SkColorFilterImageFilter::Create(filter, input); |
} |
-static SkImageFilter* make_grayscale(SkImageFilter* input = NULL, const SkImageFilter::CropRect* cropRect = NULL) { |
+static SkImageFilter* make_grayscale(SkImageFilter* input, const SkImageFilter::CropRect* cropRect) { |
SkScalar matrix[20]; |
memset(matrix, 0, 20 * sizeof(SkScalar)); |
matrix[0] = matrix[5] = matrix[10] = 0.2126f; |
@@ -144,29 +144,65 @@ static SkImageFilter* make_grayscale(SkImageFilter* input = NULL, const SkImageF |
return SkColorFilterImageFilter::Create(filter, input, cropRect); |
} |
+static SkImageFilter* make_blue(SkImageFilter* input, const SkImageFilter::CropRect* cropRect) { |
+ SkAutoTUnref<SkColorFilter> filter(SkColorFilter::CreateModeFilter(SK_ColorBLUE, |
+ SkXfermode::kSrcIn_Mode)); |
+ return SkColorFilterImageFilter::Create(filter, input, cropRect); |
+} |
+ |
DEF_TEST(ImageFilter, reporter) { |
{ |
- // Check that two non-clipping color matrices concatenate into a single filter. |
+ // Check that two non-clipping color-matrice-filters concatenate into a single filter. |
SkAutoTUnref<SkImageFilter> halfBrightness(make_scale(0.5f)); |
SkAutoTUnref<SkImageFilter> quarterBrightness(make_scale(0.5f, halfBrightness)); |
REPORTER_ASSERT(reporter, NULL == quarterBrightness->getInput(0)); |
+ SkColorFilter* cf; |
+ REPORTER_ASSERT(reporter, quarterBrightness->asColorFilter(&cf)); |
+ REPORTER_ASSERT(reporter, cf->asColorMatrix(NULL)); |
+ cf->unref(); |
} |
{ |
- // Check that a clipping color matrix followed by a grayscale does not concatenate into a single filter. |
+ // Check that a clipping color-matrice-filter followed by a color-matrice-filters |
+ // concatenates into a single filter, but not a matrixfilter (due to clamping). |
SkAutoTUnref<SkImageFilter> doubleBrightness(make_scale(2.0f)); |
SkAutoTUnref<SkImageFilter> halfBrightness(make_scale(0.5f, doubleBrightness)); |
- REPORTER_ASSERT(reporter, halfBrightness->getInput(0)); |
+ REPORTER_ASSERT(reporter, NULL == halfBrightness->getInput(0)); |
+ SkColorFilter* cf; |
+ REPORTER_ASSERT(reporter, halfBrightness->asColorFilter(&cf)); |
+ REPORTER_ASSERT(reporter, !cf->asColorMatrix(NULL)); |
+ cf->unref(); |
} |
{ |
// Check that a color filter image filter without a crop rect can be |
// expressed as a color filter. |
- SkAutoTUnref<SkImageFilter> gray(make_grayscale()); |
+ SkAutoTUnref<SkImageFilter> gray(make_grayscale(NULL, NULL)); |
+ REPORTER_ASSERT(reporter, true == gray->asColorFilter(NULL)); |
+ } |
+ |
+ { |
+ // Check that a colorfilterimage filter without a crop rect but with an input |
+ // that is another colorfilterimage can be expressed as a colorfilter (composed). |
+ SkAutoTUnref<SkImageFilter> mode(make_blue(NULL, NULL)); |
+ SkAutoTUnref<SkImageFilter> gray(make_grayscale(mode, NULL)); |
REPORTER_ASSERT(reporter, true == gray->asColorFilter(NULL)); |
} |
{ |
+ // Test that if we exceed the limit of what ComposeColorFilter can combine, we still |
+ // can build the DAG and won't assert if we call asColorFilter. |
+ SkAutoTUnref<SkImageFilter> filter(make_blue(NULL, NULL)); |
+ const int kWayTooManyForComposeColorFilter = 100; |
+ for (int i = 0; i < kWayTooManyForComposeColorFilter; ++i) { |
+ filter.reset(make_blue(filter, NULL)); |
+ // the first few of these will succeed, but after we hit the internal limit, |
+ // it will then return false. |
+ (void)filter->asColorFilter(NULL); |
+ } |
+ } |
+ |
+ { |
// Check that a color filter image filter with a crop rect cannot |
// be expressed as a color filter. |
SkImageFilter::CropRect cropRect(SkRect::MakeXYWH(0, 0, 100, 100)); |