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

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

Issue 2868042: Backend changes for notifications content settings. (Closed)
Patch Set: '' Created 10 years, 5 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/desktop_notification_service_unittest.cc
diff --git a/chrome/browser/notifications/desktop_notification_service_unittest.cc b/chrome/browser/notifications/desktop_notification_service_unittest.cc
index 4e0a705e2a8df7c761cec19474e8095311325efe..3af8b0f4c6164d0c3534fd2371ec219ebd980f69 100644
--- a/chrome/browser/notifications/desktop_notification_service_unittest.cc
+++ b/chrome/browser/notifications/desktop_notification_service_unittest.cc
@@ -4,70 +4,243 @@
#include "chrome/browser/notifications/desktop_notification_service.h"
-#include "base/task.h"
+#include "base/ref_counted.h"
#include "base/waitable_event.h"
#include "chrome/browser/notifications/notifications_prefs_cache.h"
+#include "chrome/browser/pref_service.h"
#include "chrome/browser/renderer_host/test/test_render_view_host.h"
+#include "chrome/browser/scoped_pref_update.h"
+#include "chrome/common/pref_names.h"
#include "chrome/test/testing_profile.h"
#include "grit/generated_resources.h"
#include "testing/gtest/include/gtest/gtest.h"
+#include "third_party/WebKit/WebKit/chromium/public/WebNotificationPresenter.h"
namespace {
-class WaitTask : public Task {
+// NotificationsPrefsCache wants to be called on the IO thread. This class
+// routes calls to the cache on the IO thread.
+class ThreadProxy : public base::RefCountedThreadSafe<ThreadProxy> {
public:
- WaitTask(base::WaitableEvent* event)
- : event_(event) {
+ ThreadProxy()
+ : io_event_(false, false),
+ ui_event_(false, false) {
+ // The current message loop was already initalized by the test superclass.
+ ui_thread_.reset(
+ new ChromeThread(ChromeThread::UI, MessageLoop::current()));
+
+ // Create IO thread, start its message loop.
+ io_thread_.reset(new ChromeThread(ChromeThread::IO));
+ io_thread_->Start();
+
+ // Calling PauseIOThread() here isn't safe, because the runnable method
+ // could complete before the constructor is done, deleting |this|.
}
- virtual void Run() {
- event_->Wait();
+
+ int CacheHasPermission(NotificationsPrefsCache* cache, const GURL& url) {
+ DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI));
+ ChromeThread::PostTask(ChromeThread::IO, FROM_HERE,
+ NewRunnableMethod(this, &ThreadProxy::CacheHasPermissionIO,
+ cache, url));
+ io_event_.Signal();
+ ui_event_.Wait(); // Wait for IO thread to be done.
+ ChromeThread::PostTask(ChromeThread::IO, FROM_HERE,
+ NewRunnableMethod(this, &ThreadProxy::PauseIOThreadIO));
+
+ return permission_;
+ }
+
+ void PauseIOThread() {
+ ChromeThread::PostTask(ChromeThread::IO, FROM_HERE,
+ NewRunnableMethod(this, &ThreadProxy::PauseIOThreadIO));
+ }
+
+ void DrainIOThread() {
+ DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI));
+ io_event_.Signal();
+ io_thread_->Stop();
}
private:
- base::WaitableEvent* event_;
+ friend class base::RefCountedThreadSafe<ThreadProxy>;
+ ~ThreadProxy() {
+ DrainIOThread();
+ }
+
+ void PauseIOThreadIO() {
+ DCHECK(ChromeThread::CurrentlyOn(ChromeThread::IO));
+ io_event_.Wait();
+ }
+
+ void CacheHasPermissionIO(NotificationsPrefsCache* cache, const GURL& url) {
+ DCHECK(ChromeThread::CurrentlyOn(ChromeThread::IO));
+ permission_ = cache->HasPermission(url);
+ ui_event_.Signal();
+ }
+
+ base::WaitableEvent io_event_;
+ base::WaitableEvent ui_event_;
+ scoped_ptr<ChromeThread> ui_thread_;
+ scoped_ptr<ChromeThread> io_thread_;
+
+ int permission_;
};
class DesktopNotificationServiceTest : public RenderViewHostTestHarness {
public:
- DesktopNotificationServiceTest()
- : event_(false, false) {
+ DesktopNotificationServiceTest() {
}
- base::WaitableEvent event_;
-};
-TEST_F(DesktopNotificationServiceTest, DefaultContentSettingSentToCache) {
- // The current message loop was already initalized by the superclass.
- ChromeThread ui_thread(ChromeThread::UI, MessageLoop::current());
+ virtual void SetUp() {
+ RenderViewHostTestHarness::SetUp();
+ proxy_ = new ThreadProxy;
+ proxy_->PauseIOThread();
+
+ // Creates the service, calls InitPrefs() on it which loads data from the
+ // profile into the cache and then puts the cache in io thread mode.
+ service_ = profile()->GetDesktopNotificationService();
+ cache_ = service_->prefs_cache();
+ }
- // Create IO thread, start its message loop.
- ChromeThread io_thread(ChromeThread::IO);
- io_thread.Start();
- ChromeThread::PostTask(ChromeThread::IO, FROM_HERE, new WaitTask(&event_));
+ virtual void TearDown() {
+ // The io thread's waiting on the io_event_ might hold a ref to |proxy_|,
+ // preventing its destruction. Clear that ref.
+ proxy_->DrainIOThread();
+ RenderViewHostTestHarness::TearDown();
+ }
- // Creates the service, calls InitPrefs() on it which loads data from the
- // profile into the cache and then puts the cache in io thread mode.
- DesktopNotificationService* service =
- profile()->GetDesktopNotificationService();
- NotificationsPrefsCache* cache = service->prefs_cache();
+ DesktopNotificationService* service_;
+ NotificationsPrefsCache* cache_;
+ scoped_refptr<ThreadProxy> proxy_;
+};
+TEST_F(DesktopNotificationServiceTest, DefaultContentSettingSentToCache) {
// The default pref registered in DesktopNotificationService is "ask",
// and that's what sent to the cache.
- EXPECT_EQ(CONTENT_SETTING_ASK, cache->CachedDefaultContentSetting());
+ EXPECT_EQ(CONTENT_SETTING_ASK, cache_->CachedDefaultContentSetting());
// Change the default content setting. This will post a task on the IO thread
// to update the cache.
- service->SetDefaultContentSetting(CONTENT_SETTING_BLOCK);
+ service_->SetDefaultContentSetting(CONTENT_SETTING_BLOCK);
// The updated pref shouldn't be sent to the cache immediately.
- EXPECT_EQ(CONTENT_SETTING_ASK, cache->CachedDefaultContentSetting());
+ EXPECT_EQ(CONTENT_SETTING_ASK, cache_->CachedDefaultContentSetting());
// Run IO thread tasks.
- event_.Signal();
- io_thread.Stop();
+ proxy_->DrainIOThread();
// Now that IO thread events have been processed, it should be there.
- EXPECT_EQ(CONTENT_SETTING_BLOCK, cache->CachedDefaultContentSetting());
+ EXPECT_EQ(CONTENT_SETTING_BLOCK, cache_->CachedDefaultContentSetting());
+}
+
+TEST_F(DesktopNotificationServiceTest, GrantPermissionSentToCache) {
+ GURL url("http://allowed.com");
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionNotAllowed,
+ proxy_->CacheHasPermission(cache_, url));
+
+ service_->GrantPermission(url);
+
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionAllowed,
+ proxy_->CacheHasPermission(cache_, url));
+}
+
+TEST_F(DesktopNotificationServiceTest, DenyPermissionSentToCache) {
+ GURL url("http://denied.com");
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionNotAllowed,
+ proxy_->CacheHasPermission(cache_, url));
+
+ service_->DenyPermission(url);
+
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionDenied,
+ proxy_->CacheHasPermission(cache_, url));
+}
+
+TEST_F(DesktopNotificationServiceTest, PrefChangesSentToCache) {
+ PrefService* prefs = profile()->GetPrefs();
+
+ ListValue* allowed_sites =
+ prefs->GetMutableList(prefs::kDesktopNotificationAllowedOrigins);
+ {
+ allowed_sites->Append(new StringValue(GURL("http://allowed.com").spec()));
+ ScopedPrefUpdate updateAllowed(
+ prefs, prefs::kDesktopNotificationAllowedOrigins);
+ }
+
+ ListValue* denied_sites =
+ prefs->GetMutableList(prefs::kDesktopNotificationDeniedOrigins);
+ {
+ denied_sites->Append(new StringValue(GURL("http://denied.com").spec()));
+ ScopedPrefUpdate updateDenied(
+ prefs, prefs::kDesktopNotificationDeniedOrigins);
+ }
+
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionAllowed,
+ proxy_->CacheHasPermission(cache_, GURL("http://allowed.com")));
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionDenied,
+ proxy_->CacheHasPermission(cache_, GURL("http://denied.com")));
+}
+
+TEST_F(DesktopNotificationServiceTest, GetAllowedOrigins) {
+ service_->GrantPermission(GURL("http://allowed2.com"));
+ service_->GrantPermission(GURL("http://allowed.com"));
+
+ std::vector<GURL> allowed_origins(service_->GetAllowedOrigins());
+ ASSERT_EQ(2u, allowed_origins.size());
+ EXPECT_EQ(GURL("http://allowed2.com"), allowed_origins[0]);
+ EXPECT_EQ(GURL("http://allowed.com"), allowed_origins[1]);
+}
+
+TEST_F(DesktopNotificationServiceTest, GetBlockedOrigins) {
+ service_->DenyPermission(GURL("http://denied2.com"));
+ service_->DenyPermission(GURL("http://denied.com"));
+
+ std::vector<GURL> denied_origins(service_->GetBlockedOrigins());
+ ASSERT_EQ(2u, denied_origins.size());
+ EXPECT_EQ(GURL("http://denied2.com"), denied_origins[0]);
+ EXPECT_EQ(GURL("http://denied.com"), denied_origins[1]);
+}
+
+TEST_F(DesktopNotificationServiceTest, ResetAllSentToCache) {
+ GURL allowed_url("http://allowed.com");
+ service_->GrantPermission(allowed_url);
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionAllowed,
+ proxy_->CacheHasPermission(cache_, allowed_url));
+ GURL denied_url("http://denied.com");
+ service_->DenyPermission(denied_url);
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionDenied,
+ proxy_->CacheHasPermission(cache_, denied_url));
+
+ service_->ResetAllOrigins();
+
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionNotAllowed,
+ proxy_->CacheHasPermission(cache_, allowed_url));
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionNotAllowed,
+ proxy_->CacheHasPermission(cache_, denied_url));
+}
+
+TEST_F(DesktopNotificationServiceTest, ResetAllowedSentToCache) {
+ GURL allowed_url("http://allowed.com");
+ service_->GrantPermission(allowed_url);
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionAllowed,
+ proxy_->CacheHasPermission(cache_, allowed_url));
+
+ service_->ResetAllowedOrigin(allowed_url);
+
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionNotAllowed,
+ proxy_->CacheHasPermission(cache_, allowed_url));
+}
+
+TEST_F(DesktopNotificationServiceTest, ResetBlockedSentToCache) {
+ GURL denied_url("http://denied.com");
+ service_->DenyPermission(denied_url);
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionDenied,
+ proxy_->CacheHasPermission(cache_, denied_url));
+
+ service_->ResetBlockedOrigin(denied_url);
+
+ EXPECT_EQ(WebKit::WebNotificationPresenter::PermissionNotAllowed,
+ proxy_->CacheHasPermission(cache_, denied_url));
}
} // namespace

Powered by Google App Engine
This is Rietveld 408576698