| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 "ui/views/widget/desktop_aura/desktop_screen_x11.h" | 5 #include "ui/views/widget/desktop_aura/desktop_screen_x11.h" |
| 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 "base/run_loop.h" | 9 #include "base/run_loop.h" |
| 10 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
| (...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 169 new views::DesktopNativeWidgetAura(toplevel); | 169 new views::DesktopNativeWidgetAura(toplevel); |
| 170 } | 170 } |
| 171 toplevel_params.bounds = bounds; | 171 toplevel_params.bounds = bounds; |
| 172 toplevel_params.remove_standard_frame = true; | 172 toplevel_params.remove_standard_frame = true; |
| 173 toplevel->Init(toplevel_params); | 173 toplevel->Init(toplevel_params); |
| 174 return toplevel; | 174 return toplevel; |
| 175 } | 175 } |
| 176 | 176 |
| 177 private: | 177 private: |
| 178 // Overridden from gfx::DisplayObserver: | 178 // Overridden from gfx::DisplayObserver: |
| 179 virtual void OnDisplayBoundsChanged(const gfx::Display& display) OVERRIDE { | |
| 180 changed_display_.push_back(display); | |
| 181 } | |
| 182 | |
| 183 virtual void OnDisplayAdded(const gfx::Display& new_display) OVERRIDE { | 179 virtual void OnDisplayAdded(const gfx::Display& new_display) OVERRIDE { |
| 184 added_display_.push_back(new_display); | 180 added_display_.push_back(new_display); |
| 185 } | 181 } |
| 186 | 182 |
| 187 virtual void OnDisplayRemoved(const gfx::Display& old_display) OVERRIDE { | 183 virtual void OnDisplayRemoved(const gfx::Display& old_display) OVERRIDE { |
| 188 removed_display_.push_back(old_display); | 184 removed_display_.push_back(old_display); |
| 189 } | 185 } |
| 190 | 186 |
| 187 virtual void OnDisplayMetricsChanged(const gfx::Display& display, |
| 188 DisplayObserver::MetricsType metrics) OVERRIDE { |
| 189 changed_display_.push_back(display); |
| 190 } |
| 191 |
| 191 scoped_ptr<DesktopScreenX11> screen_; | 192 scoped_ptr<DesktopScreenX11> screen_; |
| 192 | 193 |
| 193 DISALLOW_COPY_AND_ASSIGN(DesktopScreenX11Test); | 194 DISALLOW_COPY_AND_ASSIGN(DesktopScreenX11Test); |
| 194 }; | 195 }; |
| 195 | 196 |
| 196 TEST_F(DesktopScreenX11Test, BoundsChangeSingleMonitor) { | 197 TEST_F(DesktopScreenX11Test, BoundsChangeSingleMonitor) { |
| 197 std::vector<gfx::Display> displays; | 198 std::vector<gfx::Display> displays; |
| 198 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 1024, 768))); | 199 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 1024, 768))); |
| 199 screen()->ProcessDisplayChange(displays); | 200 screen()->ProcessDisplayChange(displays); |
| 200 | 201 |
| 201 EXPECT_EQ(1u, changed_display_.size()); | 202 EXPECT_EQ(1u, changed_display_.size()); |
| 202 EXPECT_EQ(0u, added_display_.size()); | 203 EXPECT_EQ(0u, added_display_.size()); |
| 203 EXPECT_EQ(0u, removed_display_.size()); | 204 EXPECT_EQ(0u, removed_display_.size()); |
| 204 } | 205 } |
| 205 | 206 |
| 206 TEST_F(DesktopScreenX11Test, AddMonitorToTheRight) { | 207 TEST_F(DesktopScreenX11Test, AddMonitorToTheRight) { |
| 207 std::vector<gfx::Display> displays; | 208 std::vector<gfx::Display> displays; |
| 208 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); | 209 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); |
| 209 displays.push_back(gfx::Display(kSecondDisplay, | 210 displays.push_back(gfx::Display(kSecondDisplay, |
| 210 gfx::Rect(640, 0, 1024, 768))); | 211 gfx::Rect(640, 0, 1024, 768))); |
| 211 screen()->ProcessDisplayChange(displays); | 212 screen()->ProcessDisplayChange(displays); |
| 212 | 213 |
| 213 EXPECT_EQ(0u, changed_display_.size()); | 214 EXPECT_EQ(1u, changed_display_.size()); |
| 214 EXPECT_EQ(1u, added_display_.size()); | 215 EXPECT_EQ(1u, added_display_.size()); |
| 215 EXPECT_EQ(0u, removed_display_.size()); | 216 EXPECT_EQ(0u, removed_display_.size()); |
| 216 } | 217 } |
| 217 | 218 |
| 218 TEST_F(DesktopScreenX11Test, AddMonitorToTheLeft) { | 219 TEST_F(DesktopScreenX11Test, AddMonitorToTheLeft) { |
| 219 std::vector<gfx::Display> displays; | 220 std::vector<gfx::Display> displays; |
| 220 displays.push_back(gfx::Display(kSecondDisplay, gfx::Rect(0, 0, 1024, 768))); | 221 displays.push_back(gfx::Display(kSecondDisplay, gfx::Rect(0, 0, 1024, 768))); |
| 221 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(1024, 0, 640, 480))); | 222 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(1024, 0, 640, 480))); |
| 222 screen()->ProcessDisplayChange(displays); | 223 screen()->ProcessDisplayChange(displays); |
| 223 | 224 |
| 224 EXPECT_EQ(1u, changed_display_.size()); | 225 EXPECT_EQ(1u, changed_display_.size()); |
| 225 EXPECT_EQ(1u, added_display_.size()); | 226 EXPECT_EQ(1u, added_display_.size()); |
| 226 EXPECT_EQ(0u, removed_display_.size()); | 227 EXPECT_EQ(0u, removed_display_.size()); |
| 227 } | 228 } |
| 228 | 229 |
| 229 TEST_F(DesktopScreenX11Test, RemoveMonitorOnRight) { | 230 TEST_F(DesktopScreenX11Test, RemoveMonitorOnRight) { |
| 230 std::vector<gfx::Display> displays; | 231 std::vector<gfx::Display> displays; |
| 231 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); | 232 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); |
| 232 displays.push_back(gfx::Display(kSecondDisplay, | 233 displays.push_back(gfx::Display(kSecondDisplay, |
| 233 gfx::Rect(640, 0, 1024, 768))); | 234 gfx::Rect(640, 0, 1024, 768))); |
| 234 screen()->ProcessDisplayChange(displays); | 235 screen()->ProcessDisplayChange(displays); |
| 235 | 236 |
| 236 ResetDisplayChanges(); | 237 ResetDisplayChanges(); |
| 237 | 238 |
| 238 displays.clear(); | 239 displays.clear(); |
| 239 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); | 240 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); |
| 240 screen()->ProcessDisplayChange(displays); | 241 screen()->ProcessDisplayChange(displays); |
| 241 | 242 |
| 242 EXPECT_EQ(0u, changed_display_.size()); | 243 EXPECT_EQ(1u, changed_display_.size()); |
| 243 EXPECT_EQ(0u, added_display_.size()); | 244 EXPECT_EQ(0u, added_display_.size()); |
| 244 EXPECT_EQ(1u, removed_display_.size()); | 245 EXPECT_EQ(1u, removed_display_.size()); |
| 245 } | 246 } |
| 246 | 247 |
| 247 TEST_F(DesktopScreenX11Test, RemoveMonitorOnLeft) { | 248 TEST_F(DesktopScreenX11Test, RemoveMonitorOnLeft) { |
| 248 std::vector<gfx::Display> displays; | 249 std::vector<gfx::Display> displays; |
| 249 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); | 250 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); |
| 250 displays.push_back(gfx::Display(kSecondDisplay, | 251 displays.push_back(gfx::Display(kSecondDisplay, |
| 251 gfx::Rect(640, 0, 1024, 768))); | 252 gfx::Rect(640, 0, 1024, 768))); |
| 252 screen()->ProcessDisplayChange(displays); | 253 screen()->ProcessDisplayChange(displays); |
| (...skipping 195 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 448 generator.PressRightButton(); | 449 generator.PressRightButton(); |
| 449 generator.ReleaseRightButton(); | 450 generator.ReleaseRightButton(); |
| 450 EXPECT_FALSE(rwh->IsMaximized()); | 451 EXPECT_FALSE(rwh->IsMaximized()); |
| 451 generator.DoubleClickLeftButton(); | 452 generator.DoubleClickLeftButton(); |
| 452 RunPendingMessages(); | 453 RunPendingMessages(); |
| 453 EXPECT_FALSE(rwh->IsMaximized()); | 454 EXPECT_FALSE(rwh->IsMaximized()); |
| 454 | 455 |
| 455 widget->CloseNow(); | 456 widget->CloseNow(); |
| 456 } | 457 } |
| 457 | 458 |
| 459 // Test that rotating the displays notifies the DisplayObservers. |
| 460 TEST_F(DesktopScreenX11Test, RotationChange) { |
| 461 std::vector<gfx::Display> displays; |
| 462 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); |
| 463 displays.push_back(gfx::Display(kSecondDisplay, |
| 464 gfx::Rect(640, 0, 1024, 768))); |
| 465 screen()->ProcessDisplayChange(displays); |
| 466 ResetDisplayChanges(); |
| 467 |
| 468 displays[0].set_rotation(gfx::Display::ROTATE_90); |
| 469 screen()->ProcessDisplayChange(displays); |
| 470 EXPECT_EQ(1u, changed_display_.size()); |
| 471 |
| 472 displays[1].set_rotation(gfx::Display::ROTATE_90); |
| 473 screen()->ProcessDisplayChange(displays); |
| 474 EXPECT_EQ(2u, changed_display_.size()); |
| 475 |
| 476 displays[0].set_rotation(gfx::Display::ROTATE_270); |
| 477 screen()->ProcessDisplayChange(displays); |
| 478 EXPECT_EQ(3u, changed_display_.size()); |
| 479 |
| 480 displays[0].set_rotation(gfx::Display::ROTATE_270); |
| 481 screen()->ProcessDisplayChange(displays); |
| 482 EXPECT_EQ(3u, changed_display_.size()); |
| 483 |
| 484 displays[0].set_rotation(gfx::Display::ROTATE_0); |
| 485 displays[1].set_rotation(gfx::Display::ROTATE_0); |
| 486 screen()->ProcessDisplayChange(displays); |
| 487 EXPECT_EQ(5u, changed_display_.size()); |
| 488 } |
| 489 |
| 490 // Test that changing the displays workarea notifies the DisplayObservers. |
| 491 TEST_F(DesktopScreenX11Test, WorkareaChange) { |
| 492 std::vector<gfx::Display> displays; |
| 493 displays.push_back(gfx::Display(kFirstDisplay, gfx::Rect(0, 0, 640, 480))); |
| 494 displays.push_back(gfx::Display(kSecondDisplay, |
| 495 gfx::Rect(640, 0, 1024, 768))); |
| 496 screen()->ProcessDisplayChange(displays); |
| 497 ResetDisplayChanges(); |
| 498 |
| 499 displays[0].set_work_area(gfx::Rect(0, 0, 300, 300)); |
| 500 screen()->ProcessDisplayChange(displays); |
| 501 EXPECT_EQ(1u, changed_display_.size()); |
| 502 |
| 503 displays[1].set_work_area(gfx::Rect(0, 0, 300, 300)); |
| 504 screen()->ProcessDisplayChange(displays); |
| 505 EXPECT_EQ(2u, changed_display_.size()); |
| 506 |
| 507 displays[0].set_work_area(gfx::Rect(0, 0, 300, 300)); |
| 508 screen()->ProcessDisplayChange(displays); |
| 509 EXPECT_EQ(2u, changed_display_.size()); |
| 510 |
| 511 displays[1].set_work_area(gfx::Rect(0, 0, 300, 300)); |
| 512 screen()->ProcessDisplayChange(displays); |
| 513 EXPECT_EQ(2u, changed_display_.size()); |
| 514 |
| 515 displays[0].set_work_area(gfx::Rect(0, 0, 640, 480)); |
| 516 displays[1].set_work_area(gfx::Rect(640, 0, 1024, 768)); |
| 517 screen()->ProcessDisplayChange(displays); |
| 518 EXPECT_EQ(4u, changed_display_.size()); |
| 519 } |
| 520 |
| 458 } // namespace views | 521 } // namespace views |
| OLD | NEW |