Index: chrome/browser/notifications/notification_channels_provider_android_unittest.cc |
diff --git a/chrome/browser/notifications/notification_channels_provider_android_unittest.cc b/chrome/browser/notifications/notification_channels_provider_android_unittest.cc |
index 300b9646847a09985c6b2f8c83dedca50c787096..09482df54a2d0da4b78bb09e8934d3c2870c4281 100644 |
--- a/chrome/browser/notifications/notification_channels_provider_android_unittest.cc |
+++ b/chrome/browser/notifications/notification_channels_provider_android_unittest.cc |
@@ -7,6 +7,8 @@ |
#include "base/memory/ptr_util.h" |
#include "base/values.h" |
#include "components/content_settings/core/browser/content_settings_pref.h" |
+#include "components/content_settings/core/browser/content_settings_rule.h" |
+#include "components/content_settings/core/browser/content_settings_utils.h" |
#include "components/content_settings/core/common/content_settings_pattern.h" |
#include "testing/gmock/include/gmock/gmock.h" |
#include "testing/gtest/include/gtest/gtest.h" |
@@ -26,6 +28,7 @@ class MockNotificationChannelsBridge |
MOCK_METHOD2(CreateChannel, void(const std::string&, bool)); |
MOCK_METHOD1(GetChannelStatus, NotificationChannelStatus(const std::string&)); |
MOCK_METHOD1(DeleteChannel, void(const std::string&)); |
+ MOCK_METHOD0(GetChannels, std::vector<Channel>()); |
}; |
class NotificationChannelsProviderAndroidTest : public testing::Test { |
@@ -129,3 +132,93 @@ TEST_F(NotificationChannelsProviderAndroidTest, |
EXPECT_TRUE(result); |
} |
+ |
+TEST_F(NotificationChannelsProviderAndroidTest, |
+ GetRuleIteratorWhenChannelsShouldNotBeUsed_ReturnsNull) { |
+ InitChannelsProvider(false /* should_use_channels */); |
+ EXPECT_FALSE(channels_provider_->GetRuleIterator( |
+ CONTENT_SETTINGS_TYPE_NOTIFICATIONS, std::string(), |
+ false /* incognito */)); |
+} |
+ |
+TEST_F(NotificationChannelsProviderAndroidTest, |
+ GetRuleIteratorForIncognito_ReturnsNull) { |
+ InitChannelsProvider(true /* should_use_channels */); |
+ EXPECT_FALSE( |
+ channels_provider_->GetRuleIterator(CONTENT_SETTINGS_TYPE_NOTIFICATIONS, |
+ std::string(), true /* incognito */)); |
+} |
+ |
+TEST_F(NotificationChannelsProviderAndroidTest, |
+ GetRuleIteratorWhenNoChannelsExist_ReturnsNull) { |
+ InitChannelsProvider(true /* should_use_channels */); |
+ EXPECT_CALL(*mock_bridge_, GetChannels()); |
+ EXPECT_FALSE(channels_provider_->GetRuleIterator( |
+ CONTENT_SETTINGS_TYPE_NOTIFICATIONS, std::string(), |
+ false /* incognito */)); |
+} |
+ |
+TEST_F(NotificationChannelsProviderAndroidTest, |
+ GetRuleIteratorWhenOneBlockedChannelExists) { |
+ InitChannelsProvider(true /* should_use_channels */); |
+ std::vector<Channel> channels; |
+ channels.push_back( |
+ {.origin = kTestOrigin, .status = NotificationChannelStatus::BLOCKED}); |
Peter Beverloo
2017/06/02 15:14:26
style nit: this is C-ish struct syntax that we don
awdf
2017/06/02 16:59:48
Done.
|
+ EXPECT_CALL(*mock_bridge_, GetChannels()).WillOnce(Return(channels)); |
+ std::unique_ptr<content_settings::RuleIterator> result = |
+ channels_provider_->GetRuleIterator(CONTENT_SETTINGS_TYPE_NOTIFICATIONS, |
+ std::string(), false /* incognito */); |
+ EXPECT_TRUE(result->HasNext()); |
+ content_settings::Rule rule = result->Next(); |
+ EXPECT_EQ(rule.primary_pattern, |
+ ContentSettingsPattern::FromString(kTestOrigin)); |
+ EXPECT_EQ(content_settings::ValueToContentSetting(rule.value.get()), |
+ CONTENT_SETTING_BLOCK); |
+ EXPECT_FALSE(result->HasNext()); |
+} |
+ |
+TEST_F(NotificationChannelsProviderAndroidTest, |
+ GetRuleIteratorWhenOneAllowedChannelExists) { |
+ InitChannelsProvider(true /* should_use_channels */); |
+ std::vector<Channel> channels; |
+ channels.push_back( |
+ {.origin = kTestOrigin, .status = NotificationChannelStatus::ENABLED}); |
+ EXPECT_CALL(*mock_bridge_, GetChannels()).WillOnce(Return(channels)); |
+ std::unique_ptr<content_settings::RuleIterator> result = |
+ channels_provider_->GetRuleIterator(CONTENT_SETTINGS_TYPE_NOTIFICATIONS, |
+ std::string(), false /* incognito */); |
+ EXPECT_TRUE(result->HasNext()); |
+ content_settings::Rule rule = result->Next(); |
+ EXPECT_EQ(rule.primary_pattern, |
+ ContentSettingsPattern::FromString(kTestOrigin)); |
+ EXPECT_EQ(content_settings::ValueToContentSetting(rule.value.get()), |
+ CONTENT_SETTING_ALLOW); |
+ EXPECT_FALSE(result->HasNext()); |
+} |
+ |
+TEST_F(NotificationChannelsProviderAndroidTest, |
+ GetRuleIteratorWhenMultipleChannelsExist) { |
+ InitChannelsProvider(true /* should_use_channels */); |
+ std::vector<Channel> channels; |
+ channels.push_back({.origin = "https://abc.com", |
+ .status = NotificationChannelStatus::ENABLED}); |
+ channels.push_back({.origin = "https://xyz.com", |
+ .status = NotificationChannelStatus::BLOCKED}); |
+ EXPECT_CALL(*mock_bridge_, GetChannels()).WillOnce(Return(channels)); |
+ std::unique_ptr<content_settings::RuleIterator> result = |
+ channels_provider_->GetRuleIterator(CONTENT_SETTINGS_TYPE_NOTIFICATIONS, |
+ std::string(), false /* incognito */); |
+ EXPECT_TRUE(result->HasNext()); |
+ content_settings::Rule first_rule = result->Next(); |
+ EXPECT_EQ(first_rule.primary_pattern, |
+ ContentSettingsPattern::FromString("https://abc.com")); |
+ EXPECT_EQ(content_settings::ValueToContentSetting(first_rule.value.get()), |
+ CONTENT_SETTING_ALLOW); |
+ EXPECT_TRUE(result->HasNext()); |
+ content_settings::Rule second_rule = result->Next(); |
+ EXPECT_EQ(second_rule.primary_pattern, |
+ ContentSettingsPattern::FromString("https://xyz.com")); |
+ EXPECT_EQ(content_settings::ValueToContentSetting(second_rule.value.get()), |
+ CONTENT_SETTING_BLOCK); |
+ EXPECT_FALSE(result->HasNext()); |
+} |