| Index: ui/ozone/platform/dri/dri_surface_unittest.cc
|
| diff --git a/ui/ozone/platform/dri/dri_surface_unittest.cc b/ui/ozone/platform/dri/dri_surface_unittest.cc
|
| index 34a5bc98bad85525cdf66b105819a41e31c4d9bb..f66060f8b97575baae73b40728a5fe1f2d126dfa 100644
|
| --- a/ui/ozone/platform/dri/dri_surface_unittest.cc
|
| +++ b/ui/ozone/platform/dri/dri_surface_unittest.cc
|
| @@ -2,6 +2,7 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| +#include "base/message_loop/message_loop.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
| #include "third_party/skia/include/core/SkCanvas.h"
|
| #include "third_party/skia/include/core/SkColor.h"
|
| @@ -27,6 +28,7 @@ class DriSurfaceTest : public testing::Test {
|
| virtual void TearDown() OVERRIDE;
|
|
|
| protected:
|
| + scoped_ptr<base::MessageLoop> message_loop_;
|
| scoped_ptr<ui::MockDriWrapper> drm_;
|
| scoped_ptr<ui::HardwareDisplayController> controller_;
|
| scoped_ptr<ui::DriSurface> surface_;
|
| @@ -36,51 +38,63 @@ class DriSurfaceTest : public testing::Test {
|
| };
|
|
|
| void DriSurfaceTest::SetUp() {
|
| + message_loop_.reset(new base::MessageLoopForUI);
|
| drm_.reset(new ui::MockDriWrapper(3));
|
| - controller_.reset(new ui::HardwareDisplayController(drm_.get(), 1, 1));
|
|
|
| - surface_.reset(new ui::DriSurface(
|
| - drm_.get(), gfx::Size(kDefaultMode.hdisplay, kDefaultMode.vdisplay)));
|
| + controller_.reset(new ui::HardwareDisplayController(drm_.get(), 1, 1));
|
| + scoped_refptr<ui::DriBuffer> buffer(new ui::DriBuffer(drm_.get()));
|
| + SkImageInfo info = SkImageInfo::MakeN32Premul(kDefaultMode.hdisplay,
|
| + kDefaultMode.vdisplay);
|
| + EXPECT_TRUE(buffer->Initialize(info));
|
| + EXPECT_TRUE(controller_->Modeset(ui::OverlayPlane(buffer), kDefaultMode));
|
| +
|
| + surface_.reset(new ui::DriSurface(drm_.get(), controller_->AsWeakPtr()));
|
| + surface_->ResizeCanvas(gfx::Size(kDefaultMode.hdisplay,
|
| + kDefaultMode.vdisplay));
|
| }
|
|
|
| void DriSurfaceTest::TearDown() {
|
| surface_.reset();
|
| controller_.reset();
|
| drm_.reset();
|
| -}
|
| -
|
| -TEST_F(DriSurfaceTest, FailInitialization) {
|
| - drm_->set_create_dumb_buffer_expectation(false);
|
| - EXPECT_FALSE(surface_->Initialize());
|
| -}
|
| -
|
| -TEST_F(DriSurfaceTest, SuccessfulInitialization) {
|
| - EXPECT_TRUE(surface_->Initialize());
|
| + message_loop_.reset();
|
| }
|
|
|
| TEST_F(DriSurfaceTest, CheckFBIDOnSwap) {
|
| - EXPECT_TRUE(surface_->Initialize());
|
| -
|
| - // Check that the framebuffer ID is correct.
|
| - EXPECT_EQ(2u, surface_->GetFramebufferId());
|
| -
|
| - surface_->SwapBuffers();
|
| -
|
| - EXPECT_EQ(1u, surface_->GetFramebufferId());
|
| + surface_->PresentCanvas(gfx::Rect());
|
| + // Framebuffer ID 1 is allocated in SetUp for the buffer used to modeset.
|
| + EXPECT_EQ(3u, drm_->current_framebuffer());
|
| + surface_->PresentCanvas(gfx::Rect());
|
| + EXPECT_EQ(2u, drm_->current_framebuffer());
|
| }
|
|
|
| -TEST_F(DriSurfaceTest, CheckPixelPointerOnSwap) {
|
| - EXPECT_TRUE(surface_->Initialize());
|
| -
|
| - void* bitmap_pixels1 = surface_->GetDrawableForWidget()->getDevice()
|
| - ->accessBitmap(false).getPixels();
|
| -
|
| - surface_->SwapBuffers();
|
| -
|
| - void* bitmap_pixels2 = surface_->GetDrawableForWidget()->getDevice()
|
| - ->accessBitmap(false).getPixels();
|
| -
|
| - // Check that once the buffers have been swapped the drawable's underlying
|
| - // pixels have been changed.
|
| - EXPECT_NE(bitmap_pixels1, bitmap_pixels2);
|
| +TEST_F(DriSurfaceTest, CheckSurfaceContents) {
|
| + SkPaint paint;
|
| + paint.setColor(SK_ColorWHITE);
|
| + SkRect rect = SkRect::MakeWH(kDefaultMode.hdisplay / 2,
|
| + kDefaultMode.vdisplay / 2);
|
| + surface_->GetCanvas()->drawRect(rect, paint);
|
| + surface_->PresentCanvas(
|
| + gfx::Rect(0, 0, kDefaultMode.hdisplay / 2, kDefaultMode.vdisplay / 2));
|
| +
|
| + SkBitmap image;
|
| + // Buffer 0 is the buffer used in SetUp for modesetting and buffer 1 is the
|
| + // frontbuffer.
|
| + // Buffer 2 is the backbuffer we just painted in, so we want to make sure its
|
| + // contents are correct.
|
| + image.setInfo(drm_->buffers()[2]->getCanvas()->imageInfo());
|
| + EXPECT_TRUE(drm_->buffers()[2]->getCanvas()->readPixels(&image, 0, 0));
|
| +
|
| + EXPECT_EQ(kDefaultMode.hdisplay, image.width());
|
| + EXPECT_EQ(kDefaultMode.vdisplay, image.height());
|
| +
|
| + // Make sure the updates are correctly propagated to the native surface.
|
| + for (int i = 0; i < image.height(); ++i) {
|
| + for (int j = 0; j < image.width(); ++j) {
|
| + if (j < kDefaultMode.hdisplay / 2 && i < kDefaultMode.vdisplay / 2)
|
| + EXPECT_EQ(SK_ColorWHITE, image.getColor(j, i));
|
| + else
|
| + EXPECT_EQ(SK_ColorBLACK, image.getColor(j, i));
|
| + }
|
| + }
|
| }
|
|
|