| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 <string> | 5 #include <string> |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/files/file_path.h" | 8 #include "base/files/file_path.h" |
| 9 #include "base/files/file_util.h" | 9 #include "base/files/file_util.h" |
| 10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
| 11 #include "base/path_service.h" | 11 #include "base/path_service.h" |
| 12 #include "base/prefs/pref_service.h" | 12 #include "base/prefs/pref_service.h" |
| 13 #include "base/strings/utf_string_conversions.h" | 13 #include "base/strings/utf_string_conversions.h" |
| 14 #include "chrome/browser/background/background_mode_manager.h" | 14 #include "chrome/browser/background/background_mode_manager.h" |
| 15 #include "chrome/browser/browser_process.h" | 15 #include "chrome/browser/browser_process.h" |
| 16 #include "chrome/browser/chrome_notification_types.h" | |
| 17 #include "chrome/browser/content_settings/cookie_settings_factory.h" | 16 #include "chrome/browser/content_settings/cookie_settings_factory.h" |
| 18 #include "chrome/browser/defaults.h" | 17 #include "chrome/browser/defaults.h" |
| 19 #include "chrome/browser/infobars/infobar_service.h" | 18 #include "chrome/browser/infobars/infobar_service.h" |
| 20 #include "chrome/browser/lifetime/application_lifetime.h" | 19 #include "chrome/browser/lifetime/application_lifetime.h" |
| 21 #include "chrome/browser/prefs/session_startup_pref.h" | 20 #include "chrome/browser/prefs/session_startup_pref.h" |
| 22 #include "chrome/browser/profiles/profile.h" | 21 #include "chrome/browser/profiles/profile.h" |
| 23 #include "chrome/browser/profiles/profile_impl.h" | 22 #include "chrome/browser/profiles/profile_impl.h" |
| 24 #include "chrome/browser/profiles/profile_manager.h" | 23 #include "chrome/browser/profiles/profile_manager.h" |
| 25 #include "chrome/browser/sessions/session_restore_test_helper.h" | 24 #include "chrome/browser/sessions/session_restore_test_helper.h" |
| 26 #include "chrome/browser/sessions/session_service_factory.h" | 25 #include "chrome/browser/sessions/session_service_factory.h" |
| (...skipping 276 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 303 EXPECT_EQ(text_present, | 302 EXPECT_EQ(text_present, |
| 304 post_interceptor_->DidLastUploadContain("posted-text")); | 303 post_interceptor_->DidLastUploadContain("posted-text")); |
| 305 EXPECT_EQ(text_present, | 304 EXPECT_EQ(text_present, |
| 306 post_interceptor_->DidLastUploadContain("text-entered")); | 305 post_interceptor_->DidLastUploadContain("text-entered")); |
| 307 EXPECT_EQ(password_present, | 306 EXPECT_EQ(password_present, |
| 308 post_interceptor_->DidLastUploadContain("posted-password")); | 307 post_interceptor_->DidLastUploadContain("posted-password")); |
| 309 EXPECT_EQ(password_present, | 308 EXPECT_EQ(password_present, |
| 310 post_interceptor_->DidLastUploadContain("password-entered")); | 309 post_interceptor_->DidLastUploadContain("password-entered")); |
| 311 } | 310 } |
| 312 | 311 |
| 313 void CloseBrowserSynchronously(Browser* browser, bool close_all_windows) { | |
| 314 content::WindowedNotificationObserver observer( | |
| 315 chrome::NOTIFICATION_BROWSER_CLOSED, | |
| 316 content::NotificationService::AllSources()); | |
| 317 if (close_all_windows) | |
| 318 chrome::CloseAllBrowsers(); | |
| 319 else | |
| 320 browser->window()->Close(); | |
| 321 #if defined(OS_MACOSX) | |
| 322 // BrowserWindowController depends on the auto release pool being recycled | |
| 323 // in the message loop to delete itself, which frees the Browser object | |
| 324 // which fires this event. | |
| 325 AutoreleasePool()->Recycle(); | |
| 326 #endif | |
| 327 observer.Wait(); | |
| 328 } | |
| 329 | |
| 330 virtual Browser* QuitBrowserAndRestore(Browser* browser, | 312 virtual Browser* QuitBrowserAndRestore(Browser* browser, |
| 331 bool close_all_windows) { | 313 bool close_all_windows) { |
| 332 Profile* profile = browser->profile(); | 314 Profile* profile = browser->profile(); |
| 333 | 315 |
| 334 // Close the browser. | 316 // Close the browser. |
| 335 chrome::IncrementKeepAliveCount(); | 317 chrome::IncrementKeepAliveCount(); |
| 336 CloseBrowserSynchronously(browser, close_all_windows); | 318 if (close_all_windows) |
| 319 CloseAllBrowsers(); |
| 320 else |
| 321 CloseBrowserSynchronously(browser); |
| 337 | 322 |
| 338 SessionServiceTestHelper helper; | 323 SessionServiceTestHelper helper; |
| 339 helper.SetService( | 324 helper.SetService( |
| 340 SessionServiceFactory::GetForProfileForSessionRestore(profile)); | 325 SessionServiceFactory::GetForProfileForSessionRestore(profile)); |
| 341 helper.SetForceBrowserNotAliveWithNoWindows(true); | 326 helper.SetForceBrowserNotAliveWithNoWindows(true); |
| 342 helper.ReleaseService(); | 327 helper.ReleaseService(); |
| 343 | 328 |
| 344 // Create a new window, which should trigger session restore. | 329 // Create a new window, which should trigger session restore. |
| 345 ui_test_utils::BrowserAddedObserver window_observer; | 330 ui_test_utils::BrowserAddedObserver window_observer; |
| 346 chrome::NewEmptyWindow(profile, chrome::HOST_DESKTOP_TYPE_NATIVE); | 331 chrome::NewEmptyWindow(profile, chrome::HOST_DESKTOP_TYPE_NATIVE); |
| (...skipping 447 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 794 // Tests that session cookies are cleared if the last window to close is a | 779 // Tests that session cookies are cleared if the last window to close is a |
| 795 // popup. | 780 // popup. |
| 796 IN_PROC_BROWSER_TEST_F(NoSessionRestoreTest, | 781 IN_PROC_BROWSER_TEST_F(NoSessionRestoreTest, |
| 797 SessionCookiesBrowserClosePopupLast) { | 782 SessionCookiesBrowserClosePopupLast) { |
| 798 StoreDataWithPage("session_cookies.html"); | 783 StoreDataWithPage("session_cookies.html"); |
| 799 Browser* popup = new Browser(Browser::CreateParams( | 784 Browser* popup = new Browser(Browser::CreateParams( |
| 800 Browser::TYPE_POPUP, | 785 Browser::TYPE_POPUP, |
| 801 browser()->profile(), | 786 browser()->profile(), |
| 802 chrome::HOST_DESKTOP_TYPE_NATIVE)); | 787 chrome::HOST_DESKTOP_TYPE_NATIVE)); |
| 803 popup->window()->Show(); | 788 popup->window()->Show(); |
| 804 CloseBrowserSynchronously(browser(), false); | 789 CloseBrowserSynchronously(browser()); |
| 805 Browser* new_browser = QuitBrowserAndRestore(popup, false); | 790 Browser* new_browser = QuitBrowserAndRestore(popup, false); |
| 806 if (browser_defaults::kBrowserAliveWithNoWindows) | 791 if (browser_defaults::kBrowserAliveWithNoWindows) |
| 807 NavigateAndCheckStoredData(new_browser, "session_cookies.html"); | 792 NavigateAndCheckStoredData(new_browser, "session_cookies.html"); |
| 808 else | 793 else |
| 809 StoreDataWithPage(new_browser, "session_cookies.html"); | 794 StoreDataWithPage(new_browser, "session_cookies.html"); |
| 810 } | 795 } |
| 811 | 796 |
| 812 IN_PROC_BROWSER_TEST_F(NoSessionRestoreTest, CookiesClearedOnBrowserClose) { | 797 IN_PROC_BROWSER_TEST_F(NoSessionRestoreTest, CookiesClearedOnBrowserClose) { |
| 813 StoreDataWithPage("cookies.html"); | 798 StoreDataWithPage("cookies.html"); |
| 814 | 799 |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 855 CookieSettingsFactory::GetForProfile(new_browser->profile()) | 840 CookieSettingsFactory::GetForProfile(new_browser->profile()) |
| 856 ->SetDefaultCookieSetting(CONTENT_SETTING_SESSION_ONLY); | 841 ->SetDefaultCookieSetting(CONTENT_SETTING_SESSION_ONLY); |
| 857 // ... even if background mode is active. | 842 // ... even if background mode is active. |
| 858 EnableBackgroundMode(); | 843 EnableBackgroundMode(); |
| 859 new_browser = QuitBrowserAndRestore(new_browser, true); | 844 new_browser = QuitBrowserAndRestore(new_browser, true); |
| 860 StoreDataWithPage(new_browser, "cookies.html"); | 845 StoreDataWithPage(new_browser, "cookies.html"); |
| 861 DisableBackgroundMode(); | 846 DisableBackgroundMode(); |
| 862 new_browser = QuitBrowserAndRestore(new_browser, true); | 847 new_browser = QuitBrowserAndRestore(new_browser, true); |
| 863 StoreDataWithPage(new_browser, "cookies.html"); | 848 StoreDataWithPage(new_browser, "cookies.html"); |
| 864 } | 849 } |
| OLD | NEW |