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

Unified Diff: chrome/browser/push_messaging/push_messaging_browsertest.cc

Issue 1062913005: Push API: Deflake PushEventEnforcesUserVisibleNotification (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@bindcurrent
Patch Set: Created 5 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | chrome/browser/push_messaging/push_messaging_service_impl.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/push_messaging/push_messaging_browsertest.cc
diff --git a/chrome/browser/push_messaging/push_messaging_browsertest.cc b/chrome/browser/push_messaging/push_messaging_browsertest.cc
index 9a1b15ca32183cf9bccc043ec1e54a8ffa4c3292..b8f7ba81fb1de6f849b10e6696b5cde85ad69201 100644
--- a/chrome/browser/push_messaging/push_messaging_browsertest.cc
+++ b/chrome/browser/push_messaging/push_messaging_browsertest.cc
@@ -199,6 +199,10 @@ class PushMessagingBrowserTest : public InProcessBrowserTest {
PushMessagingApplicationId GetServiceWorkerAppId(
int64 service_worker_registration_id);
+ void SendMessageAndWaitUntilHandled(
+ const PushMessagingApplicationId& app_id,
+ const gcm::GCMClient::IncomingMessage& message);
+
net::SpawnedTestServer* https_server() const { return https_server_.get(); }
gcm::FakeGCMProfileService* gcm_service() const { return gcm_service_; }
@@ -271,6 +275,15 @@ PushMessagingApplicationId PushMessagingBrowserTest::GetServiceWorkerAppId(
return application_id;
}
+void PushMessagingBrowserTest::SendMessageAndWaitUntilHandled(
+ const PushMessagingApplicationId& app_id,
+ const gcm::GCMClient::IncomingMessage& message) {
+ base::RunLoop run_loop;
+ push_service()->SetMessageCallbackForTesting(run_loop.QuitClosure());
+ push_service()->OnMessage(app_id.app_id_guid(), message);
+ run_loop.Run();
+}
+
IN_PROC_BROWSER_TEST_F(PushMessagingBrowserTest,
RegisterSuccessNotificationsGranted) {
TryToRegisterSuccessfully("1-0" /* expected_push_registration_id */);
@@ -484,7 +497,7 @@ IN_PROC_BROWSER_TEST_F(PushMessagingBrowserTest,
message.sender_id = "1234567890";
for (int n = 0; n < 2; n++) {
message.data["data"] = "testdata";
- push_service()->OnMessage(app_id.app_id_guid(), message);
+ SendMessageAndWaitUntilHandled(app_id, message);
ASSERT_TRUE(RunScript("resultQueue.pop()", &script_result));
EXPECT_EQ("testdata", script_result);
EXPECT_EQ(0u, notification_manager()->GetNotificationCount());
@@ -499,12 +512,12 @@ IN_PROC_BROWSER_TEST_F(PushMessagingBrowserTest,
// should show a forced one, but only on the 2nd occurrence since we allow one
// mistake per 10 push events.
message.data["data"] = "testdata";
- push_service()->OnMessage(app_id.app_id_guid(), message);
+ SendMessageAndWaitUntilHandled(app_id, message);
ASSERT_TRUE(RunScript("resultQueue.pop()", &script_result, web_contents));
EXPECT_EQ("testdata", script_result);
EXPECT_EQ(0u, notification_manager()->GetNotificationCount());
message.data["data"] = "testdata";
- push_service()->OnMessage(app_id.app_id_guid(), message);
+ SendMessageAndWaitUntilHandled(app_id, message);
ASSERT_TRUE(RunScript("resultQueue.pop()", &script_result, web_contents));
EXPECT_EQ("testdata", script_result);
@@ -518,7 +531,7 @@ IN_PROC_BROWSER_TEST_F(PushMessagingBrowserTest,
// Currently, this notification will stick around until the user or webapp
// explicitly dismisses it (though we may change this later).
message.data["data"] = "shownotification";
- push_service()->OnMessage(app_id.app_id_guid(), message);
+ SendMessageAndWaitUntilHandled(app_id, message);
ASSERT_TRUE(RunScript("resultQueue.pop()", &script_result, web_contents));
EXPECT_EQ("shownotification", script_result);
EXPECT_EQ(2u, notification_manager()->GetNotificationCount());
@@ -530,7 +543,7 @@ IN_PROC_BROWSER_TEST_F(PushMessagingBrowserTest,
// should not show a forced one.
message.data["data"] = "shownotification";
for (int n = 0; n < 9; n++) {
- push_service()->OnMessage(app_id.app_id_guid(), message);
+ SendMessageAndWaitUntilHandled(app_id, message);
ASSERT_TRUE(RunScript("resultQueue.pop()", &script_result, web_contents));
EXPECT_EQ("shownotification", script_result);
EXPECT_EQ(1u, notification_manager()->GetNotificationCount());
@@ -542,7 +555,7 @@ IN_PROC_BROWSER_TEST_F(PushMessagingBrowserTest,
// Now that 10 push messages in a row have shown notifications, we should
// allow the next one to mistakenly not show a notification.
message.data["data"] = "testdata";
- push_service()->OnMessage(app_id.app_id_guid(), message);
+ SendMessageAndWaitUntilHandled(app_id, message);
ASSERT_TRUE(RunScript("resultQueue.pop()", &script_result, web_contents));
EXPECT_EQ("testdata", script_result);
EXPECT_EQ(0u, notification_manager()->GetNotificationCount());
« no previous file with comments | « no previous file | chrome/browser/push_messaging/push_messaging_service_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698