Chromium Code Reviews| Index: core/fxge/skia/fx_skia_device_unittest.cpp |
| diff --git a/core/fxge/skia/fx_skia_device_unittest.cpp b/core/fxge/skia/fx_skia_device_unittest.cpp |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..eb7559b5e2348ee3dc435155c25c9caf8dff2ca0 |
| --- /dev/null |
| +++ b/core/fxge/skia/fx_skia_device_unittest.cpp |
| @@ -0,0 +1,164 @@ |
| +// Copyright 2016 PDFium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "core/fxge/include/fx_ge.h" |
| +#include "core/fxge/skia/fx_skia_device.h" |
| +#include "fpdfsdk/include/fsdk_define.h" |
| +#include "public/fpdfview.h" |
| +#include "testing/fx_string_testhelpers.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| +#include "third_party/skia/include/core/SkPictureRecorder.h" |
| + |
| +namespace { |
| + |
| +struct State { |
| + enum class Change { kNo, kYes }; |
| + enum class Save { kNo, kYes }; |
| + enum class Clip { kNo, kSame, kDifferentPath, kDifferentMatrix }; |
| + enum class Graphic { kNone, kPath, kText }; |
| + |
| + Change m_change; |
| + Save m_save; |
| + Clip m_clip; |
| + Graphic m_graphic; |
| + uint32_t m_pixel; |
| +}; |
| + |
| +void EmptyTest(CFX_SkiaDeviceDriver* driver, const State&) { |
| + driver->SaveState(); |
| + driver->RestoreState(true); |
| + driver->RestoreState(false); |
| +} |
| + |
| +void CommonTest(CFX_SkiaDeviceDriver* driver, const State& state) { |
| + FXTEXT_CHARPOS charPos[] = {1, 0, 1, 4, false, {0, 0, 0, 0}, false}; |
| + CFX_Font font; |
| + FX_FLOAT fontSize = 1; |
| + CFX_FontCache cache; |
| + CFX_PathData clipPath, clipPath2; |
| + clipPath.AppendRect(0, 0, 3, 1); |
| + clipPath2.AppendRect(0, 0, 2, 1); |
| + CFX_Matrix clipMatrix; |
| + CFX_Matrix clipMatrix2(1, 0, 0, 1, 0, 1); |
| + driver->SaveState(); |
| + CFX_PathData path1; |
| + path1.AppendRect(0, 0, 1, 2); |
| + CFX_Matrix matrix, matrix2; |
| + matrix2.Translate(1, 0); |
| + CFX_GraphStateData graphState; |
| + if (state.m_save == State::Save::kYes) |
| + driver->SaveState(); |
| + if (state.m_clip != State::Clip::kNo) |
| + driver->SetClip_PathFill(&clipPath, &clipMatrix, 0); |
| + if (state.m_graphic == State::Graphic::kPath) { |
| + driver->DrawPath(&path1, &matrix, &graphState, 0xFF112233, 0, |
| + FXFILL_WINDING, 0); |
| + } else if (state.m_graphic == State::Graphic::kText) { |
| + driver->DrawDeviceText(SK_ARRAY_COUNT(charPos), charPos, &font, &cache, |
| + &matrix, fontSize, 0xFF445566); |
| + } |
| + if (state.m_save == State::Save::kYes) |
| + driver->RestoreState(true); |
| + CFX_PathData path2; |
| + path2.AppendRect(0, 0, 2, 2); |
| + if (state.m_change == State::Change::kYes) { |
| + if (state.m_graphic == State::Graphic::kPath) |
| + graphState.m_LineCap = CFX_GraphStateData::LineCapRound; |
| + else if (state.m_graphic == State::Graphic::kText) |
| + fontSize = 2; |
| + } |
| + if (state.m_clip == State::Clip::kSame) |
| + driver->SetClip_PathFill(&clipPath, &clipMatrix, 0); |
| + else if (state.m_clip == State::Clip::kDifferentPath) |
| + driver->SetClip_PathFill(&clipPath2, &clipMatrix, 0); |
| + else if (state.m_clip == State::Clip::kDifferentMatrix) |
| + driver->SetClip_PathFill(&clipPath, &clipMatrix2, 0); |
| + if (state.m_graphic == State::Graphic::kPath) { |
| + driver->DrawPath(&path2, &matrix2, &graphState, 0xFF112233, 0, |
| + FXFILL_WINDING, 0); |
| + } else if (state.m_graphic == State::Graphic::kText) { |
| + driver->DrawDeviceText(SK_ARRAY_COUNT(charPos), charPos, &font, &cache, |
| + &matrix2, fontSize, 0xFF445566); |
| + } |
| + if (state.m_save == State::Save::kYes) |
| + driver->RestoreState(false); |
| + driver->RestoreState(false); |
| +} |
| + |
| +void OutOfSequenceClipTest(CFX_SkiaDeviceDriver* driver, const State&) { |
| + CFX_PathData clipPath; |
| + clipPath.AppendRect(1, 0, 3, 1); |
| + CFX_Matrix clipMatrix; |
| + driver->SaveState(); |
| + driver->SetClip_PathFill(&clipPath, &clipMatrix, 0); |
| + driver->RestoreState(true); |
| + driver->SaveState(); |
| + driver->SetClip_PathFill(&clipPath, &clipMatrix, 0); |
| + driver->RestoreState(false); |
| + driver->RestoreState(false); |
| + |
| + driver->SaveState(); |
| + driver->SaveState(); |
| + driver->SetClip_PathFill(&clipPath, &clipMatrix, 0); |
| + driver->RestoreState(true); |
| + driver->SetClip_PathFill(&clipPath, &clipMatrix, 0); |
| + driver->RestoreState(false); |
| + driver->RestoreState(false); |
| +} |
| + |
| +void Harness(void (*Test)(CFX_SkiaDeviceDriver*, const State&), |
| + const State& state) { |
| + int h = 1; |
| + int w = 4; |
| + FPDF_BITMAP bitmap = FPDFBitmap_Create(w, h, 1); |
|
Lei Zhang
2016/06/29 18:53:51
Just create a CFX_DIBitmap instead? That's what yo
caryclark
2016/06/29 19:25:40
I copied the code construction used by pdfium_test
|
| + EXPECT_NE(nullptr, bitmap); |
| + if (!bitmap) |
| + return; |
| + FPDFBitmap_FillRect(bitmap, 0, 0, w, h, 0x00000000); |
| + CFX_FxgeDevice geDevice; |
| + CFX_DIBitmap* pBitmap = CFXBitmapFromFPDFBitmap(bitmap); |
| + geDevice.Attach(pBitmap, false, nullptr, false); |
| + CFX_SkiaDeviceDriver* driver = |
| + static_cast<CFX_SkiaDeviceDriver*>(geDevice.GetDeviceDriver()); |
| + (*Test)(driver, state); |
| + driver->Flush(); |
| + uint32_t pixel = pBitmap->GetPixel(0, 0); |
| + EXPECT_EQ(state.m_pixel, pixel); |
| +#ifdef SK_DEBUG |
| + if (!driver) // force dump to be linked in so it can be called from debugger |
| + driver->Dump(); |
| +#endif |
| +} |
| + |
| +} // namespace |
| + |
| +TEST(fxge, SkiaStateEmpty) { |
| + Harness(&EmptyTest, {}); |
| +} |
| + |
| +TEST(fxge, SkiaStatePath) { |
| + Harness(&CommonTest, {State::Change::kNo, State::Save::kYes, |
| + State::Clip::kSame, State::Graphic::kPath, 0xFF112233}); |
| + Harness(&CommonTest, |
| + {State::Change::kNo, State::Save::kYes, State::Clip::kDifferentPath, |
| + State::Graphic::kPath, 0xFF112233}); |
| + Harness(&CommonTest, {State::Change::kNo, State::Save::kYes, State::Clip::kNo, |
| + State::Graphic::kPath, 0xFF112233}); |
| + Harness(&CommonTest, {State::Change::kYes, State::Save::kNo, State::Clip::kNo, |
| + State::Graphic::kPath, 0xFF112233}); |
| + Harness(&CommonTest, {State::Change::kNo, State::Save::kNo, State::Clip::kNo, |
| + State::Graphic::kPath, 0xFF112233}); |
| +} |
| + |
| +TEST(fxge, SkiaStateText) { |
| + Harness(&CommonTest, |
| + {State::Change::kNo, State::Save::kYes, State::Clip::kDifferentMatrix, |
| + State::Graphic::kText, 0xFF445566}); |
| + Harness(&CommonTest, {State::Change::kNo, State::Save::kYes, |
| + State::Clip::kSame, State::Graphic::kText, 0xFF445566}); |
| +} |
| + |
| +TEST(fxge, SkiaStateOOSClip) { |
| + Harness(&OutOfSequenceClipTest, {}); |
| +} |