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

Unified Diff: chrome/browser/notifications/notification_browsertest.cc

Issue 11359174: Convert HTML5 notification pyauto tests to browser_tests. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 8 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | chrome/test/data/notifications/notification_tester.html » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/notifications/notification_browsertest.cc
diff --git a/chrome/browser/notifications/notification_browsertest.cc b/chrome/browser/notifications/notification_browsertest.cc
index 3a693da62ab1bc75aa4622195efb5b80c72b9247..92da7364c3155cf63ab0b9dec1bc46b24c128bb5 100644
--- a/chrome/browser/notifications/notification_browsertest.cc
+++ b/chrome/browser/notifications/notification_browsertest.cc
@@ -2,25 +2,433 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+#include <deque>
+#include <string>
+
+#include "base/bind.h"
+#include "base/callback.h"
+#include "base/compiler_specific.h"
+#include "base/memory/ref_counted.h"
+#include "base/run_loop.h"
+#include "base/stringprintf.h"
+#include "base/utf_string_conversions.h"
+#include "chrome/browser/api/infobars/confirm_infobar_delegate.h"
+#include "chrome/browser/api/infobars/infobar_delegate.h"
+#include "chrome/browser/browser_process.h"
#include "chrome/browser/infobars/infobar_tab_helper.h"
+#include "chrome/browser/notifications/balloon.h"
+#include "chrome/browser/notifications/balloon_collection.h"
+#include "chrome/browser/notifications/balloon_host.h"
+#include "chrome/browser/notifications/desktop_notification_service.h"
+#include "chrome/browser/notifications/desktop_notification_service_factory.h"
+#include "chrome/browser/notifications/notification.h"
+#include "chrome/browser/notifications/notification_ui_manager.h"
+#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_tabstrip.h"
+#include "chrome/browser/ui/browser_window.h"
+#include "chrome/browser/ui/tab_contents/tab_contents.h"
+#include "chrome/common/chrome_notification_types.h"
+#include "chrome/common/content_settings.h"
+#include "chrome/common/content_settings_pattern.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "chrome/test/base/ui_test_utils.h"
+#include "content/public/browser/notification_service.h"
+#include "content/public/browser/notification_source.h"
+#include "content/public/browser/notification_types.h"
+#include "content/public/browser/render_view_host.h"
#include "content/public/browser/web_contents.h"
#include "content/public/test/browser_test_utils.h"
+#include "content/public/test/test_utils.h"
+#include "googleurl/src/gurl.h"
#include "net/base/net_util.h"
#include "net/test/test_server.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "webkit/glue/window_open_disposition.h"
+
+namespace {
+
+const char kExpectedIconUrl[] = "files/notifications/no_such_file.png";
-class NotificationsPermissionTest : public InProcessBrowserTest {
+enum InfobarAction {
+ DISMISS = 0,
+ ALLOW,
+ DENY,
+};
+
+class NotificationBalloonChangeObserver : public content::NotificationObserver {
public:
- NotificationsPermissionTest() {}
+ NotificationBalloonChangeObserver()
+ : collection_(
+ g_browser_process->notification_ui_manager()->balloon_collection()),
+ collection_changed_(false),
+ notification_received_(false),
+ running_(false),
+ done_(false) {
+ registrar_.Add(this, chrome::NOTIFICATION_NOTIFY_BALLOON_CONNECTED,
+ content::NotificationService::AllSources());
+ registrar_.Add(this, chrome::NOTIFICATION_NOTIFY_BALLOON_DISCONNECTED,
+ content::NotificationService::AllSources());
+ collection_->set_on_collection_changed_callback(
+ base::Bind(&NotificationBalloonChangeObserver::onCollectionChanged,
+ base::Unretained(this)));
+ }
+
+ virtual ~NotificationBalloonChangeObserver() {
+ collection_->set_on_collection_changed_callback(base::Closure());
+ }
+
+ bool Wait() {
+ if (!Check()) {
+ running_ = true;
+ message_loop_runner_ = new content::MessageLoopRunner;
+ message_loop_runner_->Run();
+ EXPECT_TRUE(done_);
+ }
+ return done_;
+ }
+
+ bool Check() {
stevenjb 2012/11/29 03:32:16 nit: 'if (done_) return true;' might be slightly m
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ if (!done_ && collection_changed_ && notification_received_) {
+ done_ = true;
+ if (running_) {
+ message_loop_runner_->Quit();
+ running_ = false;
+ }
+ }
+ return done_;
+ }
+
+ void onCollectionChanged() {
stevenjb 2012/11/29 03:32:16 OnCollectionChanged()
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ collection_changed_ = true;
+ Check();
+ }
+
+ // Overridden from content::NotificationObserver:
+ virtual void Observe(int type,
+ const content::NotificationSource& source,
+ const content::NotificationDetails& details) OVERRIDE {
stevenjb 2012/11/29 03:32:16 test that type == BALLOON_CONNECTED or BALLOON_DIS
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ notification_received_ = true;
+ Check();
+ }
+
+ private:
+ content::NotificationRegistrar registrar_;
+ BalloonCollection* collection_;
+
+ bool collection_changed_;
+ bool notification_received_;
+ bool running_;
+ bool done_;
+ scoped_refptr<content::MessageLoopRunner> message_loop_runner_;
+
+ DISALLOW_COPY_AND_ASSIGN(NotificationBalloonChangeObserver);
};
-// If this flakes, use http://crbug.com/62311 and http://crbug.com/74428.
-IN_PROC_BROWSER_TEST_F(NotificationsPermissionTest, TestUserGestureInfobar) {
+} // namespace
+
+class NotificationsTest : public InProcessBrowserTest {
+ public:
+ NotificationsTest() {}
+
+ protected:
+ // Overriden from InProcessBrowserTest:
+ virtual void SetUpInProcessBrowserTestFixture() OVERRIDE;
+
+ const std::deque<Balloon*>& GetActiveBalloons();
+ int GetNotificationCount();
+
+ bool CloseNotificationAndWait(const Notification& notification);
+ void CloseBrowserWindow(Browser* browser);
+ void CrashTab(Browser* browser, int index);
+ void CrashNotification(Balloon* balloon);
+
+ void SetDefaultPermissionSetting(ContentSetting setting);
+ void DenyOrigin(const GURL& origin);
+ void AllowOrigin(const GURL& origin);
+ void AllowAllOrigins();
+
+ void VerifyInfobar(const Browser* browser,
+ const std::string& origin,
+ int index);
+ std::string CreateNotification(Browser* browser,
+ bool wait_for_new_balloon,
+ const char* icon,
+ const char* title,
+ const char* body,
+ const char* replace_id);
+ std::string CreateSimpleNotification(Browser* browser,
+ bool wait_for_new_balloon);
+ bool RequestPermissionAndWait(Browser* browser);
+ bool CancelNotification(const char* notification_id, Browser* browser);
+ bool PerformActionOnInfobar(Browser* browser,
+ InfobarAction action,
+ int infobar_index,
+ int tab_index);
+ void GetPrefsByContentSetting(ContentSetting setting,
+ ContentSettingsForOneType* settings);
+ bool CheckOriginInSetting(const ContentSettingsForOneType& settings,
+ const GURL& origin);
+
+ GURL empty_page_url_;
+ GURL test_page_url_;
+
+ private:
+ void DropOriginPreference(const GURL& origin);
+ DesktopNotificationService* GetDesktopNotificationService();
+};
+
+void NotificationsTest::SetUpInProcessBrowserTestFixture() {
+ InProcessBrowserTest::SetUpInProcessBrowserTestFixture();
+
ASSERT_TRUE(test_server()->Start());
+ empty_page_url_ = test_server()->GetURL("files/empty.html");
+ test_page_url_ = test_server()->GetURL(
+ "files/notifications/notification_tester.html");
+}
+
+const std::deque<Balloon*>& NotificationsTest::GetActiveBalloons() {
+ NotificationUIManager* manager = g_browser_process->notification_ui_manager();
+ return manager->balloon_collection()->GetActiveBalloons();
stevenjb 2012/11/29 03:32:16 nit: No need for local manager variable
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+}
+
+int NotificationsTest::GetNotificationCount() {
+ NotificationUIManager* manager = g_browser_process->notification_ui_manager();
+ return manager->balloon_collection()->GetActiveBalloons().size();
stevenjb 2012/11/29 03:32:16 nit: No need for local manager variable
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+}
+
+bool NotificationsTest::CloseNotificationAndWait(
+ const Notification& notification) {
+ NotificationBalloonChangeObserver observer;
+ NotificationUIManager* manager = g_browser_process->notification_ui_manager();
+ bool success = manager->CancelById(notification.notification_id());
stevenjb 2012/11/29 03:32:16 nit: No need for local manager variable
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ if (success)
+ return observer.Wait();
+ return false;
+}
+void NotificationsTest::CloseBrowserWindow(Browser* browser) {
+ content::WindowedNotificationObserver observer(
+ chrome::NOTIFICATION_BROWSER_CLOSED,
+ content::Source<Browser>(browser));
+ browser->window()->Close();
+ observer.Wait();
+}
+
+void NotificationsTest::CrashTab(Browser* browser, int index) {
+ content::CrashTab(chrome::GetWebContentsAt(browser, index));
+}
+
+void NotificationsTest::CrashNotification(Balloon* balloon) {
+ content::CrashTab(balloon->balloon_view()->GetHost()->web_contents());
+}
+
+void NotificationsTest::SetDefaultPermissionSetting(ContentSetting setting) {
+ DesktopNotificationService* service = GetDesktopNotificationService();
+ service->SetDefaultContentSetting(setting);
+}
+
+void NotificationsTest::DenyOrigin(const GURL& origin) {
+ DropOriginPreference(origin);
+ GetDesktopNotificationService()->DenyPermission(origin);
+}
+
+void NotificationsTest::AllowOrigin(const GURL& origin) {
+ DropOriginPreference(origin);
+ GetDesktopNotificationService()->GrantPermission(origin);
+}
+
+void NotificationsTest::AllowAllOrigins() {
+ GetDesktopNotificationService()->ResetAllOrigins();
+ GetDesktopNotificationService()->SetDefaultContentSetting(
+ CONTENT_SETTING_ALLOW);
+}
+
+void NotificationsTest::VerifyInfobar(
+ const Browser* browser,
+ const std::string& origin,
+ int index) {
+ InfoBarTabHelper* infobar_helper = InfoBarTabHelper::FromWebContents(
+ chrome::GetWebContentsAt(browser, index));
+
+ ASSERT_EQ(1U, infobar_helper->GetInfoBarCount());
+ InfoBarDelegate* infobar = infobar_helper->GetInfoBarDelegateAt(0);
+ ASSERT_TRUE(infobar->AsConfirmInfoBarDelegate());
stevenjb 2012/11/29 03:32:16 Move below as ASSERT_TRUE(confirm_infobar)
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ ConfirmInfoBarDelegate* confirm_infobar = infobar->AsConfirmInfoBarDelegate();
+ int buttons = confirm_infobar->GetButtons();
+ if (buttons & ConfirmInfoBarDelegate::BUTTON_OK) {
+ EXPECT_EQ(
+ ASCIIToUTF16("Allow"),
+ confirm_infobar->GetButtonLabel(ConfirmInfoBarDelegate::BUTTON_OK));
+ } else {
+ EXPECT_TRUE(false);
stevenjb 2012/11/29 03:32:16 This seems weird, I'd ask about a better way to do
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Removed the if-else block, just check the OK butto
+ }
+ if (buttons & ConfirmInfoBarDelegate::BUTTON_CANCEL) {
+ EXPECT_EQ(
+ ASCIIToUTF16("Deny"),
+ confirm_infobar->GetButtonLabel(ConfirmInfoBarDelegate::BUTTON_CANCEL));
+ } else {
+ EXPECT_TRUE(false);
stevenjb 2012/11/29 03:32:16 same here
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Removed the if-else block, just check the Cancel b
+ }
+ std::string text = base::StringPrintf(
+ "Allow %s to show desktop notifications?",
+ origin.c_str());
stevenjb 2012/11/29 03:32:16 Is this translation dependent? Not sure how we do
chrisgao (Use stgao instead) 2012/11/29 22:49:31 After discussion with Ken, decided to remove the v
+ EXPECT_EQ(UTF8ToUTF16(text), confirm_infobar->GetMessageText());
+}
+
+std::string NotificationsTest::CreateNotification(
+ Browser* browser,
+ bool wait_for_new_balloon,
+ const char* icon,
+ const char* title,
+ const char* body,
+ const char* replace_id) {
+ std::string script = base::StringPrintf(
+ "createNotification('%s', '%s', '%s', '%s');",
+ icon,
+ title,
+ body,
+ replace_id);
stevenjb 2012/11/29 03:32:16 nit: no need for separate lines for the args?
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+
+ NotificationBalloonChangeObserver observer;
+ std::string result;
+ bool success = content::ExecuteJavaScriptAndExtractString(
+ chrome::GetActiveWebContents(browser)->GetRenderViewHost(),
+ L"",
+ UTF8ToWide(script),
+ &result);
+ if (success && result != "-1" && wait_for_new_balloon)
+ success = observer.Wait();
+ EXPECT_TRUE(success);
+
+ return result;
+}
+
+std::string NotificationsTest::CreateSimpleNotification(
+ Browser* browser,
+ bool wait_for_new_balloon) {
+ return CreateNotification(
+ browser,
+ wait_for_new_balloon,
+ "no_such_file.png",
+ "My Title",
+ "My Body",
+ "");
+}
+
+bool NotificationsTest::RequestPermissionAndWait(Browser* browser) {
+ InfoBarTabHelper* infobar_helper = InfoBarTabHelper::FromWebContents(
+ chrome::GetActiveWebContents(browser));
+ content::WindowedNotificationObserver observer(
+ chrome::NOTIFICATION_TAB_CONTENTS_INFOBAR_ADDED,
+ content::Source<InfoBarTabHelper>(infobar_helper));
+ std::string result;
+ bool success = content::ExecuteJavaScriptAndExtractString(
+ chrome::GetActiveWebContents(browser)->GetRenderViewHost(),
+ L"",
+ L"requestPermission();",
+ &result);
+ if (!success || result != "1")
+ return false;
+ observer.Wait();
+ return true;
+}
+
+bool NotificationsTest::CancelNotification(
+ const char* notification_id,
+ Browser* browser) {
+ std::string script = base::StringPrintf(
+ "cancelNotification('%s');",
+ notification_id);
+
+ NotificationBalloonChangeObserver observer;
+ std::string result;
+ bool success = content::ExecuteJavaScriptAndExtractString(
+ chrome::GetActiveWebContents(browser)->GetRenderViewHost(),
+ L"",
+ UTF8ToWide(script),
+ &result);
+ if (!success || result != "1")
+ return false;
+ return observer.Wait();
+}
+
+bool NotificationsTest::PerformActionOnInfobar(
+ Browser* browser,
+ InfobarAction action,
+ int infobar_index,
+ int tab_index) {
+ InfoBarTabHelper* infobar_helper = InfoBarTabHelper::FromWebContents(
+ chrome::GetWebContentsAt(browser, tab_index));
+
+ InfoBarDelegate* infobar = infobar_helper->GetInfoBarDelegateAt(
+ infobar_index);
+ switch (action) {
+ case DISMISS: {
+ infobar->InfoBarDismissed();
+ infobar_helper->RemoveInfoBar(infobar);
+ return true;
+ }
+ case ALLOW: {
+ ConfirmInfoBarDelegate* confirm_bar = infobar->AsConfirmInfoBarDelegate();
+ if (confirm_bar->Accept()) {
+ infobar_helper->RemoveInfoBar(infobar);
+ return true;
+ }
+ }
+ case DENY: {
+ ConfirmInfoBarDelegate* confirm_bar = infobar->AsConfirmInfoBarDelegate();
+ if (confirm_bar->Cancel()) {
+ infobar_helper->RemoveInfoBar(infobar);
+ return true;
+ }
+ }
+ }
+
+ return false;
+}
+
+void NotificationsTest::GetPrefsByContentSetting(
+ ContentSetting setting,
+ ContentSettingsForOneType* settings) {
+ DesktopNotificationService* service = GetDesktopNotificationService();
+ service->GetNotificationsSettings(settings);
+ for (ContentSettingsForOneType::iterator it = settings->begin();
+ it != settings->end();) {
stevenjb 2012/11/29 03:32:16 nit: ' ' between ; and )
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ if (it->setting != setting || it->source.compare("preference") != 0) {
+ it = settings->erase(it);
+ } else {
+ ++it;
+ }
stevenjb 2012/11/29 03:32:16 nit: {} unnecessary for single line ifs.
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ }
+}
+
+bool NotificationsTest::CheckOriginInSetting(
+ const ContentSettingsForOneType& settings,
+ const GURL& origin) {
+ ContentSettingsPattern pattern =
+ ContentSettingsPattern::FromURLNoWildcard(origin);
+ for (ContentSettingsForOneType::const_iterator it = settings.begin();
+ it != settings.end(); ++it) {
+ if (it->primary_pattern == pattern) {
+ return true;
+ }
stevenjb 2012/11/29 03:32:16 nit: no {}
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ }
+ return false;
+}
+
+void NotificationsTest::DropOriginPreference(const GURL& origin) {
+ GetDesktopNotificationService()->ClearSetting(
+ ContentSettingsPattern::FromURLNoWildcard(origin));
+}
+
+DesktopNotificationService* NotificationsTest::GetDesktopNotificationService() {
+ Profile* profile = browser()->profile();
+ return DesktopNotificationServiceFactory::GetForProfile(profile);
+}
+
+// If this flakes, use http://crbug.com/62311 and http://crbug.com/74428.
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestUserGestureInfobar) {
ui_test_utils::NavigateToURL(
browser(),
test_server()->GetURL(
@@ -41,9 +449,7 @@ IN_PROC_BROWSER_TEST_F(NotificationsPermissionTest, TestUserGestureInfobar) {
}
// If this flakes, use http://crbug.com/62311.
-IN_PROC_BROWSER_TEST_F(NotificationsPermissionTest, TestNoUserGestureInfobar) {
- ASSERT_TRUE(test_server()->Start());
-
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestNoUserGestureInfobar) {
// Load a page which just does a request; no user gesture should result
// in no infobar.
ui_test_utils::NavigateToURL(
@@ -54,3 +460,369 @@ IN_PROC_BROWSER_TEST_F(NotificationsPermissionTest, TestNoUserGestureInfobar) {
EXPECT_EQ(0U, InfoBarTabHelper::FromWebContents(
chrome::GetWebContentsAt(browser(), 0))->GetInfoBarCount());
}
+
+// Disable new testcases on Chrome OS due to failure on creating notification.
+#if !defined(OS_CHROMEOS)
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestCreateSimpleNotification) {
+ // Creates a simple notification.
+ AllowAllOrigins();
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateSimpleNotification(browser(), true);
+ EXPECT_NE("-1", result);
+
+ const std::deque<Balloon*>& balloons = GetActiveBalloons();
+ ASSERT_EQ(1U, balloons.size());
+ Balloon* balloon = balloons[0];
+ const Notification& notification = balloon->notification();
+ GURL EXPECTED_ICON_URL = test_server()->GetURL(kExpectedIconUrl);
+ EXPECT_EQ(EXPECTED_ICON_URL, notification.icon_url());
+ EXPECT_EQ(ASCIIToUTF16("My Title"), notification.title());
+ EXPECT_EQ(ASCIIToUTF16("My Body"), notification.body());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestCloseNotification) {
+ // Creates a notification and closes it.
+ AllowAllOrigins();
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateSimpleNotification(browser(), true);
+ EXPECT_NE("-1", result);
+
+ const std::deque<Balloon*>& balloons = GetActiveBalloons();
+ ASSERT_EQ(1U, balloons.size());
+ EXPECT_TRUE(CloseNotificationAndWait(balloons[0]->notification()));
+ ASSERT_EQ(0, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestCancelNotification) {
+ // Creates a notification and cancels it in the origin page.
+ AllowAllOrigins();
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string note_id = CreateSimpleNotification(browser(), true);
+ EXPECT_NE(note_id, "-1");
+
+ ASSERT_EQ(1, GetNotificationCount());
+ ASSERT_TRUE(CancelNotification(note_id.c_str(), browser()));
+ ASSERT_EQ(0, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestPermissionInfobarAppears) {
+ // Requests notification privileges and verifies the infobar appears.
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+
+ ASSERT_EQ(0, GetNotificationCount());
+ VerifyInfobar(browser(), test_page_url_.host(), 0);
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestAllowOnPermissionInfobar) {
+ // Tries to create a notification and clicks allow on the infobar.
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ // This notification should not be shown because we do not have permission.
+ CreateSimpleNotification(browser(), false);
+ ASSERT_EQ(0, GetNotificationCount());
+
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+ ASSERT_TRUE(PerformActionOnInfobar(browser(), ALLOW, 0, 0));
+
+ CreateSimpleNotification(browser(), true);
+ EXPECT_EQ(1, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestDenyOnPermissionInfobar) {
+ // Test that no notification is created
+ // when Deny is chosen from permission infobar.
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+ PerformActionOnInfobar(browser(), DENY, 0, 0);
+ CreateSimpleNotification(browser(), false);
+ ASSERT_EQ(0, GetNotificationCount());
+ ContentSettingsForOneType settings;
+ GetPrefsByContentSetting(CONTENT_SETTING_BLOCK, &settings);
+ EXPECT_TRUE(CheckOriginInSetting(settings, test_page_url_));
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestClosePermissionInfobar) {
+ // Test that no notification is created when permission infobar is dismissed.
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+ PerformActionOnInfobar(browser(), DISMISS, 0, 0);
+ CreateSimpleNotification(browser(), false);
+ ASSERT_EQ(0, GetNotificationCount());
+ ContentSettingsForOneType settings;
+ GetPrefsByContentSetting(CONTENT_SETTING_BLOCK, &settings);
+ EXPECT_EQ(0U, settings.size());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestNotificationWithPropertyMissing) {
+ // Test that a notification can be created if one property is missing.
+ AllowAllOrigins();
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateSimpleNotification(browser(), true);
+ EXPECT_NE("-1", result);
+
+ const std::deque<Balloon*>& balloons = GetActiveBalloons();
+ ASSERT_EQ(1U, balloons.size());
+ Balloon* balloon = balloons[0];
+ const Notification& notification = balloon->notification();
+ GURL EXPECTED_ICON_URL = test_server()->GetURL(kExpectedIconUrl);
+ EXPECT_EQ(EXPECTED_ICON_URL, notification.icon_url());
+ EXPECT_EQ(ASCIIToUTF16("My Title"), notification.title());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestAllowNotificationsFromAllSites) {
+ // Verify that all domains can be allowed to show notifications.
+ SetDefaultPermissionSetting(CONTENT_SETTING_ALLOW);
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateSimpleNotification(browser(), true);
+ EXPECT_NE("-1", result);
+
+ ASSERT_EQ(1, GetNotificationCount());
+ EXPECT_EQ(0U, InfoBarTabHelper::FromWebContents(
+ chrome::GetWebContentsAt(browser(), 0))->GetInfoBarCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestDenyNotificationsFromAllSites) {
+ // Verify that no domain can show notifications.
+ SetDefaultPermissionSetting(CONTENT_SETTING_BLOCK);
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateSimpleNotification(browser(), false);
+ EXPECT_EQ("-1", result);
+
+ ASSERT_EQ(0, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestDenyDomainAndAllowAll) {
+ // Verify that denying a domain and allowing all shouldn't show
+ // notifications from the denied domain.
+ DenyOrigin(test_page_url_.GetOrigin());
+ SetDefaultPermissionSetting(CONTENT_SETTING_ALLOW);
+
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateSimpleNotification(browser(), false);
+ EXPECT_EQ("-1", result);
+
+ ASSERT_EQ(0, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestAllowDomainAndDenyAll) {
+ // Verify that allowing a domain and denying all others should show
+ // notifications from the allowed domain.
+ AllowOrigin(test_page_url_.GetOrigin());
+ SetDefaultPermissionSetting(CONTENT_SETTING_BLOCK);
+
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateSimpleNotification(browser(), true);
+ EXPECT_NE("-1", result);
+
+ ASSERT_EQ(1, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestDenyAndThenAllowDomain) {
+ // Verify that denying and again allowing should show notifications.
+ DenyOrigin(test_page_url_.GetOrigin());
+
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateSimpleNotification(browser(), false);
+ EXPECT_EQ("-1", result);
+
+ ASSERT_EQ(0, GetNotificationCount());
+
+ AllowOrigin(test_page_url_.GetOrigin());
+ result = CreateSimpleNotification(browser(), true);
+ EXPECT_NE("-1", result);
+
+ ASSERT_EQ(1, GetNotificationCount());
+ EXPECT_EQ(0U, InfoBarTabHelper::FromWebContents(
+ chrome::GetWebContentsAt(browser(), 0))->GetInfoBarCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestCreateDenyCloseNotifications) {
+ // Verify able to create, deny, and close the notification.
+ AllowAllOrigins();
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ CreateSimpleNotification(browser(), true);
+ ASSERT_EQ(1, GetNotificationCount());
+
+ DenyOrigin(test_page_url_.GetOrigin());
+ ContentSettingsForOneType settings;
+ GetPrefsByContentSetting(CONTENT_SETTING_BLOCK, &settings);
+ ASSERT_TRUE(CheckOriginInSetting(settings, test_page_url_.GetOrigin()));
+
+ const std::deque<Balloon*>& balloons1 = GetActiveBalloons();
+ EXPECT_EQ(1U, balloons1.size());
+ ASSERT_TRUE(CloseNotificationAndWait(balloons1[0]->notification()));
+ ASSERT_EQ(0, GetNotificationCount());
+}
+
+// Crashes on Linux/Win. See http://crbug.com/160657.
+IN_PROC_BROWSER_TEST_F(
+ NotificationsTest,
+ DISABLED_TestOriginPrefsNotSavedInIncognito) {
+ // Verify that allow/deny origin preferences are not saved in incognito.
+ Browser* incognito = CreateIncognitoBrowser();
+ ui_test_utils::NavigateToURL(incognito, test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(incognito));
+ PerformActionOnInfobar(incognito, DENY, 0, 0);
+ CloseBrowserWindow(incognito);
+
+ incognito = CreateIncognitoBrowser();
+ ui_test_utils::NavigateToURL(incognito, test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(incognito));
+ PerformActionOnInfobar(incognito, ALLOW, 0, 0);
+ CreateSimpleNotification(incognito, true);
+ ASSERT_EQ(1, GetNotificationCount());
+ CloseBrowserWindow(incognito);
+
+ incognito = CreateIncognitoBrowser();
+ ui_test_utils::NavigateToURL(incognito, test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(incognito));
+
+ ContentSettingsForOneType settings;
+ GetPrefsByContentSetting(CONTENT_SETTING_BLOCK, &settings);
+ EXPECT_EQ(0U, settings.size());
+ GetPrefsByContentSetting(CONTENT_SETTING_ALLOW, &settings);
+ EXPECT_EQ(0U, settings.size());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestExitBrowserWithInfobar) {
+ // Exit the browser window, when the infobar appears.
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestCrashTabWithPermissionInfobar) {
+ // Test crashing the tab with permission infobar doesn't crash Chrome.
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser(),
+ empty_page_url_,
+ NEW_BACKGROUND_TAB,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_TAB);
+ chrome::ActivateTabAt(browser(), 0, true);
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+ CrashTab(browser(), 0);
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestKillNotificationProcess) {
+ // Test killing a notification doesn't crash Chrome.
+ AllowAllOrigins();
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ CreateSimpleNotification(browser(), true);
+ ASSERT_EQ(1, GetNotificationCount());
+
+ const std::deque<Balloon*>& balloons = GetActiveBalloons();
+ ASSERT_EQ(1U, balloons.size());
+ CrashNotification(balloons[0]);
+ ASSERT_EQ(0, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestIncognitoNotification) {
+ // Test notifications in incognito window.
+ Browser* browser = CreateIncognitoBrowser();
+ ui_test_utils::NavigateToURL(browser, test_page_url_);
+ chrome::ActivateTabAt(browser, 0, true);
+ ASSERT_TRUE(RequestPermissionAndWait(browser));
+ PerformActionOnInfobar(browser, ALLOW, 0, 0);
+ CreateSimpleNotification(browser, true);
+ ASSERT_EQ(1, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestCloseTabWithPermissionInfobar) {
+ // Test that user can close tab when infobar present.
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser(),
+ GURL("about:blank"),
+ NEW_BACKGROUND_TAB,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_TAB);
+ chrome::ActivateTabAt(browser(), 0, true);
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+ content::WindowedNotificationObserver observer(
+ content::NOTIFICATION_WEB_CONTENTS_DESTROYED,
+ content::NotificationService::AllSources());
+ chrome::CloseWebContents(browser(), chrome::GetWebContentsAt(browser(), 0));
+ observer.Wait();
+}
+
+IN_PROC_BROWSER_TEST_F(
+ NotificationsTest,
+ TestNavigateAwayWithPermissionInfobar) {
+ // Test navigating away when an infobar is present,
+ // then trying to create a notification from the same page.
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser(),
+ GURL("about:blank"),
+ NEW_BACKGROUND_TAB,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_TAB);
+ chrome::ActivateTabAt(browser(), 0, true);
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ ASSERT_TRUE(RequestPermissionAndWait(browser()));
+ PerformActionOnInfobar(browser(), ALLOW, 0, 0);
+ CreateSimpleNotification(browser(), true);
+ ASSERT_EQ(1, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestCrashRendererNotificationRemain) {
+ // Test crashing renderer does not close or crash notification.
+ AllowAllOrigins();
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser(),
+ GURL("about:blank"),
+ NEW_BACKGROUND_TAB,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_TAB);
+ chrome::ActivateTabAt(browser(), 0, true);
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+ CreateSimpleNotification(browser(), true);
+ ASSERT_EQ(1, GetNotificationCount());
+ CrashTab(browser(), 0);
+ ASSERT_EQ(1, GetNotificationCount());
+}
+
+IN_PROC_BROWSER_TEST_F(NotificationsTest, TestNotificationReplacement) {
+ // Test that we can replace a notification using the replaceId.
+ AllowAllOrigins();
+
+ ui_test_utils::NavigateToURL(browser(), test_page_url_);
+
+ std::string result = CreateNotification(
+ browser(),
+ true,
+ "abc.png",
+ "Title1",
+ "Body1",
+ "chat");
stevenjb 2012/11/29 03:32:16 nit: one or two lines for args, here and below
chrisgao (Use stgao instead) 2012/11/29 22:49:31 Done.
+ EXPECT_NE("-1", result);
+
+ ASSERT_EQ(1, GetNotificationCount());
+
+ result = CreateNotification(
+ browser(),
+ false,
+ "no_such_file.png",
+ "Title2",
+ "Body2",
+ "chat");
+ EXPECT_NE("-1", result);
+
+ const std::deque<Balloon*>& balloons = GetActiveBalloons();
+ EXPECT_EQ(1U, balloons.size());
+ const Notification& notification = balloons[0]->notification();
+ GURL EXPECTED_ICON_URL = test_server()->GetURL(kExpectedIconUrl);
+ EXPECT_EQ(EXPECTED_ICON_URL, notification.icon_url());
+ EXPECT_EQ(ASCIIToUTF16("Title2"), notification.title());
+ EXPECT_EQ(ASCIIToUTF16("Body2"), notification.body());
+}
+
+#endif // !defined(OS_CHROMEOS)
« no previous file with comments | « no previous file | chrome/test/data/notifications/notification_tester.html » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698