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

Side by Side Diff: ui/views/window/dialog_delegate_unittest.cc

Issue 2807243004: Fix layout of BubbleFrameView when there's only a close button in the (Closed)
Patch Set: fix tests Created 3 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/bubble/bubble_frame_view_unittest.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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 <stddef.h> 5 #include <stddef.h>
6 6
7 #include "base/macros.h" 7 #include "base/macros.h"
8 #include "base/strings/utf_string_conversions.h" 8 #include "base/strings/utf_string_conversions.h"
9 #include "ui/base/hit_test.h" 9 #include "ui/base/hit_test.h"
10 #include "ui/events/event_processor.h" 10 #include "ui/events/event_processor.h"
(...skipping 10 matching lines...) Expand all
21 #if defined(OS_MACOSX) 21 #if defined(OS_MACOSX)
22 #include "ui/base/test/scoped_fake_full_keyboard_access.h" 22 #include "ui/base/test/scoped_fake_full_keyboard_access.h"
23 #endif 23 #endif
24 24
25 namespace views { 25 namespace views {
26 26
27 namespace { 27 namespace {
28 28
29 class TestDialog : public DialogDelegateView { 29 class TestDialog : public DialogDelegateView {
30 public: 30 public:
31 TestDialog() 31 TestDialog() : input_(new views::Textfield()) { AddChildView(input_); }
32 : input_(new views::Textfield()),
33 canceled_(false),
34 accepted_(false),
35 closed_(false),
36 closeable_(false),
37 should_handle_escape_(false) {
38 AddChildView(input_);
39 }
40 ~TestDialog() override {} 32 ~TestDialog() override {}
41 33
42 void Init() { 34 void Init() {
43 // Add the accelerator before being added to the widget hierarchy (before 35 // Add the accelerator before being added to the widget hierarchy (before
44 // DCV has registered its accelerator) to make sure accelerator handling is 36 // DCV has registered its accelerator) to make sure accelerator handling is
45 // not dependent on the order of AddAccelerator calls. 37 // not dependent on the order of AddAccelerator calls.
46 EXPECT_FALSE(GetWidget()); 38 EXPECT_FALSE(GetWidget());
47 AddAccelerator(ui::Accelerator(ui::VKEY_ESCAPE, ui::EF_NONE)); 39 AddAccelerator(ui::Accelerator(ui::VKEY_ESCAPE, ui::EF_NONE));
48 } 40 }
49 41
50 // WidgetDelegate overrides: 42 // WidgetDelegate overrides:
51 bool ShouldShowWindowTitle() const override { 43 bool ShouldShowWindowTitle() const override {
52 return !title_.empty(); 44 return !title_.empty();
53 } 45 }
54 46
47 bool ShouldShowCloseButton() const override { return show_close_button_; }
Peter Kasting 2017/04/13 22:36:29 Nit: Maybe no blank line above this
Evan Stade 2017/04/13 23:39:17 Done.
Peter Kasting 2017/04/13 23:47:34 You didn't, but it's not important :) Same for th
Evan Stade 2017/04/13 23:51:24 oi, I seem to be in too much of a hurry to do anyt
48
55 // DialogDelegateView overrides: 49 // DialogDelegateView overrides:
56 bool Cancel() override { 50 bool Cancel() override {
57 canceled_ = true; 51 canceled_ = true;
58 return closeable_; 52 return closeable_;
59 } 53 }
60 bool Accept() override { 54 bool Accept() override {
61 accepted_ = true; 55 accepted_ = true;
62 return closeable_; 56 return closeable_;
63 } 57 }
64 bool Close() override { 58 bool Close() override {
65 closed_ = true; 59 closed_ = true;
66 return closeable_; 60 return closeable_;
67 } 61 }
68 62
69 // DialogDelegateView overrides:
70 gfx::Size GetPreferredSize() const override { return gfx::Size(200, 200); } 63 gfx::Size GetPreferredSize() const override { return gfx::Size(200, 200); }
71 bool AcceleratorPressed(const ui::Accelerator& accelerator) override { 64 bool AcceleratorPressed(const ui::Accelerator& accelerator) override {
72 return should_handle_escape_; 65 return should_handle_escape_;
73 } 66 }
74 base::string16 GetWindowTitle() const override { return title_; } 67 base::string16 GetWindowTitle() const override { return title_; }
75 View* GetInitiallyFocusedView() override { return input_; } 68 View* GetInitiallyFocusedView() override { return input_; }
76 bool ShouldUseCustomFrame() const override { return true; } 69 bool ShouldUseCustomFrame() const override { return true; }
77 70
78 void CheckAndResetStates(bool canceled, 71 void CheckAndResetStates(bool canceled,
79 bool accepted, 72 bool accepted,
80 bool closed) { 73 bool closed) {
81 EXPECT_EQ(canceled, canceled_); 74 EXPECT_EQ(canceled, canceled_);
82 canceled_ = false; 75 canceled_ = false;
83 EXPECT_EQ(accepted, accepted_); 76 EXPECT_EQ(accepted, accepted_);
84 accepted_ = false; 77 accepted_ = false;
85 EXPECT_EQ(closed, closed_); 78 EXPECT_EQ(closed, closed_);
86 closed_ = false; 79 closed_ = false;
87 } 80 }
88 81
89 void TearDown() { 82 void TearDown() {
90 closeable_ = true; 83 closeable_ = true;
91 GetWidget()->Close(); 84 GetWidget()->Close();
92 } 85 }
93 86
94 void set_title(const base::string16& title) { title_ = title; } 87 void set_title(const base::string16& title) { title_ = title; }
88 void set_show_close_button(bool show_close) {
89 show_close_button_ = show_close;
90 }
95 void set_should_handle_escape(bool should_handle_escape) { 91 void set_should_handle_escape(bool should_handle_escape) {
96 should_handle_escape_ = should_handle_escape; 92 should_handle_escape_ = should_handle_escape;
97 } 93 }
98 94
99 views::Textfield* input() { return input_; } 95 views::Textfield* input() { return input_; }
100 96
101 private: 97 private:
102 views::Textfield* input_; 98 views::Textfield* input_;
103 bool canceled_; 99 bool canceled_ = false;
104 bool accepted_; 100 bool accepted_ = false;
105 bool closed_; 101 bool closed_ = false;
106 // Prevent the dialog from closing, for repeated ok and cancel button clicks. 102 // Prevent the dialog from closing, for repeated ok and cancel button clicks.
107 bool closeable_; 103 bool closeable_;
108 base::string16 title_; 104 base::string16 title_;
109 bool should_handle_escape_; 105 bool show_close_button_ = true;
106 bool should_handle_escape_ = false;
110 107
111 DISALLOW_COPY_AND_ASSIGN(TestDialog); 108 DISALLOW_COPY_AND_ASSIGN(TestDialog);
112 }; 109 };
113 110
114 class DialogTest : public ViewsTestBase { 111 class DialogTest : public ViewsTestBase {
115 public: 112 public:
116 DialogTest() : dialog_(nullptr) {} 113 DialogTest() : dialog_(nullptr) {}
117 ~DialogTest() override {} 114 ~DialogTest() override {}
118 115
119 void SetUp() override { 116 void SetUp() override {
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after
198 delete dialog()->GetDialogClientView()->cancel_button(); 195 delete dialog()->GetDialogClientView()->cancel_button();
199 } 196 }
200 197
201 TEST_F(DialogTest, HitTest_HiddenTitle) { 198 TEST_F(DialogTest, HitTest_HiddenTitle) {
202 // Ensure that BubbleFrameView hit-tests as expected when the title is hidden. 199 // Ensure that BubbleFrameView hit-tests as expected when the title is hidden.
203 const NonClientView* view = dialog()->GetWidget()->non_client_view(); 200 const NonClientView* view = dialog()->GetWidget()->non_client_view();
204 BubbleFrameView* frame = static_cast<BubbleFrameView*>(view->frame_view()); 201 BubbleFrameView* frame = static_cast<BubbleFrameView*>(view->frame_view());
205 const int border = frame->bubble_border()->GetBorderThickness(); 202 const int border = frame->bubble_border()->GetBorderThickness();
206 203
207 struct { 204 struct {
208 const int point; 205 int point;
Peter Kasting 2017/04/13 22:36:29 Nit: I suppose these could be const like the old o
Evan Stade 2017/04/13 23:39:17 Done.
209 const int hit; 206 int hit;
207 } cases[] = {
208 {border, HTSYSMENU},
209 {border + 10, HTSYSMENU},
210 {border + 20, HTNOWHERE},
211 {border + 50, HTCLIENT /* Space is reserved for the close button. */},
212 {border + 60, HTCLIENT},
213 {1000, HTNOWHERE},
214 };
215
216 for (size_t i = 0; i < arraysize(cases); ++i) {
217 gfx::Point point(cases[i].point, cases[i].point);
218 EXPECT_EQ(cases[i].hit, frame->NonClientHitTest(point))
219 << " case " << i << " with border: " << border << ", at point "
220 << cases[i].point;
221 }
222 }
223
224 TEST_F(DialogTest, HitTest_HiddenTitleNoCloseButton) {
225 auto* dialog = new TestDialog();
226 dialog->set_show_close_button(false);
Peter Kasting 2017/04/13 22:36:28 I don't suppose there's an easy way to toggle this
Evan Stade 2017/04/13 23:39:18 I tried a few ways of doing that but to no avail.
Peter Kasting 2017/04/13 23:41:29 I went to look, but I don't see the patch doing th
227 dialog->Init();
228 DialogDelegate::CreateDialogWidget(dialog, GetContext(), nullptr)->Show();
229
230 const NonClientView* view = dialog->GetWidget()->non_client_view();
231 BubbleFrameView* frame = static_cast<BubbleFrameView*>(view->frame_view());
232 const int border = frame->bubble_border()->GetBorderThickness();
233
234 struct {
235 int point;
236 int hit;
210 } cases[] = { 237 } cases[] = {
211 { border, HTSYSMENU }, 238 { border, HTSYSMENU },
212 { border + 10, HTSYSMENU }, 239 { border + 10, HTSYSMENU },
213 { border + 20, HTCLIENT }, 240 { border + 20, HTCLIENT },
214 { border + 50, HTCLIENT }, 241 { border + 50, HTCLIENT },
215 { border + 60, HTCLIENT }, 242 { border + 60, HTCLIENT },
216 { 1000, HTNOWHERE }, 243 { 1000, HTNOWHERE },
217 }; 244 };
218 245
219 for (size_t i = 0; i < arraysize(cases); ++i) { 246 for (size_t i = 0; i < arraysize(cases); ++i) {
220 gfx::Point point(cases[i].point, cases[i].point); 247 gfx::Point point(cases[i].point, cases[i].point);
221 EXPECT_EQ(cases[i].hit, frame->NonClientHitTest(point)) 248 EXPECT_EQ(cases[i].hit, frame->NonClientHitTest(point))
222 << " case " << i << " with border: " << border << ", at point " 249 << " case " << i << " with border: " << border << ", at point "
223 << cases[i].point; 250 << cases[i].point;
224 } 251 }
252
253 dialog->TearDown();
225 } 254 }
226 255
227 TEST_F(DialogTest, HitTest_WithTitle) { 256 TEST_F(DialogTest, HitTest_WithTitle) {
228 // Ensure that BubbleFrameView hit-tests as expected when the title is shown. 257 // Ensure that BubbleFrameView hit-tests as expected when the title is shown.
229 const NonClientView* view = dialog()->GetWidget()->non_client_view(); 258 const NonClientView* view = dialog()->GetWidget()->non_client_view();
230 dialog()->set_title(base::ASCIIToUTF16("Title")); 259 dialog()->set_title(base::ASCIIToUTF16("Title"));
231 dialog()->GetWidget()->UpdateWindowTitle(); 260 dialog()->GetWidget()->UpdateWindowTitle();
232 BubbleFrameView* frame = static_cast<BubbleFrameView*>(view->frame_view()); 261 BubbleFrameView* frame = static_cast<BubbleFrameView*>(view->frame_view());
233 const int border = frame->bubble_border()->GetBorderThickness(); 262 const int border = frame->bubble_border()->GetBorderThickness();
234 263
(...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after
343 // On showing the dialog, the initially focused View will be the OK button. 372 // On showing the dialog, the initially focused View will be the OK button.
344 // Since it is no longer focusable, focus should advance to the next focusable 373 // Since it is no longer focusable, focus should advance to the next focusable
345 // View, which is |textfield|. 374 // View, which is |textfield|.
346 dialog_widget->Show(); 375 dialog_widget->Show();
347 EXPECT_TRUE(textfield->HasFocus()); 376 EXPECT_TRUE(textfield->HasFocus());
348 EXPECT_EQ(textfield, dialog->GetFocusManager()->GetFocusedView()); 377 EXPECT_EQ(textfield, dialog->GetFocusManager()->GetFocusedView());
349 dialog_widget->CloseNow(); 378 dialog_widget->CloseNow();
350 } 379 }
351 380
352 } // namespace views 381 } // namespace views
OLDNEW
« no previous file with comments | « ui/views/bubble/bubble_frame_view_unittest.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698