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

Side by Side Diff: chrome/browser/ui/views/extensions/chooser_dialog_view_browsertest.cc

Issue 2086663003: Change ChooserController ownership model (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address reillyg@'s comments Created 4 years, 6 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
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 "chrome/browser/ui/views/extensions/chooser_dialog_view.h" 5 #include "chrome/browser/ui/views/extensions/chooser_dialog_view.h"
6 6
7 #include "base/macros.h" 7 #include "base/macros.h"
8 #include "chrome/browser/extensions/extension_browsertest.h" 8 #include "chrome/browser/extensions/extension_browsertest.h"
9 #include "chrome/browser/platform_util.h"
10 #include "chrome/browser/ui/browser_window.h"
9 #include "chrome/browser/ui/tabs/tab_strip_model.h" 11 #include "chrome/browser/ui/tabs/tab_strip_model.h"
10 #include "chrome/grit/generated_resources.h" 12 #include "chrome/grit/generated_resources.h"
11 #include "components/chooser_controller/mock_chooser_controller.h" 13 #include "components/chooser_controller/mock_chooser_controller.h"
12 #include "testing/gmock/include/gmock/gmock.h" 14 #include "testing/gmock/include/gmock/gmock.h"
13 #include "testing/gtest/include/gtest/gtest.h" 15 #include "testing/gtest/include/gtest/gtest.h"
14 #include "ui/base/l10n/l10n_util.h" 16 #include "ui/base/l10n/l10n_util.h"
15 #include "ui/gfx/range/range.h" 17 #include "ui/gfx/range/range.h"
16 #include "ui/views/controls/table/table_view.h" 18 #include "ui/views/controls/table/table_view.h"
19 #include "ui/views/widget/widget.h"
20 #include "ui/views/window/dialog_client_view.h"
17 21
18 class ChooserDialogViewTest : public ExtensionBrowserTest { 22 class ChooserDialogViewTest : public ExtensionBrowserTest {
19 public: 23 public:
20 ChooserDialogViewTest() {} 24 ChooserDialogViewTest() {}
21 ~ChooserDialogViewTest() override {} 25 ~ChooserDialogViewTest() override {}
22 26
23 void SetUpOnMainThread() override { 27 void SetUpOnMainThread() override {
24 content::WebContents* web_contents = 28 content::WebContents* web_contents =
25 browser()->tab_strip_model()->GetWebContentsAt(0); 29 browser()->tab_strip_model()->GetWebContentsAt(0);
26 mock_chooser_controller_.reset(new MockChooserController(nullptr)); 30 std::unique_ptr<MockChooserController> mock_chooser_controller(
27 chooser_dialog_view_.reset( 31 new MockChooserController(nullptr));
28 new ChooserDialogView(web_contents, mock_chooser_controller_.get())); 32 mock_chooser_controller_ = mock_chooser_controller.get();
33 std::unique_ptr<ChooserDialogView> chooser_dialog_view(
34 new ChooserDialogView(web_contents,
35 std::move(mock_chooser_controller)));
36 chooser_dialog_view_ = chooser_dialog_view.get();
29 table_view_ = chooser_dialog_view_->table_view_for_test(); 37 table_view_ = chooser_dialog_view_->table_view_for_test();
30 ASSERT_TRUE(table_view_); 38 ASSERT_TRUE(table_view_);
31 table_model_ = table_view_->model(); 39 table_model_ = table_view_->model();
32 ASSERT_TRUE(table_model_); 40 ASSERT_TRUE(table_model_);
41 views::Widget* modal_dialog = views::DialogDelegate::CreateDialogWidget(
msw 2016/06/22 18:23:17 Why do we need to actually create and show a dialo
juncai 2016/06/22 22:41:20 Creating and showing the dialog make sure that the
msw 2016/06/22 23:13:37 Acknowledged.
42 chooser_dialog_view.release(), nullptr,
43 platform_util::GetViewForWindow(
44 browser()->window()->GetNativeWindow()));
45 modal_dialog->Show();
33 } 46 }
34 47
35 protected: 48 protected:
36 std::unique_ptr<MockChooserController> mock_chooser_controller_; 49 MockChooserController* mock_chooser_controller_;
37 std::unique_ptr<ChooserDialogView> chooser_dialog_view_; 50 ChooserDialogView* chooser_dialog_view_;
38 views::TableView* table_view_; 51 views::TableView* table_view_;
39 ui::TableModel* table_model_; 52 ui::TableModel* table_model_;
40 53
41 private: 54 private:
42 DISALLOW_COPY_AND_ASSIGN(ChooserDialogViewTest); 55 DISALLOW_COPY_AND_ASSIGN(ChooserDialogViewTest);
43 }; 56 };
44 57
45 IN_PROC_BROWSER_TEST_F(ChooserDialogViewTest, InitialState) { 58 IN_PROC_BROWSER_TEST_F(ChooserDialogViewTest, InitialState) {
46 // Since "No devices found." needs to be displayed on the |table_view_|, 59 // Since "No devices found." needs to be displayed on the |table_view_|,
47 // the number of rows is 1. 60 // the number of rows is 1.
(...skipping 20 matching lines...) Expand all
68 81
69 IN_PROC_BROWSER_TEST_F(ChooserDialogViewTest, Close) { 82 IN_PROC_BROWSER_TEST_F(ChooserDialogViewTest, Close) {
70 EXPECT_CALL(*mock_chooser_controller_, Close()).Times(1); 83 EXPECT_CALL(*mock_chooser_controller_, Close()).Times(1);
71 chooser_dialog_view_->Close(); 84 chooser_dialog_view_->Close();
72 } 85 }
73 86
74 IN_PROC_BROWSER_TEST_F(ChooserDialogViewTest, ClickStyledLabelLink) { 87 IN_PROC_BROWSER_TEST_F(ChooserDialogViewTest, ClickStyledLabelLink) {
75 EXPECT_CALL(*mock_chooser_controller_, OpenHelpCenterUrl()).Times(1); 88 EXPECT_CALL(*mock_chooser_controller_, OpenHelpCenterUrl()).Times(1);
76 chooser_dialog_view_->StyledLabelLinkClicked(nullptr, gfx::Range(), 0); 89 chooser_dialog_view_->StyledLabelLinkClicked(nullptr, gfx::Range(), 0);
77 } 90 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698