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

Side by Side Diff: ui/views/mus/native_widget_mus_unittest.cc

Issue 1863523006: mash: Make system tray bubble close when another window is activated (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: review comments Created 4 years, 8 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
« no previous file with comments | « ui/views/mus/native_widget_mus.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "ui/views/mus/native_widget_mus.h" 5 #include "ui/views/mus/native_widget_mus.h"
6 6
7 #include "base/macros.h" 7 #include "base/macros.h"
8 #include "components/mus/public/cpp/property_type_converters.h" 8 #include "components/mus/public/cpp/property_type_converters.h"
9 #include "components/mus/public/cpp/window.h" 9 #include "components/mus/public/cpp/window.h"
10 #include "components/mus/public/cpp/window_property.h" 10 #include "components/mus/public/cpp/window_property.h"
11 #include "components/mus/public/interfaces/window_manager.mojom.h" 11 #include "components/mus/public/interfaces/window_manager.mojom.h"
12 #include "testing/gtest/include/gtest/gtest.h" 12 #include "testing/gtest/include/gtest/gtest.h"
13 #include "third_party/skia/include/core/SkBitmap.h" 13 #include "third_party/skia/include/core/SkBitmap.h"
14 #include "third_party/skia/include/core/SkColor.h" 14 #include "third_party/skia/include/core/SkColor.h"
15 #include "ui/aura/window.h" 15 #include "ui/aura/window.h"
16 #include "ui/gfx/geometry/rect.h" 16 #include "ui/gfx/geometry/rect.h"
17 #include "ui/gfx/image/image_skia.h" 17 #include "ui/gfx/image/image_skia.h"
18 #include "ui/gfx/skia_util.h" 18 #include "ui/gfx/skia_util.h"
19 #include "ui/views/test/focus_manager_test.h"
19 #include "ui/views/test/views_test_base.h" 20 #include "ui/views/test/views_test_base.h"
20 #include "ui/views/widget/widget.h" 21 #include "ui/views/widget/widget.h"
21 #include "ui/views/widget/widget_delegate.h" 22 #include "ui/views/widget/widget_delegate.h"
23 #include "ui/views/widget/widget_observer.h"
22 24
23 namespace views { 25 namespace views {
24 namespace { 26 namespace {
25 27
26 // Returns a small colored bitmap. 28 // Returns a small colored bitmap.
27 SkBitmap MakeBitmap(SkColor color) { 29 SkBitmap MakeBitmap(SkColor color) {
28 SkBitmap bitmap; 30 SkBitmap bitmap;
29 bitmap.allocN32Pixels(8, 8); 31 bitmap.allocN32Pixels(8, 8);
30 bitmap.eraseColor(color); 32 bitmap.eraseColor(color);
31 return bitmap; 33 return bitmap;
32 } 34 }
33 35
36 // An observer that tracks widget activation changes.
37 class WidgetActivationObserver : public WidgetObserver {
38 public:
39 explicit WidgetActivationObserver(Widget* widget) : widget_(widget) {
40 widget_->AddObserver(this);
41 }
42
43 ~WidgetActivationObserver() override {
44 widget_->RemoveObserver(this);
45 }
46
47 const std::vector<bool>& changes() const { return changes_; }
48
49 // WidgetObserver:
50 void OnWidgetActivationChanged(Widget* widget, bool active) override {
51 ASSERT_EQ(widget_, widget);
52 changes_.push_back(active);
53 }
54
55 private:
56 Widget* widget_;
57 std::vector<bool> changes_;
58
59 DISALLOW_COPY_AND_ASSIGN(WidgetActivationObserver);
60 };
61
34 // A WidgetDelegate that supplies an app icon. 62 // A WidgetDelegate that supplies an app icon.
35 class TestWidgetDelegate : public WidgetDelegateView { 63 class TestWidgetDelegate : public WidgetDelegateView {
36 public: 64 public:
37 explicit TestWidgetDelegate(const SkBitmap& icon) 65 explicit TestWidgetDelegate(const SkBitmap& icon)
38 : app_icon_(gfx::ImageSkia::CreateFrom1xBitmap(icon)) {} 66 : app_icon_(gfx::ImageSkia::CreateFrom1xBitmap(icon)) {}
39 67
40 ~TestWidgetDelegate() override {} 68 ~TestWidgetDelegate() override {}
41 69
42 void SetIcon(const SkBitmap& icon) { 70 void SetIcon(const SkBitmap& icon) {
43 app_icon_ = gfx::ImageSkia::CreateFrom1xBitmap(icon); 71 app_icon_ = gfx::ImageSkia::CreateFrom1xBitmap(icon);
44 } 72 }
45 73
46 // views::WidgetDelegate: 74 // views::WidgetDelegate:
47 gfx::ImageSkia GetWindowAppIcon() override { return app_icon_; } 75 gfx::ImageSkia GetWindowAppIcon() override { return app_icon_; }
48 76
49 private: 77 private:
50 gfx::ImageSkia app_icon_; 78 gfx::ImageSkia app_icon_;
51 79
52 DISALLOW_COPY_AND_ASSIGN(TestWidgetDelegate); 80 DISALLOW_COPY_AND_ASSIGN(TestWidgetDelegate);
53 }; 81 };
54 82
55 class NativeWidgetMusTest : public ViewsTestBase { 83 class NativeWidgetMusTest : public ViewsTestBase {
56 public: 84 public:
57 NativeWidgetMusTest() {} 85 NativeWidgetMusTest() {}
58 ~NativeWidgetMusTest() override {} 86 ~NativeWidgetMusTest() override {}
59 87
60 // Creates a test widget. Takes ownership of |delegate|. 88 // Creates a test widget. Takes ownership of |delegate|.
61 Widget* CreateWidget(TestWidgetDelegate* delegate) { 89 scoped_ptr<Widget> CreateWidget(TestWidgetDelegate* delegate) {
62 Widget* widget = new Widget(); 90 scoped_ptr<Widget> widget(new Widget());
63 Widget::InitParams params = CreateParams(Widget::InitParams::TYPE_WINDOW); 91 Widget::InitParams params = CreateParams(Widget::InitParams::TYPE_WINDOW);
64 params.delegate = delegate; 92 params.delegate = delegate;
65 params.ownership = Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET; 93 params.ownership = Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET;
66 params.bounds = gfx::Rect(10, 20, 100, 200); 94 params.bounds = gfx::Rect(10, 20, 100, 200);
67 widget->Init(params); 95 widget->Init(params);
68 return widget; 96 return widget;
69 } 97 }
70 98
71 private: 99 private:
72 DISALLOW_COPY_AND_ASSIGN(NativeWidgetMusTest); 100 DISALLOW_COPY_AND_ASSIGN(NativeWidgetMusTest);
73 }; 101 };
74 102
103 // Tests communication of activation and focus between Widget and
104 // NativeWidgetMus.
105 TEST_F(NativeWidgetMusTest, OnActivationChanged) {
106 scoped_ptr<Widget> widget(CreateWidget(nullptr));
107 widget->Show();
108
109 // Track activation, focus and blur events.
110 WidgetActivationObserver activation_observer(widget.get());
111 TestWidgetFocusChangeListener focus_listener;
112 WidgetFocusManager::GetInstance()->AddFocusChangeListener(&focus_listener);
113
114 // Deactivate the Widget, which deactivates the NativeWidgetMus.
115 widget->Deactivate();
116
117 // The widget is blurred and deactivated.
118 ASSERT_EQ(1u, focus_listener.focus_changes().size());
119 EXPECT_EQ(nullptr, focus_listener.focus_changes()[0]);
120 ASSERT_EQ(1u, activation_observer.changes().size());
121 EXPECT_EQ(false, activation_observer.changes()[0]);
122
123 // Re-activate the Widget, which actives the NativeWidgetMus.
124 widget->Activate();
125
126 // The widget is focused and activated.
127 ASSERT_EQ(2u, focus_listener.focus_changes().size());
128 EXPECT_EQ(widget->GetNativeView(), focus_listener.focus_changes()[1]);
129 ASSERT_EQ(2u, activation_observer.changes().size());
130 EXPECT_TRUE(activation_observer.changes()[1]);
131
132 WidgetFocusManager::GetInstance()->RemoveFocusChangeListener(&focus_listener);
133 }
134
75 // Tests that a window with an icon sets the mus::Window icon property. 135 // Tests that a window with an icon sets the mus::Window icon property.
76 TEST_F(NativeWidgetMusTest, AppIcon) { 136 TEST_F(NativeWidgetMusTest, AppIcon) {
77 // Create a Widget with a bitmap as the icon. 137 // Create a Widget with a bitmap as the icon.
78 SkBitmap source_bitmap = MakeBitmap(SK_ColorRED); 138 SkBitmap source_bitmap = MakeBitmap(SK_ColorRED);
79 scoped_ptr<Widget> widget( 139 scoped_ptr<Widget> widget(
80 CreateWidget(new TestWidgetDelegate(source_bitmap))); 140 CreateWidget(new TestWidgetDelegate(source_bitmap)));
81 141
82 // The mus::Window has the icon property. 142 // The mus::Window has the icon property.
83 mus::Window* window = 143 mus::Window* window =
84 static_cast<NativeWidgetMus*>(widget->native_widget_private())->window(); 144 static_cast<NativeWidgetMus*>(widget->native_widget_private())->window();
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
128 TEST_F(NativeWidgetMusTest, ValidLayerTree) { 188 TEST_F(NativeWidgetMusTest, ValidLayerTree) {
129 scoped_ptr<Widget> widget(CreateWidget(nullptr)); 189 scoped_ptr<Widget> widget(CreateWidget(nullptr));
130 View* content = new View; 190 View* content = new View;
131 content->SetPaintToLayer(true); 191 content->SetPaintToLayer(true);
132 widget->GetContentsView()->AddChildView(content); 192 widget->GetContentsView()->AddChildView(content);
133 EXPECT_TRUE(widget->GetNativeWindow()->layer()->Contains(content->layer())); 193 EXPECT_TRUE(widget->GetNativeWindow()->layer()->Contains(content->layer()));
134 } 194 }
135 195
136 } // namespace 196 } // namespace
137 } // namespace views 197 } // namespace views
OLDNEW
« no previous file with comments | « ui/views/mus/native_widget_mus.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698