blob: 0a3a608155ab851f4dbd3be57d90193f09be4731 [file] [log] [blame]
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/webid/federated_identity_api_permission_context.h"
#include "base/memory/raw_ptr.h"
#include "chrome/browser/content_settings/host_content_settings_map_factory.h"
#include "chrome/browser/webid/federated_identity_api_permission_context_factory.h"
#include "chrome/test/base/testing_profile.h"
#include "components/content_settings/core/browser/host_content_settings_map.h"
#include "components/content_settings/core/common/content_settings.h"
#include "components/content_settings/core/common/content_settings_types.h"
#include "content/public/test/browser_task_environment.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "url/gurl.h"
#include "url/origin.h"
class FederatedIdentityApiPermissionContextTest : public testing::Test {
public:
FederatedIdentityApiPermissionContextTest() = default;
~FederatedIdentityApiPermissionContextTest() override = default;
FederatedIdentityApiPermissionContextTest(
FederatedIdentityApiPermissionContextTest&) = delete;
FederatedIdentityApiPermissionContextTest& operator=(
FederatedIdentityApiPermissionContextTest&) = delete;
void SetUp() override {
context_ =
FederatedIdentityApiPermissionContextFactory::GetForProfile(&profile_);
host_content_settings_map_ =
HostContentSettingsMapFactory::GetForProfile(&profile_);
}
protected:
base::raw_ptr<FederatedIdentityApiPermissionContext> context_;
base::raw_ptr<HostContentSettingsMap> host_content_settings_map_;
ContentSetting GetContentSetting(const GURL& rp_url) {
return host_content_settings_map_->GetContentSetting(
rp_url, rp_url, ContentSettingsType::FEDERATED_IDENTITY_API);
}
private:
content::BrowserTaskEnvironment task_environment_;
TestingProfile profile_;
};
// Test that FederatedIdentityApiPermissionContext::RecordDismissAndEmbargo()
// clears the permission if it is enabled.
TEST_F(FederatedIdentityApiPermissionContextTest, EnabledEmbargo) {
GURL rp_url("https://rp.com");
host_content_settings_map_->SetDefaultContentSetting(
ContentSettingsType::FEDERATED_IDENTITY_API, CONTENT_SETTING_BLOCK);
host_content_settings_map_->SetContentSettingDefaultScope(
rp_url, rp_url, ContentSettingsType::FEDERATED_IDENTITY_API,
CONTENT_SETTING_ALLOW);
EXPECT_EQ(CONTENT_SETTING_ALLOW, GetContentSetting(rp_url));
// Embargoing `rp_url` should return the default content setting for `rp_url`.
context_->RecordDismissAndEmbargo(url::Origin::Create(rp_url));
EXPECT_EQ(CONTENT_SETTING_BLOCK, GetContentSetting(rp_url));
}