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

Side by Side Diff: ui/views/widget/native_widget_unittest.cc

Issue 11416251: Desktop aura: Continue threading context through views. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix erroneously removed line from NWWin tests. Created 8 years 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
« no previous file with comments | « ui/views/widget/native_widget_aura_unittest.cc ('k') | ui/views/widget/widget.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "testing/gtest/include/gtest/gtest.h" 5 #include "testing/gtest/include/gtest/gtest.h"
6 #include "ui/views/controls/native/native_view_host.h" 6 #include "ui/views/controls/native/native_view_host.h"
7 #include "ui/views/test/views_test_base.h" 7 #include "ui/views/test/views_test_base.h"
8 #include "ui/views/view.h" 8 #include "ui/views/view.h"
9 #include "ui/views/widget/native_widget_private.h" 9 #include "ui/views/widget/native_widget_private.h"
10 #include "ui/views/widget/native_widget_test_utils.h"
11 #include "ui/views/widget/widget.h" 10 #include "ui/views/widget/widget.h"
12 11
13 namespace views { 12 namespace views {
14 13
15 class ScopedTestWidget { 14 class ScopedTestWidget {
16 public: 15 public:
17 explicit ScopedTestWidget(internal::NativeWidgetPrivate* native_widget) 16 explicit ScopedTestWidget(internal::NativeWidgetPrivate* native_widget)
18 : native_widget_(native_widget) { 17 : native_widget_(native_widget) {
19 } 18 }
20 ~ScopedTestWidget() { 19 ~ScopedTestWidget() {
(...skipping 10 matching lines...) Expand all
31 private: 30 private:
32 internal::NativeWidgetPrivate* native_widget_; 31 internal::NativeWidgetPrivate* native_widget_;
33 DISALLOW_COPY_AND_ASSIGN(ScopedTestWidget); 32 DISALLOW_COPY_AND_ASSIGN(ScopedTestWidget);
34 }; 33 };
35 34
36 class NativeWidgetTest : public ViewsTestBase { 35 class NativeWidgetTest : public ViewsTestBase {
37 public: 36 public:
38 NativeWidgetTest() {} 37 NativeWidgetTest() {}
39 virtual ~NativeWidgetTest() {} 38 virtual ~NativeWidgetTest() {}
40 39
40 internal::NativeWidgetPrivate* CreateNativeWidgetOfType(
41 Widget::InitParams::Type type) {
42 Widget* widget = new Widget;
43 Widget::InitParams params = CreateParams(type);
44 params.ownership = views::Widget::InitParams::NATIVE_WIDGET_OWNS_WIDGET;
45 params.child = false; // Implicitly set to true by ctor with TYPE_CONTROL.
46 params.bounds = gfx::Rect(10, 10, 200, 200);
47 widget->Init(params);
48 return widget->native_widget_private();
49 }
50
51 internal::NativeWidgetPrivate* CreateNativeWidget() {
52 return CreateNativeWidgetOfType(Widget::InitParams::TYPE_POPUP);
53 }
54
55 internal::NativeWidgetPrivate* CreateNativeSubWidget() {
56 return CreateNativeWidgetOfType(Widget::InitParams::TYPE_CONTROL);
57 }
58
41 private: 59 private:
42 DISALLOW_COPY_AND_ASSIGN(NativeWidgetTest); 60 DISALLOW_COPY_AND_ASSIGN(NativeWidgetTest);
43 }; 61 };
44 62
45 TEST_F(NativeWidgetTest, CreateNativeWidget) { 63 TEST_F(NativeWidgetTest, CreateNativeWidget) {
46 ScopedTestWidget widget(internal::CreateNativeWidget()); 64 ScopedTestWidget widget(CreateNativeWidget());
47 EXPECT_TRUE(widget->GetWidget()->GetNativeView() != NULL); 65 EXPECT_TRUE(widget->GetWidget()->GetNativeView() != NULL);
48 } 66 }
49 67
50 TEST_F(NativeWidgetTest, GetNativeWidgetForNativeView) { 68 TEST_F(NativeWidgetTest, GetNativeWidgetForNativeView) {
51 ScopedTestWidget widget(internal::CreateNativeWidget()); 69 ScopedTestWidget widget(CreateNativeWidget());
52 EXPECT_EQ(widget.get(), 70 EXPECT_EQ(widget.get(),
53 internal::NativeWidgetPrivate::GetNativeWidgetForNativeView( 71 internal::NativeWidgetPrivate::GetNativeWidgetForNativeView(
54 widget->GetWidget()->GetNativeView())); 72 widget->GetWidget()->GetNativeView()));
55 } 73 }
56 74
57 // |widget| has the toplevel NativeWidget. 75 // |widget| has the toplevel NativeWidget.
58 TEST_F(NativeWidgetTest, GetTopLevelNativeWidget1) { 76 TEST_F(NativeWidgetTest, GetTopLevelNativeWidget1) {
59 ScopedTestWidget widget(internal::CreateNativeWidget()); 77 ScopedTestWidget widget(CreateNativeWidget());
60 EXPECT_EQ(widget.get(), 78 EXPECT_EQ(widget.get(),
61 internal::NativeWidgetPrivate::GetTopLevelNativeWidget( 79 internal::NativeWidgetPrivate::GetTopLevelNativeWidget(
62 widget->GetWidget()->GetNativeView())); 80 widget->GetWidget()->GetNativeView()));
63 } 81 }
64 82
65 // |toplevel_widget| has the toplevel NativeWidget. 83 // |toplevel_widget| has the toplevel NativeWidget.
66 TEST_F(NativeWidgetTest, GetTopLevelNativeWidget2) { 84 TEST_F(NativeWidgetTest, GetTopLevelNativeWidget2) {
67 ScopedTestWidget toplevel_widget(internal::CreateNativeWidget()); 85 ScopedTestWidget toplevel_widget(CreateNativeWidget());
68 86
69 // |toplevel_widget| owns |child_host|. 87 // |toplevel_widget| owns |child_host|.
70 NativeViewHost* child_host = new NativeViewHost; 88 NativeViewHost* child_host = new NativeViewHost;
71 toplevel_widget->GetWidget()->SetContentsView(child_host); 89 toplevel_widget->GetWidget()->SetContentsView(child_host);
72 90
73 // |child_host| owns |child_widget|. 91 // |child_host| owns |child_widget|.
74 internal::NativeWidgetPrivate* child_widget = 92 internal::NativeWidgetPrivate* child_widget = CreateNativeSubWidget();
75 internal::CreateNativeSubWidget();
76 child_host->Attach(child_widget->GetWidget()->GetNativeView()); 93 child_host->Attach(child_widget->GetWidget()->GetNativeView());
77 94
78 EXPECT_EQ(toplevel_widget.get(), 95 EXPECT_EQ(toplevel_widget.get(),
79 internal::NativeWidgetPrivate::GetTopLevelNativeWidget( 96 internal::NativeWidgetPrivate::GetTopLevelNativeWidget(
80 child_widget->GetWidget()->GetNativeView())); 97 child_widget->GetWidget()->GetNativeView()));
81 } 98 }
82 99
83 } // namespace views 100 } // namespace views
OLDNEW
« no previous file with comments | « ui/views/widget/native_widget_aura_unittest.cc ('k') | ui/views/widget/widget.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698