| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "blimp/engine/app/ui/blimp_screen.h" | 5 #include "blimp/engine/app/ui/blimp_screen.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
| 12 #include "base/files/file_util.h" | 12 #include "base/files/file_util.h" |
| 13 #include "base/files/scoped_temp_dir.h" | 13 #include "base/files/scoped_temp_dir.h" |
| 14 #include "base/memory/ptr_util.h" | 14 #include "base/memory/ptr_util.h" |
| 15 #include "base/strings/stringprintf.h" | 15 #include "base/strings/stringprintf.h" |
| 16 #include "blimp/engine/app/switches.h" | 16 #include "blimp/engine/app/switches.h" |
| 17 #include "testing/gmock/include/gmock/gmock.h" | 17 #include "testing/gmock/include/gmock/gmock.h" |
| 18 #include "testing/gtest/include/gtest/gtest.h" | 18 #include "testing/gtest/include/gtest/gtest.h" |
| 19 #include "ui/gfx/display.h" | 19 #include "ui/display/display.h" |
| 20 #include "ui/gfx/display_observer.h" | 20 #include "ui/display/display_observer.h" |
| 21 #include "ui/gfx/screen.h" | 21 #include "ui/display/screen.h" |
| 22 | 22 |
| 23 using testing::InSequence; | 23 using testing::InSequence; |
| 24 | 24 |
| 25 namespace blimp { | 25 namespace blimp { |
| 26 namespace engine { | 26 namespace engine { |
| 27 namespace { | 27 namespace { |
| 28 | 28 |
| 29 // Checks if two gfx::Displays have the ID. | 29 // Checks if two display::Displays have the ID. |
| 30 MATCHER_P(EqualsDisplay, display, "") { | 30 MATCHER_P(EqualsDisplay, display, "") { |
| 31 return display.id() == arg.id(); | 31 return display.id() == arg.id(); |
| 32 } | 32 } |
| 33 | 33 |
| 34 class MockDisplayObserver : public gfx::DisplayObserver { | 34 class MockDisplayObserver : public display::DisplayObserver { |
| 35 public: | 35 public: |
| 36 MockDisplayObserver() {} | 36 MockDisplayObserver() {} |
| 37 ~MockDisplayObserver() override {} | 37 ~MockDisplayObserver() override {} |
| 38 | 38 |
| 39 MOCK_METHOD1(OnDisplayAdded, void(const gfx::Display&)); | 39 MOCK_METHOD1(OnDisplayAdded, void(const display::Display&)); |
| 40 MOCK_METHOD1(OnDisplayRemoved, void(const gfx::Display&)); | 40 MOCK_METHOD1(OnDisplayRemoved, void(const display::Display&)); |
| 41 MOCK_METHOD2(OnDisplayMetricsChanged, | 41 MOCK_METHOD2(OnDisplayMetricsChanged, |
| 42 void(const gfx::Display& display, uint32_t changed_metrics)); | 42 void(const display::Display& display, uint32_t changed_metrics)); |
| 43 }; | 43 }; |
| 44 | 44 |
| 45 class BlimpScreenTest : public testing::Test { | 45 class BlimpScreenTest : public testing::Test { |
| 46 protected: | 46 protected: |
| 47 void SetUp() override { | 47 void SetUp() override { |
| 48 screen_ = base::WrapUnique(new BlimpScreen); | 48 screen_ = base::WrapUnique(new BlimpScreen); |
| 49 screen_->AddObserver(&observer1_); | 49 screen_->AddObserver(&observer1_); |
| 50 screen_->AddObserver(&observer2_); | 50 screen_->AddObserver(&observer2_); |
| 51 } | 51 } |
| 52 | 52 |
| 53 std::unique_ptr<BlimpScreen> screen_; | 53 std::unique_ptr<BlimpScreen> screen_; |
| 54 testing::StrictMock<MockDisplayObserver> observer1_; | 54 testing::StrictMock<MockDisplayObserver> observer1_; |
| 55 testing::StrictMock<MockDisplayObserver> observer2_; | 55 testing::StrictMock<MockDisplayObserver> observer2_; |
| 56 }; | 56 }; |
| 57 | 57 |
| 58 TEST_F(BlimpScreenTest, ObserversAreInfomed) { | 58 TEST_F(BlimpScreenTest, ObserversAreInfomed) { |
| 59 auto display = screen_->GetPrimaryDisplay(); | 59 auto display = screen_->GetPrimaryDisplay(); |
| 60 uint32_t changed_metrics = | 60 uint32_t changed_metrics = |
| 61 gfx::DisplayObserver::DISPLAY_METRIC_DEVICE_SCALE_FACTOR | | 61 display::DisplayObserver::DISPLAY_METRIC_DEVICE_SCALE_FACTOR | |
| 62 gfx::DisplayObserver::DISPLAY_METRIC_BOUNDS; | 62 display::DisplayObserver::DISPLAY_METRIC_BOUNDS; |
| 63 | 63 |
| 64 InSequence s; | 64 InSequence s; |
| 65 EXPECT_CALL(observer1_, | 65 EXPECT_CALL(observer1_, |
| 66 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); | 66 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); |
| 67 EXPECT_CALL(observer2_, | 67 EXPECT_CALL(observer2_, |
| 68 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); | 68 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); |
| 69 | 69 |
| 70 changed_metrics = gfx::DisplayObserver::DISPLAY_METRIC_BOUNDS; | 70 changed_metrics = display::DisplayObserver::DISPLAY_METRIC_BOUNDS; |
| 71 EXPECT_CALL(observer1_, | 71 EXPECT_CALL(observer1_, |
| 72 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); | 72 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); |
| 73 EXPECT_CALL(observer2_, | 73 EXPECT_CALL(observer2_, |
| 74 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); | 74 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); |
| 75 | 75 |
| 76 changed_metrics = gfx::DisplayObserver::DISPLAY_METRIC_DEVICE_SCALE_FACTOR; | 76 changed_metrics = |
| 77 display::DisplayObserver::DISPLAY_METRIC_DEVICE_SCALE_FACTOR; |
| 77 EXPECT_CALL(observer1_, | 78 EXPECT_CALL(observer1_, |
| 78 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); | 79 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); |
| 79 EXPECT_CALL(observer2_, | 80 EXPECT_CALL(observer2_, |
| 80 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); | 81 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); |
| 81 | 82 |
| 82 gfx::Size size1(100, 200); | 83 gfx::Size size1(100, 200); |
| 83 screen_->UpdateDisplayScaleAndSize(2.0f, size1); | 84 screen_->UpdateDisplayScaleAndSize(2.0f, size1); |
| 84 EXPECT_EQ(size1, screen_->GetPrimaryDisplay().GetSizeInPixel()); | 85 EXPECT_EQ(size1, screen_->GetPrimaryDisplay().GetSizeInPixel()); |
| 85 EXPECT_EQ(2.0f, screen_->GetPrimaryDisplay().device_scale_factor()); | 86 EXPECT_EQ(2.0f, screen_->GetPrimaryDisplay().device_scale_factor()); |
| 86 | 87 |
| 87 screen_->UpdateDisplayScaleAndSize(2.0f, size1); | 88 screen_->UpdateDisplayScaleAndSize(2.0f, size1); |
| 88 | 89 |
| 89 gfx::Size size2(200, 100); | 90 gfx::Size size2(200, 100); |
| 90 screen_->UpdateDisplayScaleAndSize(2.0f, size2); | 91 screen_->UpdateDisplayScaleAndSize(2.0f, size2); |
| 91 EXPECT_EQ(size2, screen_->GetPrimaryDisplay().GetSizeInPixel()); | 92 EXPECT_EQ(size2, screen_->GetPrimaryDisplay().GetSizeInPixel()); |
| 92 EXPECT_EQ(2.0f, screen_->GetPrimaryDisplay().device_scale_factor()); | 93 EXPECT_EQ(2.0f, screen_->GetPrimaryDisplay().device_scale_factor()); |
| 93 | 94 |
| 94 screen_->UpdateDisplayScaleAndSize(3.0f, size2); | 95 screen_->UpdateDisplayScaleAndSize(3.0f, size2); |
| 95 EXPECT_EQ(3.0f, screen_->GetPrimaryDisplay().device_scale_factor()); | 96 EXPECT_EQ(3.0f, screen_->GetPrimaryDisplay().device_scale_factor()); |
| 96 } | 97 } |
| 97 | 98 |
| 98 TEST_F(BlimpScreenTest, RemoveObserver) { | 99 TEST_F(BlimpScreenTest, RemoveObserver) { |
| 99 screen_->RemoveObserver(&observer2_); | 100 screen_->RemoveObserver(&observer2_); |
| 100 auto display = screen_->GetPrimaryDisplay(); | 101 auto display = screen_->GetPrimaryDisplay(); |
| 101 uint32_t changed_metrics = | 102 uint32_t changed_metrics = |
| 102 gfx::DisplayObserver::DISPLAY_METRIC_DEVICE_SCALE_FACTOR | | 103 display::DisplayObserver::DISPLAY_METRIC_DEVICE_SCALE_FACTOR | |
| 103 gfx::DisplayObserver::DISPLAY_METRIC_BOUNDS; | 104 display::DisplayObserver::DISPLAY_METRIC_BOUNDS; |
| 104 EXPECT_CALL(observer1_, | 105 EXPECT_CALL(observer1_, |
| 105 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); | 106 OnDisplayMetricsChanged(EqualsDisplay(display), changed_metrics)); |
| 106 | 107 |
| 107 gfx::Size size1(100, 100); | 108 gfx::Size size1(100, 100); |
| 108 screen_->UpdateDisplayScaleAndSize(2.0f, size1); | 109 screen_->UpdateDisplayScaleAndSize(2.0f, size1); |
| 109 EXPECT_EQ(size1, screen_->GetPrimaryDisplay().GetSizeInPixel()); | 110 EXPECT_EQ(size1, screen_->GetPrimaryDisplay().GetSizeInPixel()); |
| 110 } | 111 } |
| 111 | 112 |
| 112 } // namespace | 113 } // namespace |
| 113 } // namespace engine | 114 } // namespace engine |
| 114 } // namespace blimp | 115 } // namespace blimp |
| OLD | NEW |