diff options
author | 2016-06-22 08:18:54 -0700 | |
---|---|---|
committer | 2016-06-22 08:18:54 -0700 | |
commit | 111a42d9cebf0bb8844c5d24f67fac57cc619d29 (patch) | |
tree | ce93848c7176621f02b2ced77d56572932ebd4e4 /tests/ColorSpaceTest.cpp | |
parent | 05dceabf3422b785b52439378aa5527c42c6ca18 (diff) |
Enable flattening and unflattening of SkColorSpace
BUG=skia:
GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2085653003
Review-Url: https://codereview.chromium.org/2085653003
Diffstat (limited to 'tests/ColorSpaceTest.cpp')
-rw-r--r-- | tests/ColorSpaceTest.cpp | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/tests/ColorSpaceTest.cpp b/tests/ColorSpaceTest.cpp index 4b39ab02c6..853bdceb4f 100644 --- a/tests/ColorSpaceTest.cpp +++ b/tests/ColorSpaceTest.cpp @@ -165,3 +165,41 @@ DEF_TEST(ColorSpace_Named, r) { SkImageInfo info = SkImageInfo::MakeS32(10, 10, kPremul_SkAlphaType); REPORTER_ASSERT(r, info.gammaCloseToSRGB()); } + +static void test_serialize(skiatest::Reporter* r, SkColorSpace* space, bool isNamed) { + sk_sp<SkData> data = space->serialize(); + sk_sp<SkColorSpace> newSpace = SkColorSpace::Deserialize(data->data(), data->size()); + + if (isNamed) { + REPORTER_ASSERT(r, space == newSpace.get()); + } else { + REPORTER_ASSERT(r, space->gammaNamed() == newSpace->gammaNamed()); + + REPORTER_ASSERT(r, space->xyz().getFloat(0, 0) == newSpace->xyz().getFloat(0, 0)); + REPORTER_ASSERT(r, space->xyz().getFloat(0, 1) == newSpace->xyz().getFloat(0, 1)); + REPORTER_ASSERT(r, space->xyz().getFloat(0, 2) == newSpace->xyz().getFloat(0, 2)); + REPORTER_ASSERT(r, space->xyz().getFloat(0, 3) == newSpace->xyz().getFloat(0, 3)); + REPORTER_ASSERT(r, space->xyz().getFloat(1, 0) == newSpace->xyz().getFloat(1, 0)); + REPORTER_ASSERT(r, space->xyz().getFloat(1, 1) == newSpace->xyz().getFloat(1, 1)); + REPORTER_ASSERT(r, space->xyz().getFloat(1, 2) == newSpace->xyz().getFloat(1, 2)); + REPORTER_ASSERT(r, space->xyz().getFloat(1, 3) == newSpace->xyz().getFloat(1, 3)); + REPORTER_ASSERT(r, space->xyz().getFloat(2, 0) == newSpace->xyz().getFloat(2, 0)); + REPORTER_ASSERT(r, space->xyz().getFloat(2, 1) == newSpace->xyz().getFloat(2, 1)); + REPORTER_ASSERT(r, space->xyz().getFloat(2, 2) == newSpace->xyz().getFloat(2, 2)); + REPORTER_ASSERT(r, space->xyz().getFloat(2, 3) == newSpace->xyz().getFloat(2, 3)); + REPORTER_ASSERT(r, space->xyz().getFloat(3, 0) == newSpace->xyz().getFloat(3, 0)); + REPORTER_ASSERT(r, space->xyz().getFloat(3, 1) == newSpace->xyz().getFloat(3, 1)); + REPORTER_ASSERT(r, space->xyz().getFloat(3, 2) == newSpace->xyz().getFloat(3, 2)); + REPORTER_ASSERT(r, space->xyz().getFloat(3, 3) == newSpace->xyz().getFloat(3, 3)); + } +} + +DEF_TEST(ColorSpace_Serialize, r) { + test_serialize(r, SkColorSpace::NewNamed(SkColorSpace::kSRGB_Named).get(), true); + test_serialize(r, SkColorSpace::NewNamed(SkColorSpace::kAdobeRGB_Named).get(), true); + + sk_sp<SkData> monitorData = SkData::MakeFromFileName( + GetResourcePath("monitor_profiles/HP_ZR30w.icc").c_str()); + test_serialize(r, SkColorSpace::NewICC(monitorData->data(), monitorData->size()).get(), false); +} + |