OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "mandoline/ui/browser/browser.h" | 5 #include "mandoline/ui/browser/browser.h" |
6 | 6 |
7 #include "base/run_loop.h" | 7 #include "base/run_loop.h" |
8 #include "components/view_manager/public/cpp/view.h" | 8 #include "components/view_manager/public/cpp/view.h" |
9 #include "mandoline/ui/browser/browser_delegate.h" | 9 #include "mandoline/ui/browser/browser_delegate.h" |
10 #include "mojo/application/public/cpp/application_connection.h" | 10 #include "mojo/application/public/cpp/application_connection.h" |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
45 | 45 |
46 MOJO_DISALLOW_COPY_AND_ASSIGN(TestBrowser); | 46 MOJO_DISALLOW_COPY_AND_ASSIGN(TestBrowser); |
47 }; | 47 }; |
48 | 48 |
49 class BrowserTest : public mojo::test::ApplicationTestBase, | 49 class BrowserTest : public mojo::test::ApplicationTestBase, |
50 public mojo::ApplicationDelegate, | 50 public mojo::ApplicationDelegate, |
51 public BrowserDelegate { | 51 public BrowserDelegate { |
52 public: | 52 public: |
53 BrowserTest() | 53 BrowserTest() |
54 : app_(nullptr), | 54 : app_(nullptr), |
55 last_closed_connection_(nullptr), | |
56 last_browser_closed_(nullptr) {} | 55 last_browser_closed_(nullptr) {} |
57 | 56 |
58 // Creates a new Browser object. | 57 // Creates a new Browser object. |
59 TestBrowser* CreateBrowser() { | 58 TestBrowser* CreateBrowser() { |
60 if (!app_) | 59 if (!app_) |
61 return nullptr; | 60 return nullptr; |
62 TestBrowser* browser = new TestBrowser(app_, this); | 61 TestBrowser* browser = new TestBrowser(app_, this); |
63 browsers_.insert(browser); | 62 browsers_.insert(browser); |
64 return browser; | 63 return browser; |
65 } | 64 } |
66 | 65 |
67 TestBrowser* WaitForBrowserClosed() { | 66 TestBrowser* WaitForBrowserClosed() { |
68 if (!last_browser_closed_) { | 67 if (!last_browser_closed_) { |
69 browser_closed_run_loop_.reset(new base::RunLoop); | 68 browser_closed_run_loop_.reset(new base::RunLoop); |
70 browser_closed_run_loop_->Run(); | 69 browser_closed_run_loop_->Run(); |
71 browser_closed_run_loop_.reset(); | 70 browser_closed_run_loop_.reset(); |
72 } | 71 } |
73 TestBrowser* last_browser = last_browser_closed_; | 72 TestBrowser* last_browser = last_browser_closed_; |
74 last_browser_closed_ = nullptr; | 73 last_browser_closed_ = nullptr; |
75 return last_browser; | 74 return last_browser; |
76 } | 75 } |
77 | 76 |
78 // Returns the last ApplicationConnection closed. | |
79 void* last_closed_connection() { | |
80 return last_closed_connection_; | |
81 } | |
82 | |
83 // Overridden from ApplicationDelegate: | 77 // Overridden from ApplicationDelegate: |
84 void Initialize(mojo::ApplicationImpl* app) override { | 78 void Initialize(mojo::ApplicationImpl* app) override { |
85 app_ = app; | 79 app_ = app; |
86 } | 80 } |
87 | 81 |
88 void OnWillCloseConnection(mojo::ApplicationConnection* connection) override { | |
89 // WARNING: DO NOT FOLLOW THIS POINTER. IT WILL BE DESTROYED. | |
90 last_closed_connection_ = connection; | |
91 } | |
92 | |
93 // ApplicationTestBase: | 82 // ApplicationTestBase: |
94 ApplicationDelegate* GetApplicationDelegate() override { return this; } | 83 ApplicationDelegate* GetApplicationDelegate() override { return this; } |
95 | 84 |
96 // Overridden from BrowserDelegate: | 85 // Overridden from BrowserDelegate: |
97 void BrowserClosed(Browser* browser) override { | 86 void BrowserClosed(Browser* browser) override { |
98 scoped_ptr<Browser> browser_owner(browser); | 87 scoped_ptr<Browser> browser_owner(browser); |
99 TestBrowser* test_browser = static_cast<TestBrowser*>(browser); | 88 TestBrowser* test_browser = static_cast<TestBrowser*>(browser); |
100 DCHECK_GT(browsers_.count(test_browser), 0u); | 89 DCHECK_GT(browsers_.count(test_browser), 0u); |
101 browsers_.erase(test_browser); | 90 browsers_.erase(test_browser); |
102 last_browser_closed_ = test_browser; | 91 last_browser_closed_ = test_browser; |
103 if (browser_closed_run_loop_) { | 92 if (browser_closed_run_loop_) { |
104 browser_owner.reset(); | 93 browser_owner.reset(); |
105 browser_closed_run_loop_->Quit(); | 94 browser_closed_run_loop_->Quit(); |
106 } | 95 } |
107 } | 96 } |
108 | 97 |
109 void InitUIIfNecessary(Browser* browser, mojo::View* root_view) override {} | 98 void InitUIIfNecessary(Browser* browser, mojo::View* root_view) override {} |
110 | 99 |
111 private: | 100 private: |
112 mojo::ApplicationImpl* app_; | 101 mojo::ApplicationImpl* app_; |
113 void* last_closed_connection_; | |
114 std::set<TestBrowser*> browsers_; | 102 std::set<TestBrowser*> browsers_; |
115 TestBrowser* last_browser_closed_; | 103 TestBrowser* last_browser_closed_; |
116 scoped_ptr<base::RunLoop> browser_closed_run_loop_; | 104 scoped_ptr<base::RunLoop> browser_closed_run_loop_; |
117 | 105 |
118 MOJO_DISALLOW_COPY_AND_ASSIGN(BrowserTest); | 106 MOJO_DISALLOW_COPY_AND_ASSIGN(BrowserTest); |
119 }; | 107 }; |
120 | 108 |
121 // This test verifies that closing a Browser closes the associated application | 109 // This test verifies that closing a Browser closes the associated application |
122 // connection with the view manager. | 110 // connection with the view manager. |
123 TEST_F(BrowserTest, ClosingBrowserClosesAppConnection) { | 111 TEST_F(BrowserTest, ClosingBrowserClosesAppConnection) { |
124 Browser* browser = CreateBrowser(); | 112 Browser* browser = CreateBrowser(); |
125 ASSERT_NE(nullptr, browser); | 113 ASSERT_NE(nullptr, browser); |
126 mojo::ApplicationConnection* view_manager_connection = | 114 mojo::ApplicationConnection* view_manager_connection = |
127 browser->view_manager_init_.connection(); | 115 browser->view_manager_init_.connection(); |
| 116 mojo::ApplicationConnection::TestApi connection_test_api( |
| 117 view_manager_connection); |
128 ASSERT_NE(nullptr, view_manager_connection); | 118 ASSERT_NE(nullptr, view_manager_connection); |
| 119 base::WeakPtr<mojo::ApplicationConnection> ptr = |
| 120 connection_test_api.GetWeakPtr(); |
129 BrowserClosed(browser); | 121 BrowserClosed(browser); |
130 EXPECT_EQ(last_closed_connection(), view_manager_connection); | 122 EXPECT_FALSE(ptr); |
131 } | 123 } |
132 | 124 |
133 // This test verifies that we can create two Browsers and each Browser has a | 125 // This test verifies that we can create two Browsers and each Browser has a |
134 // different AppliationConnection and different root view. | 126 // different AppliationConnection and different root view. |
135 TEST_F(BrowserTest, TwoBrowsers) { | 127 TEST_F(BrowserTest, TwoBrowsers) { |
136 TestBrowser* browser1 = CreateBrowser(); | 128 TestBrowser* browser1 = CreateBrowser(); |
137 mojo::ApplicationConnection* browser1_connection = | 129 mojo::ApplicationConnection* browser1_connection = |
138 browser1->view_manager_init_.connection(); | 130 browser1->view_manager_init_.connection(); |
139 ASSERT_NE(nullptr, browser1); | 131 ASSERT_NE(nullptr, browser1); |
140 browser1->WaitForOnEmbed(); | 132 browser1->WaitForOnEmbed(); |
(...skipping 12 matching lines...) Expand all Loading... |
153 | 145 |
154 // Deleting the view manager closes the connection. | 146 // Deleting the view manager closes the connection. |
155 delete browser1->root()->view_manager(); | 147 delete browser1->root()->view_manager(); |
156 EXPECT_EQ(browser1, WaitForBrowserClosed()); | 148 EXPECT_EQ(browser1, WaitForBrowserClosed()); |
157 | 149 |
158 delete browser2->root()->view_manager(); | 150 delete browser2->root()->view_manager(); |
159 EXPECT_EQ(browser2, WaitForBrowserClosed()); | 151 EXPECT_EQ(browser2, WaitForBrowserClosed()); |
160 } | 152 } |
161 | 153 |
162 } // namespace mandoline | 154 } // namespace mandoline |
OLD | NEW |