Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(668)

Side by Side Diff: ui/ozone/platform/dri/dri_surface_factory_unittest.cc

Issue 393233005: [Ozone-DRI] Convert HardwareDisplayController to use scanout buffers (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include <vector> 5 #include <vector>
6 6
7 #include "base/memory/scoped_ptr.h" 7 #include "base/memory/scoped_ptr.h"
8 #include "base/message_loop/message_loop.h" 8 #include "base/message_loop/message_loop.h"
9 #include "testing/gtest/include/gtest/gtest.h" 9 #include "testing/gtest/include/gtest/gtest.h"
10 #include "third_party/skia/include/core/SkCanvas.h" 10 #include "third_party/skia/include/core/SkCanvas.h"
11 #include "third_party/skia/include/core/SkColor.h" 11 #include "third_party/skia/include/core/SkColor.h"
12 #include "third_party/skia/include/core/SkImageInfo.h" 12 #include "third_party/skia/include/core/SkImageInfo.h"
13 #include "ui/ozone/platform/dri/dri_buffer.h" 13 #include "ui/ozone/platform/dri/dri_buffer.h"
14 #include "ui/ozone/platform/dri/dri_surface.h" 14 #include "ui/ozone/platform/dri/dri_surface.h"
15 #include "ui/ozone/platform/dri/dri_surface_factory.h" 15 #include "ui/ozone/platform/dri/dri_surface_factory.h"
16 #include "ui/ozone/platform/dri/hardware_display_controller.h" 16 #include "ui/ozone/platform/dri/hardware_display_controller.h"
17 #include "ui/ozone/platform/dri/screen_manager.h" 17 #include "ui/ozone/platform/dri/screen_manager.h"
18 #include "ui/ozone/platform/dri/test/mock_dri_wrapper.h" 18 #include "ui/ozone/platform/dri/test/mock_dri_wrapper.h"
19 #include "ui/ozone/platform/dri/test/mock_surface_generator.h"
20 #include "ui/ozone/public/surface_factory_ozone.h" 19 #include "ui/ozone/public/surface_factory_ozone.h"
21 #include "ui/ozone/public/surface_ozone_canvas.h" 20 #include "ui/ozone/public/surface_ozone_canvas.h"
22 21
23 namespace { 22 namespace {
24 23
24 // Mode of size 6x4.
25 const drmModeModeInfo kDefaultMode = 25 const drmModeModeInfo kDefaultMode =
26 {0, 6, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, {'\0'}}; 26 {0, 6, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, {'\0'}};
27 27
28 class MockScreenManager : public ui::ScreenManager { 28 class MockScreenManager : public ui::ScreenManager {
29 public: 29 public:
30 MockScreenManager(ui::DriWrapper* dri, 30 MockScreenManager(ui::DriWrapper* dri,
31 ui::ScanoutSurfaceGenerator* surface_generator) 31 ui::ScanoutBufferGenerator* buffer_generator)
32 : ScreenManager(dri, surface_generator), 32 : ScreenManager(dri, buffer_generator),
33 dri_(dri) {} 33 dri_(dri) {}
34 virtual ~MockScreenManager() {} 34 virtual ~MockScreenManager() {}
35 35
36 // Normally we'd use DRM to figure out the controller configuration. But we 36 // Normally we'd use DRM to figure out the controller configuration. But we
37 // can't use DRM in unit tests, so we just create a fake configuration. 37 // can't use DRM in unit tests, so we just create a fake configuration.
38 virtual void ForceInitializationOfPrimaryDisplay() OVERRIDE { 38 virtual void ForceInitializationOfPrimaryDisplay() OVERRIDE {
39 ConfigureDisplayController(1, 2, kDefaultMode); 39 ConfigureDisplayController(1, 2, kDefaultMode);
40 } 40 }
41 41
42 private: 42 private:
43 ui::DriWrapper* dri_; // Not owned. 43 ui::DriWrapper* dri_; // Not owned.
44 44
45 DISALLOW_COPY_AND_ASSIGN(MockScreenManager); 45 DISALLOW_COPY_AND_ASSIGN(MockScreenManager);
46 }; 46 };
47 47
48 } // namespace 48 } // namespace
49 49
50 class DriSurfaceFactoryTest : public testing::Test { 50 class DriSurfaceFactoryTest : public testing::Test {
51 public: 51 public:
52 DriSurfaceFactoryTest() {} 52 DriSurfaceFactoryTest() {}
53 53
54 virtual void SetUp() OVERRIDE; 54 virtual void SetUp() OVERRIDE;
55 virtual void TearDown() OVERRIDE; 55 virtual void TearDown() OVERRIDE;
56 protected: 56 protected:
57 scoped_ptr<base::MessageLoop> message_loop_; 57 scoped_ptr<base::MessageLoop> message_loop_;
58 scoped_ptr<ui::MockDriWrapper> dri_; 58 scoped_ptr<ui::MockDriWrapper> dri_;
59 scoped_ptr<ui::MockSurfaceGenerator> surface_generator_; 59 scoped_ptr<ui::DriBufferGenerator> buffer_generator_;
60 scoped_ptr<MockScreenManager> screen_manager_; 60 scoped_ptr<MockScreenManager> screen_manager_;
61 scoped_ptr<ui::DriSurfaceFactory> factory_; 61 scoped_ptr<ui::DriSurfaceFactory> factory_;
62 62
63 private: 63 private:
64 DISALLOW_COPY_AND_ASSIGN(DriSurfaceFactoryTest); 64 DISALLOW_COPY_AND_ASSIGN(DriSurfaceFactoryTest);
65 }; 65 };
66 66
67 void DriSurfaceFactoryTest::SetUp() { 67 void DriSurfaceFactoryTest::SetUp() {
68 message_loop_.reset(new base::MessageLoopForUI); 68 message_loop_.reset(new base::MessageLoopForUI);
69 dri_.reset(new ui::MockDriWrapper(3)); 69 dri_.reset(new ui::MockDriWrapper(3));
70 surface_generator_.reset(new ui::MockSurfaceGenerator(dri_.get())); 70 buffer_generator_.reset(new ui::DriBufferGenerator(dri_.get()));
71 screen_manager_.reset(new MockScreenManager(dri_.get(), 71 screen_manager_.reset(new MockScreenManager(dri_.get(),
72 surface_generator_.get())); 72 buffer_generator_.get()));
73 factory_.reset(new ui::DriSurfaceFactory(dri_.get(), screen_manager_.get())); 73 factory_.reset(new ui::DriSurfaceFactory(dri_.get(), screen_manager_.get()));
74 } 74 }
75 75
76 void DriSurfaceFactoryTest::TearDown() { 76 void DriSurfaceFactoryTest::TearDown() {
77 factory_.reset(); 77 factory_.reset();
78 message_loop_.reset(); 78 message_loop_.reset();
79 } 79 }
80 80
81 TEST_F(DriSurfaceFactoryTest, FailInitialization) { 81 TEST_F(DriSurfaceFactoryTest, FailInitialization) {
82 dri_->fail_init(); 82 dri_->fail_init();
(...skipping 30 matching lines...) Expand all
113 113
114 SkPaint paint; 114 SkPaint paint;
115 paint.setColor(SK_ColorWHITE); 115 paint.setColor(SK_ColorWHITE);
116 SkRect rect = SkRect::MakeWH(kDefaultMode.hdisplay / 2, 116 SkRect rect = SkRect::MakeWH(kDefaultMode.hdisplay / 2,
117 kDefaultMode.vdisplay / 2); 117 kDefaultMode.vdisplay / 2);
118 surface->GetCanvas()->drawRect(rect, paint); 118 surface->GetCanvas()->drawRect(rect, paint);
119 surface->PresentCanvas( 119 surface->PresentCanvas(
120 gfx::Rect(0, 0, kDefaultMode.hdisplay / 2, kDefaultMode.vdisplay / 2)); 120 gfx::Rect(0, 0, kDefaultMode.hdisplay / 2, kDefaultMode.vdisplay / 2));
121 121
122 SkBitmap image; 122 SkBitmap image;
123 // Buffers 0 and 1 are the cursor buffers and 2 and 3 are the surface buffers. 123 // Buffers 0 and 1 are the cursor buffers, 2 is the modeset buffer, and
124 // Buffer 3 is the backbuffer we just painted in, so we want to make sure its 124 // 3 and 4 are the surface buffers.
125 // Buffer 4 is the backbuffer we just painted in, so we want to make sure its
125 // contents are correct. 126 // contents are correct.
126 image.setInfo(dri_->buffers()[3]->getCanvas()->imageInfo()); 127 image.setInfo(dri_->buffers()[4]->getCanvas()->imageInfo());
127 EXPECT_TRUE(dri_->buffers()[3]->getCanvas()->readPixels(&image, 0, 0)); 128 EXPECT_TRUE(dri_->buffers()[4]->getCanvas()->readPixels(&image, 0, 0));
128 129
129 EXPECT_EQ(kDefaultMode.hdisplay, image.width()); 130 EXPECT_EQ(kDefaultMode.hdisplay, image.width());
130 EXPECT_EQ(kDefaultMode.vdisplay, image.height()); 131 EXPECT_EQ(kDefaultMode.vdisplay, image.height());
131 132
132 // Make sure the updates are correctly propagated to the native surface. 133 // Make sure the updates are correctly propagated to the native surface.
133 for (int i = 0; i < image.height(); ++i) { 134 for (int i = 0; i < image.height(); ++i) {
134 for (int j = 0; j < image.width(); ++j) { 135 for (int j = 0; j < image.width(); ++j) {
135 if (j < kDefaultMode.hdisplay / 2 && i < kDefaultMode.vdisplay / 2) 136 if (j < kDefaultMode.hdisplay / 2 && i < kDefaultMode.vdisplay / 2)
136 EXPECT_EQ(SK_ColorWHITE, image.getColor(j, i)); 137 EXPECT_EQ(SK_ColorWHITE, image.getColor(j, i));
137 else 138 else
(...skipping 29 matching lines...) Expand all
167 for (int i = 0; i < cursor.height(); ++i) { 168 for (int i = 0; i < cursor.height(); ++i) {
168 for (int j = 0; j < cursor.width(); ++j) { 169 for (int j = 0; j < cursor.width(); ++j) {
169 if (j < info.width() && i < info.height()) 170 if (j < info.width() && i < info.height())
170 EXPECT_EQ(SK_ColorWHITE, cursor.getColor(j, i)); 171 EXPECT_EQ(SK_ColorWHITE, cursor.getColor(j, i));
171 else 172 else
172 EXPECT_EQ(static_cast<SkColor>(SK_ColorTRANSPARENT), 173 EXPECT_EQ(static_cast<SkColor>(SK_ColorTRANSPARENT),
173 cursor.getColor(j, i)); 174 cursor.getColor(j, i));
174 } 175 }
175 } 176 }
176 } 177 }
OLDNEW
« no previous file with comments | « ui/ozone/platform/dri/dri_surface_factory.cc ('k') | ui/ozone/platform/dri/dri_surface_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698