Chromium Code Reviews| 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()); |
| +} |