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

Side by Side Diff: chrome/browser/ui/libgtk2ui/select_file_dialog_impl_test.cc

Issue 1363093004: Add BrowserSelectFileDialogTest.OpenCloseFileDialog (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: add comments Created 5 years, 1 month 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 | « chrome/browser/ui/libgtk2ui/select_file_dialog_impl_gtk2.cc ('k') | chrome/chrome_tests.gypi » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5
sadrul 2015/11/17 02:10:15 - extra new line
joone 2015/11/17 23:16:22 Done.
6 #include "base/run_loop.h"
7 #include "chrome/browser/ui/browser.h"
8 #include "chrome/browser/ui/browser_window.h"
9 #include "chrome/browser/ui/chrome_select_file_policy.h"
10 #include "chrome/browser/ui/libgtk2ui/select_file_dialog_impl_gtk2.h"
11 #include "chrome/browser/ui/view_ids.h"
12 #include "chrome/test/base/in_process_browser_test.h"
13 #include "chrome/test/base/interactive_test_utils.h"
14 #include "chrome/test/base/ui_test_utils.h"
15 #include "net/test/embedded_test_server/embedded_test_server.h"
16 #include "ui/shell_dialogs/select_file_dialog.h"
17 #include "ui/views/widget/widget.h"
18 #include "ui/views/widget/widget_observer.h"
19
20 using BrowserSelectFileDialogTest = InProcessBrowserTest;
21
22 // Spins a run loop until a Widget's activation reaches the desired state.
23 class WidgetActivationWaiter : public views::WidgetObserver {
24 public:
25 WidgetActivationWaiter(views::Widget* widget, bool active)
26 : observed_(false), active_(active) {
27 widget->AddObserver(this);
28 EXPECT_NE(active, widget->IsActive());
29 }
30
31 void Wait() {
32 if (!observed_)
33 run_loop_.Run();
34 }
35
36 private:
37 // views::WidgetObserver:
38 void OnWidgetActivationChanged(views::Widget* widget, bool active) override {
39 if (active_ != active)
40 return;
41
42 observed_ = true;
43 widget->RemoveObserver(this);
44 if (run_loop_.running())
45 run_loop_.Quit();
46 }
47
48 base::RunLoop run_loop_;
49 bool observed_;
50 bool active_;
51
52 DISALLOW_COPY_AND_ASSIGN(WidgetActivationWaiter);
53 };
54
55 namespace libgtk2ui {
56
57 // FilePicker opens a GtkFileChooser.
58 class FilePicker : public ui::SelectFileDialog::Listener {
59 public:
60 explicit FilePicker(BrowserWindow* window) {
61 select_file_dialog_ = ui::SelectFileDialog::Create(
62 this, new ChromeSelectFilePolicy(nullptr));
63
64 gfx::NativeWindow parent_window = window->GetNativeWindow();
65 ui::SelectFileDialog::FileTypeInfo file_types;
66 file_types.support_drive = true;
67 const base::FilePath file_path;
68 select_file_dialog_->SelectFile(ui::SelectFileDialog::SELECT_OPEN_FILE,
69 base::string16(),
70 file_path,
71 &file_types,
72 0,
73 base::FilePath::StringType(),
74 parent_window,
75 nullptr);
76 }
77
78 ~FilePicker() override {
79 if (select_file_dialog_.get())
sadrul 2015/11/17 02:10:15 When can |select_file_dialog_| be null?
joone 2015/11/17 23:16:22 There is no case where |select_file_dialog_| is nu
80 select_file_dialog_->ListenerDestroyed();
81 }
82
83 void Close() {
84 SelectFileDialogImplGTK* file_dialog =
85 static_cast<SelectFileDialogImplGTK*>(select_file_dialog_.get());
86
87
88 while (!file_dialog->dialogs_.empty())
89 gtk_widget_destroy(*(file_dialog->dialogs_.begin()));
90 }
91
92 // SelectFileDialog::Listener implementation.
93 void FileSelected(const base::FilePath& path,
94 int index,
95 void* params) override {}
96 private:
97 // Dialog box used for opening and saving files.
98 scoped_refptr<ui::SelectFileDialog> select_file_dialog_;
99
100 DISALLOW_COPY_AND_ASSIGN(FilePicker);
101 };
102
103 } // namespace libgtk2ui
104
105 // Test that the file-picker is opened and closed without memory leaks.
106 IN_PROC_BROWSER_TEST_F(BrowserSelectFileDialogTest, OpenCloseFileDialog) {
107 // Bring the native window to the foreground. Returns true on success.
108 ASSERT_TRUE(ui_test_utils::BringBrowserWindowToFront(browser()));
109 // Initializes and waits until the test server is ready to accept requests.
110 ASSERT_TRUE(embedded_test_server()->Start());
sadrul 2015/11/17 02:10:15 You don't need to start the test-server, right?
joone 2015/11/17 23:16:22 Right, we don't need to run it because the page lo
111 ASSERT_TRUE(browser()->window()->IsActive());
112
113 // Leaks in GtkFileChooserDialog. http://crbug.com/537468
114 ANNOTATE_SCOPED_MEMORY_LEAK;
115 libgtk2ui::FilePicker file_picker(browser()->window());
116
117 gfx::NativeWindow window = browser()->window()->GetNativeWindow();
118 views::Widget* widget = views::Widget::GetWidgetForNativeWindow(window);
119 ASSERT_NE(nullptr, widget);
120
121 // Run a nested loop until the browser window becomes inactive
122 // so that the file-picker can be active.
123 WidgetActivationWaiter wait_inactive(widget, false);
124 wait_inactive.Wait();
125 EXPECT_FALSE(browser()->window()->IsActive());
126 file_picker.Close();
127
128 // Run a nested loop until the browser window becomes active.
129 WidgetActivationWaiter wait_active(widget, true);
130 wait_active.Wait();
131 EXPECT_TRUE(browser()->window()->IsActive());
132 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/libgtk2ui/select_file_dialog_impl_gtk2.cc ('k') | chrome/chrome_tests.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698