summaryrefslogtreecommitdiffstats
path: root/webkit/tools
diff options
context:
space:
mode:
Diffstat (limited to 'webkit/tools')
-rw-r--r--webkit/tools/test_shell/layout_test_controller.cc13
-rw-r--r--webkit/tools/test_shell/layout_test_controller.h1
-rw-r--r--webkit/tools/test_shell/test_shell.cc1
3 files changed, 15 insertions, 0 deletions
diff --git a/webkit/tools/test_shell/layout_test_controller.cc b/webkit/tools/test_shell/layout_test_controller.cc
index 7643217..bcc70fb 100644
--- a/webkit/tools/test_shell/layout_test_controller.cc
+++ b/webkit/tools/test_shell/layout_test_controller.cc
@@ -157,6 +157,7 @@ LayoutTestController::LayoutTestController(TestShell* shell) :
BindMethod("setPrivateBrowsingEnabled", &LayoutTestController::setPrivateBrowsingEnabled);
BindMethod("setUseDashboardCompatibilityMode", &LayoutTestController::setUseDashboardCompatibilityMode);
+ BindMethod("setJavaScriptCanAccessClipboard", &LayoutTestController::setJavaScriptCanAccessClipboard);
BindMethod("setXSSAuditorEnabled", &LayoutTestController::setXSSAuditorEnabled);
BindMethod("evaluateScriptInIsolatedWorld", &LayoutTestController::evaluateScriptInIsolatedWorld);
BindMethod("overridePreference", &LayoutTestController::overridePreference);
@@ -929,6 +930,16 @@ void LayoutTestController::setPrivateBrowsingEnabled(
result->SetNull();
}
+void LayoutTestController::setJavaScriptCanAccessClipboard(
+ const CppArgumentList& args, CppVariant* result) {
+ if (args.size() > 0 && args[0].isBool()) {
+ WebPreferences* prefs = shell_->GetWebPreferences();
+ prefs->javascript_can_access_clipboard = args[0].value.boolValue;
+ prefs->Apply(shell_->webView());
+ }
+ result->SetNull();
+}
+
void LayoutTestController::setXSSAuditorEnabled(
const CppArgumentList& args, CppVariant* result) {
if (args.size() > 0 && args[0].isBool()) {
@@ -1060,6 +1071,8 @@ void LayoutTestController::overridePreference(
preferences->java_enabled = CppVariantToBool(value);
else if (key == "WebKitUsesPageCachePreferenceKey")
preferences->uses_page_cache = CppVariantToBool(value);
+ else if (key == "WebKitJavaScriptCanAccessClipboard")
+ preferences->javascript_can_access_clipboard = CppVariantToBool(value);
else if (key == "WebKitXSSAuditorEnabled")
preferences->xss_auditor_enabled = CppVariantToBool(value);
else if (key == "WebKitLocalStorageEnabledPreferenceKey")
diff --git a/webkit/tools/test_shell/layout_test_controller.h b/webkit/tools/test_shell/layout_test_controller.h
index 3a29544..0dc04df 100644
--- a/webkit/tools/test_shell/layout_test_controller.h
+++ b/webkit/tools/test_shell/layout_test_controller.h
@@ -213,6 +213,7 @@ class LayoutTestController : public CppBoundClass {
void setCallCloseOnWebViews(const CppArgumentList& args, CppVariant* result);
void setPrivateBrowsingEnabled(const CppArgumentList& args, CppVariant* result);
+ void setJavaScriptCanAccessClipboard(const CppArgumentList& args, CppVariant* result);
void setXSSAuditorEnabled(const CppArgumentList& args, CppVariant* result);
void evaluateScriptInIsolatedWorld(const CppArgumentList& args, CppVariant* result);
void overridePreference(const CppArgumentList& args, CppVariant* result);
diff --git a/webkit/tools/test_shell/test_shell.cc b/webkit/tools/test_shell/test_shell.cc
index b67f5b5..564979c 100644
--- a/webkit/tools/test_shell/test_shell.cc
+++ b/webkit/tools/test_shell/test_shell.cc
@@ -485,6 +485,7 @@ void TestShell::ResetWebPreferences() {
web_prefs_->text_areas_are_resizable = false;
web_prefs_->java_enabled = false;
web_prefs_->allow_scripts_to_close_windows = false;
+ web_prefs_->javascript_can_access_clipboard = true;
web_prefs_->xss_auditor_enabled = false;
// It's off by default for Chrome, but we don't want to
// lose the coverage of dynamic font tests in webkit test.