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

Side by Side Diff: chrome/browser/ui/panels/base_panel_browser_test.cc

Issue 8503037: Fix the problem that notifications and panels overlap. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix per feedback Created 9 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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/panels/base_panel_browser_test.h" 5 #include "chrome/browser/ui/panels/base_panel_browser_test.h"
6 6
7 #include "chrome/browser/ui/browser_list.h" 7 #include "chrome/browser/ui/browser_list.h"
8 8
9 #include "base/command_line.h" 9 #include "base/command_line.h"
10 #include "base/message_loop.h" 10 #include "base/message_loop.h"
(...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after
140 void MockAutoHidingDesktopBarImpl::NotifyVisibilityChange( 140 void MockAutoHidingDesktopBarImpl::NotifyVisibilityChange(
141 AutoHidingDesktopBar::Alignment alignment, 141 AutoHidingDesktopBar::Alignment alignment,
142 AutoHidingDesktopBar::Visibility visibility) { 142 AutoHidingDesktopBar::Visibility visibility) {
143 observer_->OnAutoHidingDesktopBarVisibilityChanged(alignment, visibility); 143 observer_->OnAutoHidingDesktopBarVisibilityChanged(alignment, visibility);
144 } 144 }
145 145
146 void MockAutoHidingDesktopBarImpl::NotifyThicknessChange() { 146 void MockAutoHidingDesktopBarImpl::NotifyThicknessChange() {
147 observer_->OnAutoHidingDesktopBarThicknessChanged(); 147 observer_->OnAutoHidingDesktopBarThicknessChanged();
148 } 148 }
149 149
150 bool ExistsPanel(Panel* panel) {
151 const PanelManager::Panels& panels = PanelManager::GetInstance()->panels();
152 return find(panels.begin(), panels.end(), panel) != panels.end();
153 }
154
150 } // namespace 155 } // namespace
151 156
152 BasePanelBrowserTest::BasePanelBrowserTest() 157 BasePanelBrowserTest::BasePanelBrowserTest()
153 : InProcessBrowserTest(), 158 : InProcessBrowserTest(),
154 testing_work_area_(0, 0, kTestingWorkAreaWidth, 159 testing_work_area_(0, 0, kTestingWorkAreaWidth,
155 kTestingWorkAreaHeight) { 160 kTestingWorkAreaHeight) {
156 #if defined(OS_MACOSX) 161 #if defined(OS_MACOSX)
157 FindBarBridge::disable_animations_during_testing_ = true; 162 FindBarBridge::disable_animations_during_testing_ = true;
158 #endif 163 #endif
159 } 164 }
160 165
161 BasePanelBrowserTest::~BasePanelBrowserTest() { 166 BasePanelBrowserTest::~BasePanelBrowserTest() {
162 } 167 }
163 168
164 void BasePanelBrowserTest::SetUpCommandLine(CommandLine* command_line) { 169 void BasePanelBrowserTest::SetUpCommandLine(CommandLine* command_line) {
165 EnableDOMAutomation(); 170 EnableDOMAutomation();
166 } 171 }
167 172
168 void BasePanelBrowserTest::SetUpOnMainThread() { 173 void BasePanelBrowserTest::SetUpOnMainThread() {
169 InProcessBrowserTest::SetUpOnMainThread(); 174 InProcessBrowserTest::SetUpOnMainThread();
170 175
171 // Setup the work area and desktop bar so that we have consistent testing 176 // Setup the work area and desktop bar so that we have consistent testing
172 // environment for all panel related tests. 177 // environment for all panel related tests.
173 PanelManager* panel_manager = PanelManager::GetInstance(); 178 PanelManager* panel_manager = PanelManager::GetInstance();
174 mock_auto_hiding_desktop_bar_ = new MockAutoHidingDesktopBarImpl( 179 mock_auto_hiding_desktop_bar_ = new MockAutoHidingDesktopBarImpl(
175 panel_manager); 180 panel_manager);
176 panel_manager->set_auto_hiding_desktop_bar(mock_auto_hiding_desktop_bar_); 181 panel_manager->set_auto_hiding_desktop_bar(mock_auto_hiding_desktop_bar_);
177 panel_manager->SetWorkAreaForTesting(testing_work_area_); 182 // Do not use the testing work area if it is empty since we're going to
183 // use the actual work area in some testing scenarios.
184 if (!testing_work_area_.IsEmpty())
185 panel_manager->SetWorkAreaForTesting(testing_work_area_);
178 panel_manager->enable_auto_sizing(false); 186 panel_manager->enable_auto_sizing(false);
179 panel_manager->remove_delays_for_testing(); 187 panel_manager->remove_delays_for_testing();
180 // This is needed so the subsequently created panels can be activated. 188 // This is needed so the subsequently created panels can be activated.
181 // On a Mac, it transforms background-only test process into foreground one. 189 // On a Mac, it transforms background-only test process into foreground one.
182 EXPECT_TRUE(ui_test_utils::BringBrowserWindowToFront(browser())); 190 EXPECT_TRUE(ui_test_utils::BringBrowserWindowToFront(browser()));
183 } 191 }
184 192
193 void BasePanelBrowserTest::WaitForPanelAdded(Panel* panel) {
194 if (ExistsPanel(panel))
195 return;
196 ui_test_utils::WindowedNotificationObserver signal(
jennb 2011/11/11 23:02:43 Should create the signal first, then do the 'if (E
197 chrome::NOTIFICATION_PANEL_ADDED,
198 content::Source<Panel>(panel));
199 signal.Wait();
200 EXPECT_TRUE(ExistsPanel(panel));
201 }
202
203 void BasePanelBrowserTest::WaitForPanelRemoved(Panel* panel) {
204 if (!ExistsPanel(panel))
205 return;
206 ui_test_utils::WindowedNotificationObserver signal(
207 chrome::NOTIFICATION_PANEL_REMOVED,
208 content::Source<Panel>(panel));
209 signal.Wait();
210 EXPECT_FALSE(ExistsPanel(panel));
211 }
212
185 void BasePanelBrowserTest::WaitForPanelActiveState( 213 void BasePanelBrowserTest::WaitForPanelActiveState(
186 Panel* panel, ActiveState expected_state) { 214 Panel* panel, ActiveState expected_state) {
187 DCHECK(expected_state == SHOW_AS_ACTIVE || 215 DCHECK(expected_state == SHOW_AS_ACTIVE ||
188 expected_state == SHOW_AS_INACTIVE); 216 expected_state == SHOW_AS_INACTIVE);
189 ui_test_utils::WindowedNotificationObserver signal( 217 ui_test_utils::WindowedNotificationObserver signal(
190 chrome::NOTIFICATION_PANEL_CHANGED_ACTIVE_STATUS, 218 chrome::NOTIFICATION_PANEL_CHANGED_ACTIVE_STATUS,
191 content::Source<Panel>(panel)); 219 content::Source<Panel>(panel));
192 if (panel->IsActive() == (expected_state == SHOW_AS_ACTIVE)) 220 if (panel->IsActive() == (expected_state == SHOW_AS_ACTIVE))
193 return; // Already in required state. 221 return; // Already in required state.
194 signal.Wait(); 222 signal.Wait();
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after
325 std::string error; 353 std::string error;
326 scoped_refptr<Extension> extension = Extension::Create( 354 scoped_refptr<Extension> extension = Extension::Create(
327 full_path, location, *input_value, 355 full_path, location, *input_value,
328 Extension::STRICT_ERROR_CHECKS, &error); 356 Extension::STRICT_ERROR_CHECKS, &error);
329 EXPECT_TRUE(extension.get()); 357 EXPECT_TRUE(extension.get());
330 EXPECT_STREQ("", error.c_str()); 358 EXPECT_STREQ("", error.c_str());
331 browser()->GetProfile()->GetExtensionService()-> 359 browser()->GetProfile()->GetExtensionService()->
332 OnExtensionInstalled(extension.get(), false, -1); 360 OnExtensionInstalled(extension.get(), false, -1);
333 return extension; 361 return extension;
334 } 362 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698