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

Unified Diff: chrome/browser/ui/webui/settings/site_settings_handler_unittest.cc

Issue 1988463002: MD Settings: Convert C++ handlers to be JavaScript-lifecycle aware. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 7 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/ui/webui/settings/site_settings_handler_unittest.cc
diff --git a/chrome/browser/ui/webui/settings/site_settings_handler_unittest.cc b/chrome/browser/ui/webui/settings/site_settings_handler_unittest.cc
index 4640cacfa3d85e4a2a733ee5e8e14b66572860e2..9538f1e493b272e1296b811265ba2954df07b8bd 100644
--- a/chrome/browser/ui/webui/settings/site_settings_handler_unittest.cc
+++ b/chrome/browser/ui/webui/settings/site_settings_handler_unittest.cc
@@ -25,10 +25,17 @@ namespace settings {
class SiteSettingsHandlerTest : public testing::Test {
public:
- SiteSettingsHandlerTest() {}
+ SiteSettingsHandlerTest() : handler_(&profile_) {}
+
+ void SetUp() override {
+ handler()->set_web_ui(web_ui());
+ handler()->AllowJavascript();
+ web_ui()->ClearTrackedCalls();
+ }
Profile* profile() { return &profile_; }
content::TestWebUI* web_ui() { return &web_ui_; }
+ SiteSettingsHandler* handler() { return &handler_; }
void ValidateDefault(bool expected_default, size_t expected_total_calls) {
EXPECT_EQ(expected_total_calls, web_ui()->call_data().size());
@@ -126,38 +133,33 @@ class SiteSettingsHandlerTest : public testing::Test {
content::TestBrowserThreadBundle thread_bundle_;
TestingProfile profile_;
content::TestWebUI web_ui_;
+ SiteSettingsHandler handler_;
};
TEST_F(SiteSettingsHandlerTest, GetAndSetDefault) {
- SiteSettingsHandler handler(profile());
- handler.set_web_ui(web_ui());
-
ContentSettingsType type = CONTENT_SETTINGS_TYPE_NOTIFICATIONS;
// Test the JS -> C++ -> JS callback path for getting and setting defaults.
base::ListValue getArgs;
getArgs.Append(new base::StringValue(kCallbackId));
getArgs.Append(new base::FundamentalValue(type));
- handler.HandleGetDefaultValueForContentType(&getArgs);
+ handler()->HandleGetDefaultValueForContentType(&getArgs);
ValidateDefault(true, 1U);
// Set the default to 'Blocked'.
base::ListValue setArgs;
setArgs.Append(new base::FundamentalValue(type));
setArgs.Append(new base::StringValue("block"));
- handler.HandleSetDefaultValueForContentType(&setArgs);
+ handler()->HandleSetDefaultValueForContentType(&setArgs);
EXPECT_EQ(2U, web_ui()->call_data().size());
// Verify that the default has been set to 'Blocked'.
- handler.HandleGetDefaultValueForContentType(&getArgs);
+ handler()->HandleGetDefaultValueForContentType(&getArgs);
ValidateDefault(false, 3U);
}
TEST_F(SiteSettingsHandlerTest, Origins) {
- SiteSettingsHandler handler(profile());
- handler.set_web_ui(web_ui());
-
ContentSettingsType type = CONTENT_SETTINGS_TYPE_NOTIFICATIONS;
// Test the JS -> C++ -> JS callback path for configuring origins, by setting
@@ -168,14 +170,14 @@ TEST_F(SiteSettingsHandlerTest, Origins) {
setArgs.Append(new base::StringValue(google)); // Secondary pattern.
setArgs.Append(new base::FundamentalValue(type));
setArgs.Append(new base::StringValue("block"));
- handler.HandleSetCategoryPermissionForOrigin(&setArgs);
+ handler()->HandleSetCategoryPermissionForOrigin(&setArgs);
EXPECT_EQ(1U, web_ui()->call_data().size());
// Verify the change was successful.
base::ListValue listArgs;
listArgs.Append(new base::StringValue(kCallbackId));
listArgs.Append(new base::FundamentalValue(type));
- handler.HandleGetExceptionList(&listArgs);
+ handler()->HandleGetExceptionList(&listArgs);
ValidateOrigin(google, google, "block", "preference", 2U);
// Reset things back to how they were.
@@ -183,30 +185,27 @@ TEST_F(SiteSettingsHandlerTest, Origins) {
resetArgs.Append(new base::StringValue(google));
resetArgs.Append(new base::StringValue(google));
resetArgs.Append(new base::FundamentalValue(type));
- handler.HandleResetCategoryPermissionForOrigin(&resetArgs);
+ handler()->HandleResetCategoryPermissionForOrigin(&resetArgs);
EXPECT_EQ(3U, web_ui()->call_data().size());
// Verify the reset was successful.
- handler.HandleGetExceptionList(&listArgs);
+ handler()->HandleGetExceptionList(&listArgs);
ValidateNoOrigin(4U);
}
TEST_F(SiteSettingsHandlerTest, Patterns) {
- SiteSettingsHandler handler(profile());
- handler.set_web_ui(web_ui());
-
base::ListValue args;
std::string pattern("[*.]google.com");
args.Append(new base::StringValue(kCallbackId));
args.Append(new base::StringValue(pattern));
- handler.HandleIsPatternValid(&args);
+ handler()->HandleIsPatternValid(&args);
ValidatePattern(true, 1U);
base::ListValue invalid;
std::string bad_pattern(";");
invalid.Append(new base::StringValue(kCallbackId));
invalid.Append(new base::StringValue(bad_pattern));
- handler.HandleIsPatternValid(&invalid);
+ handler()->HandleIsPatternValid(&invalid);
ValidatePattern(false, 2U);
}
« no previous file with comments | « chrome/browser/ui/webui/settings/site_settings_handler.cc ('k') | chrome/browser/ui/webui/settings/system_handler.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698