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

Unified Diff: chrome/browser/ui/webui/settings_browsertest.cc

Issue 7237030: Added options browser_tests using the generator and js handler framework. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Windows doesn't allow OVERRIDE on destructors. Created 9 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/ui/webui/settings_browsertest.cc
diff --git a/chrome/browser/ui/webui/settings_browsertest.cc b/chrome/browser/ui/webui/settings_browsertest.cc
index 6bd57664786f4dc88e6169720383052562b3c041..c4a750aa62877e233cb07f61f3535317078f554f 100644
--- a/chrome/browser/ui/webui/settings_browsertest.cc
+++ b/chrome/browser/ui/webui/settings_browsertest.cc
@@ -2,125 +2,15 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#include "chrome/browser/ui/webui/options/core_options_handler.h"
#include "chrome/browser/ui/webui/web_ui_browsertest.h"
-#include "chrome/common/url_constants.h"
-#include "chrome/test/ui_test_utils.h"
#include "googleurl/src/gurl.h"
-#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
-using ::testing::StrictMock;
-using ::testing::_;
+// crbug.com/88104 - v8_shell#host doesn't build when host=="arm".
+#if !defined(ARCH_CPU_ARM_FAMILY)
-MATCHER_P(Eq_ListValue, inList, "") {
- return arg->Equals(inList);
-}
+typedef WebUIBrowserTest SettingsWebUITest;
-class MockCoreOptionsHandler : public CoreOptionsHandler {
David Tseng 2011/07/07 19:26:28 Not sure why you're removing this? You can't mock
Sheridan Rawlins 2011/07/07 23:39:23 As we discussed at your cube, we shouldn't be test
- public:
- MOCK_METHOD1(HandleInitialize,
- void(const ListValue* args));
- MOCK_METHOD1(HandleFetchPrefs,
- void(const ListValue* args));
- MOCK_METHOD1(HandleObservePrefs,
- void(const ListValue* args));
- MOCK_METHOD1(HandleSetBooleanPref,
- void(const ListValue* args));
- MOCK_METHOD1(HandleSetIntegerPref,
- void(const ListValue* args));
- MOCK_METHOD1(HandleSetDoublePref,
- void(const ListValue* args));
- MOCK_METHOD1(HandleSetStringPref,
- void(const ListValue* args));
- MOCK_METHOD1(HandleSetObjectPref,
- void(const ListValue* args));
- MOCK_METHOD1(HandleClearPref,
- void(const ListValue* args));
- MOCK_METHOD1(HandleUserMetricsAction,
- void(const ListValue* args));
+#include "chrome/test/data/webui/settings-inl.h"
- virtual void RegisterMessages() {
- web_ui_->RegisterMessageCallback("coreOptionsInitialize",
- NewCallback(this, &MockCoreOptionsHandler ::HandleInitialize));
- web_ui_->RegisterMessageCallback("fetchPrefs",
- NewCallback(this, &MockCoreOptionsHandler ::HandleFetchPrefs));
- web_ui_->RegisterMessageCallback("observePrefs",
- NewCallback(this, &MockCoreOptionsHandler ::HandleObservePrefs));
- web_ui_->RegisterMessageCallback("setBooleanPref",
- NewCallback(this, &MockCoreOptionsHandler ::HandleSetBooleanPref));
- web_ui_->RegisterMessageCallback("setIntegerPref",
- NewCallback(this, &MockCoreOptionsHandler ::HandleSetIntegerPref));
- web_ui_->RegisterMessageCallback("setDoublePref",
- NewCallback(this, &MockCoreOptionsHandler ::HandleSetDoublePref));
- web_ui_->RegisterMessageCallback("setStringPref",
- NewCallback(this, &MockCoreOptionsHandler ::HandleSetStringPref));
- web_ui_->RegisterMessageCallback("setObjectPref",
- NewCallback(this, &MockCoreOptionsHandler ::HandleSetObjectPref));
- web_ui_->RegisterMessageCallback("clearPref",
- NewCallback(this, &MockCoreOptionsHandler ::HandleClearPref));
- web_ui_->RegisterMessageCallback("coreOptionsUserMetricsAction",
- NewCallback(this, &MockCoreOptionsHandler ::HandleUserMetricsAction));
- }
-};
-
-class SettingsWebUITest : public WebUIBrowserTest {
- protected:
- virtual void SetUpInProcessBrowserTestFixture() {
- WebUIBrowserTest::SetUpInProcessBrowserTestFixture();
- AddLibrary(FilePath(FILE_PATH_LITERAL("settings.js")));
- }
-
- virtual void SetUpOnMainThread() {
- mock_core_options_handler_.reset(new StrictMock<MockCoreOptionsHandler>());
- ui_test_utils::NavigateToURL(
- browser(), GURL(chrome::kChromeUISettingsURL));
- }
-
- virtual void CleanUpOnMainThread() {
- mock_core_options_handler_.reset();
- }
-
- virtual WebUIMessageHandler* GetMockMessageHandler() {
- return mock_core_options_handler_.get();
- }
-
- scoped_ptr<StrictMock<MockCoreOptionsHandler> > mock_core_options_handler_;
-};
-
-// Test the end to end js to WebUI handler code path for
-// the message setBooleanPref.
-// TODO(dtseng): add more EXPECT_CALL's when updating js test.
-
-// Crashes on Mac only. See http://crbug.com/79181
-#if defined(OS_MACOSX)
-#define MAYBE_TestSetBooleanPrefTriggers DISABLED_TestSetBooleanPrefTriggers
-#else
-#define MAYBE_TestSetBooleanPrefTriggers TestSetBooleanPrefTriggers
-#endif
-IN_PROC_BROWSER_TEST_F(SettingsWebUITest, MAYBE_TestSetBooleanPrefTriggers) {
- // This serves as an example of a very constrained test.
- ListValue true_list_value;
- true_list_value.Append(Value::CreateStringValue("browser.show_home_button"));
- true_list_value.Append(Value::CreateBooleanValue(true));
- true_list_value.Append(
- Value::CreateStringValue("Options_Homepage_HomeButton"));
- EXPECT_CALL(*mock_core_options_handler_,
- HandleSetBooleanPref(Eq_ListValue(&true_list_value)));
- ASSERT_TRUE(RunJavascriptTest("testSetBooleanPrefTriggers"));
-}
-
-// Not meant to run on ChromeOS at this time.
-// Not finishing in windows. http://crbug.com/81723
-#if defined(OS_CHROMEOS) || defined(OS_MACOSX) || defined (OS_WIN) || defined(TOUCH_UI)
-#define MAYBE_TestRefreshStaysOnCurrentPage\
- DISABLED_TestRefreshStaysOnCurrentPage
-#else
-#define MAYBE_TestRefreshStaysOnCurrentPage TestRefreshStaysOnCurrentPage
-#endif
-IN_PROC_BROWSER_TEST_F(SettingsWebUITest,
- MAYBE_TestRefreshStaysOnCurrentPage) {
- ASSERT_TRUE(RunJavascriptFunction("openUnderTheHood"));
- ASSERT_TRUE(RunJavascriptFunction("refreshPage"));
- ASSERT_TRUE(RunJavascriptTest("testPageIsUnderTheHood"));
-}
+#endif // !defined(ARCH_CPU_ARM_FAMILY)

Powered by Google App Engine
This is Rietveld 408576698