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

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

Issue 2729613006: When navigation focuses a web contents, also activate its window. (Closed)
Patch Set: Copyright + nits Created 3 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/notifications/notification_interactive_uitest_support.cc
diff --git a/chrome/browser/notifications/notification_interactive_uitest_support.cc b/chrome/browser/notifications/notification_interactive_uitest_support.cc
new file mode 100644
index 0000000000000000000000000000000000000000..73680f9a35c053d7182f219bc01404b4395145c4
--- /dev/null
+++ b/chrome/browser/notifications/notification_interactive_uitest_support.cc
@@ -0,0 +1,299 @@
+// Copyright 2017 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/notifications/notification_interactive_uitest_support.h"
+
+#include "base/run_loop.h"
+#include "chrome/browser/chrome_notification_types.h"
+#include "chrome/browser/content_settings/host_content_settings_map_factory.h"
+#include "chrome/browser/notifications/desktop_notification_profile_util.h"
+#include "chrome/browser/notifications/web_notification_delegate.h"
+#include "chrome/browser/permissions/permission_request_manager.h"
+#include "chrome/browser/ui/browser_window.h"
+#include "chrome/browser/ui/tabs/tab_strip_model.h"
+#include "chrome/common/chrome_features.h"
+#include "chrome/test/base/ui_test_utils.h"
+#include "components/content_settings/core/browser/host_content_settings_map.h"
+#include "content/public/test/browser_test_utils.h"
+#include "ui/message_center/message_center.h"
+#include "ui/message_center/message_center_observer.h"
+
+namespace {
+
+// Used to observe the creation of permission prompt without responding.
+class PermissionRequestObserver : public PermissionRequestManager::Observer {
+ public:
+ explicit PermissionRequestObserver(content::WebContents* web_contents)
+ : request_manager_(
+ PermissionRequestManager::FromWebContents(web_contents)),
+ request_shown_(false),
+ message_loop_runner_(new content::MessageLoopRunner) {
+ request_manager_->AddObserver(this);
+ }
+ ~PermissionRequestObserver() override {
+ // Safe to remove twice if it happens.
+ request_manager_->RemoveObserver(this);
+ }
+
+ void Wait() { message_loop_runner_->Run(); }
+
+ bool request_shown() { return request_shown_; }
+
+ private:
+ // PermissionRequestManager::Observer
+ void OnBubbleAdded() override {
+ request_shown_ = true;
+ request_manager_->RemoveObserver(this);
+ message_loop_runner_->Quit();
+ }
+
+ PermissionRequestManager* request_manager_;
+ bool request_shown_;
+ scoped_refptr<content::MessageLoopRunner> message_loop_runner_;
+
+ DISALLOW_COPY_AND_ASSIGN(PermissionRequestObserver);
+};
+
+} // namespace
+
+class MessageCenterChangeObserver::Impl
+ : public message_center::MessageCenterObserver {
+ public:
+ Impl() : notification_received_(false) {
+ message_center::MessageCenter::Get()->AddObserver(this);
+ }
+
+ ~Impl() override {
+ message_center::MessageCenter::Get()->RemoveObserver(this);
+ }
+
+ bool Wait() {
+ if (notification_received_)
+ return true;
+
+ message_loop_runner_ = new content::MessageLoopRunner;
+ message_loop_runner_->Run();
+ return notification_received_;
+ }
+
+ // message_center::MessageCenterObserver:
+ void OnNotificationAdded(const std::string& notification_id) override {
+ OnMessageCenterChanged();
+ }
+
+ void OnNotificationRemoved(const std::string& notification_id,
+ bool by_user) override {
+ OnMessageCenterChanged();
+ }
+
+ void OnNotificationUpdated(const std::string& notification_id) override {
+ OnMessageCenterChanged();
+ }
+
+ void OnNotificationClicked(const std::string& notification_id) override {
+ OnMessageCenterChanged();
+ }
+
+ void OnMessageCenterChanged() {
+ notification_received_ = true;
+ if (message_loop_runner_.get())
+ message_loop_runner_->Quit();
+ }
+
+ bool notification_received_;
+ scoped_refptr<content::MessageLoopRunner> message_loop_runner_;
+
+ DISALLOW_COPY_AND_ASSIGN(Impl);
+};
+
+MessageCenterChangeObserver::MessageCenterChangeObserver() : impl_(new Impl) {}
+MessageCenterChangeObserver::~MessageCenterChangeObserver() = default;
+
+bool MessageCenterChangeObserver::Wait() {
+ return impl_->Wait();
+}
+
+// -----------------------------------------------------------------------------
+
+int NotificationsTest::GetNotificationCount() {
+ return message_center::MessageCenter::Get()->NotificationCount();
+}
+
+int NotificationsTest::GetNotificationPopupCount() {
+ return message_center::MessageCenter::Get()->GetPopupNotifications().size();
+}
+
+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(browser->tab_strip_model()->GetWebContentsAt(index));
+}
+
+void NotificationsTest::DenyOrigin(const GURL& origin) {
+ DropOriginPreference(origin);
+ DesktopNotificationProfileUtil::DenyPermission(browser()->profile(), origin);
+}
+
+void NotificationsTest::AllowOrigin(const GURL& origin) {
+ DropOriginPreference(origin);
+ DesktopNotificationProfileUtil::GrantPermission(browser()->profile(), origin);
+}
+
+void NotificationsTest::AllowAllOrigins() {
+ // Reset all origins
+ HostContentSettingsMapFactory::GetForProfile(browser()->profile())
+ ->ClearSettingsForOneType(CONTENT_SETTINGS_TYPE_NOTIFICATIONS);
+ SetDefaultContentSetting(CONTENT_SETTING_ALLOW);
+}
+
+void NotificationsTest::SetDefaultContentSetting(ContentSetting setting) {
+ HostContentSettingsMapFactory::GetForProfile(browser()->profile())
+ ->SetDefaultContentSetting(CONTENT_SETTINGS_TYPE_NOTIFICATIONS, setting);
+}
+
+std::string NotificationsTest::CreateNotification(Browser* browser,
+ bool wait_for_new_balloon,
+ const char* icon,
+ const char* title,
+ const char* body,
+ const char* replace_id,
+ const char* onclick) {
+ std::string script = base::StringPrintf(
+ "createNotification('%s', '%s', '%s', '%s', (e) => { %s });", icon, title,
+ body, replace_id, onclick);
+
+ MessageCenterChangeObserver observer;
+ std::string result;
+ bool success = content::ExecuteScriptAndExtractString(
+ GetActiveWebContents(browser), 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", "");
+}
+
+std::string NotificationsTest::RequestAndRespondToPermission(
+ Browser* browser,
+ PermissionRequestManager::AutoResponseType bubble_response) {
+ std::string result;
+ content::WebContents* web_contents = GetActiveWebContents(browser);
+ PermissionRequestManager::FromWebContents(web_contents)
+ ->set_auto_response_for_test(bubble_response);
+ EXPECT_TRUE(content::ExecuteScriptAndExtractString(
+ web_contents, "requestPermission();", &result));
+ return result;
+}
+
+bool NotificationsTest::RequestAndAcceptPermission(Browser* browser) {
+ std::string result = RequestAndRespondToPermission(
+ browser, PermissionRequestManager::ACCEPT_ALL);
+ return "request-callback-granted" == result;
+}
+
+bool NotificationsTest::RequestAndDenyPermission(Browser* browser) {
+ std::string result = RequestAndRespondToPermission(
+ browser, PermissionRequestManager::DENY_ALL);
+ return "request-callback-denied" == result;
+}
+
+bool NotificationsTest::RequestAndDismissPermission(Browser* browser) {
+ std::string result =
+ RequestAndRespondToPermission(browser, PermissionRequestManager::DISMISS);
+ return "request-callback-default" == result;
+}
+
+bool NotificationsTest::RequestPermissionAndWait(Browser* browser) {
+ content::WebContents* web_contents = GetActiveWebContents(browser);
+ ui_test_utils::NavigateToURL(browser, GetTestPageURL());
+ PermissionRequestObserver observer(web_contents);
+ std::string result;
+ EXPECT_TRUE(content::ExecuteScriptAndExtractString(
+ web_contents, "requestPermissionAndRespond();", &result));
+ EXPECT_EQ("requested", result);
+ observer.Wait();
+ return observer.request_shown();
+}
+
+bool NotificationsTest::CancelNotification(const char* notification_id,
+ Browser* browser) {
+ std::string script =
+ base::StringPrintf("cancelNotification('%s');", notification_id);
+
+ MessageCenterChangeObserver observer;
+ std::string result;
+ bool success = content::ExecuteScriptAndExtractString(
+ GetActiveWebContents(browser), script, &result);
+ if (!success || result != "1")
+ return false;
+ return observer.Wait();
+}
+
+void NotificationsTest::GetPrefsByContentSetting(
+ ContentSetting setting,
+ ContentSettingsForOneType* settings) {
+ DesktopNotificationProfileUtil::GetNotificationsSettings(browser()->profile(),
+ settings);
+ for (ContentSettingsForOneType::iterator it = settings->begin();
+ it != settings->end();) {
+ if (it->setting != setting || it->source.compare("preference") != 0)
+ it = settings->erase(it);
+ else
+ ++it;
+ }
+}
+
+bool NotificationsTest::CheckOriginInSetting(
+ const ContentSettingsForOneType& settings,
+ const GURL& origin) {
+ ContentSettingsPattern pattern =
+ ContentSettingsPattern::FromURLNoWildcard(origin);
+ for (const auto& setting : settings) {
+ if (setting.primary_pattern == pattern)
+ return true;
+ }
+ return false;
+}
+
+GURL NotificationsTest::GetTestPageURLForFile(const std::string& file) const {
+ return embedded_test_server()->GetURL(std::string("/notifications/") + file);
+}
+
+GURL NotificationsTest::GetTestPageURL() const {
+ return GetTestPageURLForFile("notification_tester.html");
+}
+
+content::WebContents* NotificationsTest::GetActiveWebContents(
+ Browser* browser) {
+ return browser->tab_strip_model()->GetActiveWebContents();
+}
+
+void NotificationsTest::EnableFullscreenNotifications() {
+ feature_list_.InitWithFeatures(
+ {features::kPreferHtmlOverPlugins,
+ features::kAllowFullscreenWebNotificationsFeature},
+ {});
+}
+
+void NotificationsTest::DisableFullscreenNotifications() {
+ feature_list_.InitWithFeatures(
+ {features::kPreferHtmlOverPlugins},
+ {features::kAllowFullscreenWebNotificationsFeature});
+}
+
+void NotificationsTest::DropOriginPreference(const GURL& origin) {
+ DesktopNotificationProfileUtil::ClearSetting(browser()->profile(), origin);
+}
« no previous file with comments | « chrome/browser/notifications/notification_interactive_uitest_support.h ('k') | chrome/browser/ui/browser_navigator.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698