blob: f634680d12af76f21d85ab080dd3d59626205a2a [file] [log] [blame]
/*
* Copyright (C) 2010 Google Inc. All rights reserved.
* Copyright (C) 2010 Pawel Hajdan (phajdan.jr@chromium.org)
* Copyright (C) 2012 Apple Inc. All Rights Reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following disclaimer
* in the documentation and/or other materials provided with the
* distribution.
* * Neither the name of Google Inc. nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "TestRunner.h"
#include "MockWebSpeechInputController.h"
#include "MockWebSpeechRecognizer.h"
#include "NotificationPresenter.h"
#include "TestInterfaces.h"
#include "WebPermissions.h"
#include "public/platform/WebData.h"
#include "public/platform/WebDeviceMotionData.h"
#include "public/platform/WebDeviceOrientationData.h"
#include "public/platform/WebPoint.h"
#include "public/platform/WebURLResponse.h"
#include "public/testing/WebPreferences.h"
#include "public/testing/WebTestDelegate.h"
#include "public/testing/WebTestProxy.h"
#include "public/web/WebBindings.h"
#include "public/web/WebDataSource.h"
#include "public/web/WebDocument.h"
#include "public/web/WebElement.h"
#include "public/web/WebFindOptions.h"
#include "public/web/WebFrame.h"
#include "public/web/WebGeolocationClientMock.h"
#include "public/web/WebInputElement.h"
#include "public/web/WebMIDIClientMock.h"
#include "public/web/WebScriptSource.h"
#include "public/web/WebSecurityPolicy.h"
#include "public/web/WebSerializedScriptValue.h"
#include "public/web/WebSettings.h"
#include "public/web/WebSurroundingText.h"
#include "public/web/WebView.h"
#include "v8/include/v8.h"
#include <limits>
#if defined(__linux__) || defined(ANDROID)
#include "public/web/linux/WebFontRendering.h"
#endif
using namespace blink;
using namespace std;
namespace WebTestRunner {
namespace {
class InvokeCallbackTask : public WebMethodTask<TestRunner> {
public:
InvokeCallbackTask(TestRunner* object, WebScopedPtr<CppVariant> callbackArguments)
: WebMethodTask<TestRunner>(object)
, m_callbackArguments(callbackArguments)
{
}
virtual void runIfValid()
{
CppVariant invokeResult;
m_callbackArguments->invokeDefault(m_callbackArguments.get(), 1, invokeResult);
}
private:
WebScopedPtr<CppVariant> m_callbackArguments;
};
}
TestRunner::WorkQueue::~WorkQueue()
{
reset();
}
void TestRunner::WorkQueue::processWorkSoon()
{
if (m_controller->topLoadingFrame())
return;
if (!m_queue.empty()) {
// We delay processing queued work to avoid recursion problems.
m_controller->m_delegate->postTask(new WorkQueueTask(this));
} else if (!m_controller->m_waitUntilDone)
m_controller->m_delegate->testFinished();
}
void TestRunner::WorkQueue::processWork()
{
// Quit doing work once a load is in progress.
while (!m_queue.empty()) {
bool startedLoad = m_queue.front()->run(m_controller->m_delegate, m_controller->m_webView);
delete m_queue.front();
m_queue.pop_front();
if (startedLoad)
return;
}
if (!m_controller->m_waitUntilDone && !m_controller->topLoadingFrame())
m_controller->m_delegate->testFinished();
}
void TestRunner::WorkQueue::reset()
{
m_frozen = false;
while (!m_queue.empty()) {
delete m_queue.front();
m_queue.pop_front();
}
}
void TestRunner::WorkQueue::addWork(WorkItem* work)
{
if (m_frozen) {
delete work;
return;
}
m_queue.push_back(work);
}
TestRunner::TestRunner(TestInterfaces* interfaces)
: m_testIsRunning(false)
, m_closeRemainingWindows(false)
, m_workQueue(this)
, m_testInterfaces(interfaces)
, m_delegate(0)
, m_webView(0)
, m_pageOverlay(0)
, m_webPermissions(new WebPermissions)
, m_notificationPresenter(new NotificationPresenter)
{
// Initialize the map that associates methods of this class with the names
// they will use when called by JavaScript. The actual binding of those
// names to their methods will be done by calling bindToJavaScript() (defined
// by CppBoundClass, the parent to TestRunner).
// Methods controlling test execution.
bindMethod("notifyDone", &TestRunner::notifyDone);
bindMethod("queueBackNavigation", &TestRunner::queueBackNavigation);
bindMethod("queueForwardNavigation", &TestRunner::queueForwardNavigation);
bindMethod("queueLoadingScript", &TestRunner::queueLoadingScript);
bindMethod("queueLoad", &TestRunner::queueLoad);
bindMethod("queueLoadHTMLString", &TestRunner::queueLoadHTMLString);
bindMethod("queueNonLoadingScript", &TestRunner::queueNonLoadingScript);
bindMethod("queueReload", &TestRunner::queueReload);
bindMethod("setCloseRemainingWindowsWhenComplete", &TestRunner::setCloseRemainingWindowsWhenComplete);
bindMethod("resetTestHelperControllers", &TestRunner::resetTestHelperControllers);
bindMethod("setCustomPolicyDelegate", &TestRunner::setCustomPolicyDelegate);
bindMethod("waitForPolicyDelegate", &TestRunner::waitForPolicyDelegate);
bindMethod("waitUntilDone", &TestRunner::waitUntilDone);
bindMethod("windowCount", &TestRunner::windowCount);
// Methods implemented in terms of chromium's public WebKit API.
bindMethod("setTabKeyCyclesThroughElements", &TestRunner::setTabKeyCyclesThroughElements);
bindMethod("execCommand", &TestRunner::execCommand);
bindMethod("isCommandEnabled", &TestRunner::isCommandEnabled);
bindMethod("callShouldCloseOnWebView", &TestRunner::callShouldCloseOnWebView);
bindMethod("setDomainRelaxationForbiddenForURLScheme", &TestRunner::setDomainRelaxationForbiddenForURLScheme);
bindMethod("evaluateScriptInIsolatedWorldAndReturnValue", &TestRunner::evaluateScriptInIsolatedWorldAndReturnValue);
bindMethod("evaluateScriptInIsolatedWorld", &TestRunner::evaluateScriptInIsolatedWorld);
bindMethod("setIsolatedWorldSecurityOrigin", &TestRunner::setIsolatedWorldSecurityOrigin);
bindMethod("setIsolatedWorldContentSecurityPolicy", &TestRunner::setIsolatedWorldContentSecurityPolicy);
bindMethod("addOriginAccessWhitelistEntry", &TestRunner::addOriginAccessWhitelistEntry);
bindMethod("removeOriginAccessWhitelistEntry", &TestRunner::removeOriginAccessWhitelistEntry);
bindMethod("hasCustomPageSizeStyle", &TestRunner::hasCustomPageSizeStyle);
bindMethod("forceRedSelectionColors", &TestRunner::forceRedSelectionColors);
bindMethod("injectStyleSheet", &TestRunner::injectStyleSheet);
bindMethod("startSpeechInput", &TestRunner::startSpeechInput);
bindMethod("findString", &TestRunner::findString);
bindMethod("setValueForUser", &TestRunner::setValueForUser);
bindMethod("selectionAsMarkup", &TestRunner::selectionAsMarkup);
bindMethod("setTextSubpixelPositioning", &TestRunner::setTextSubpixelPositioning);
bindMethod("setPageVisibility", &TestRunner::setPageVisibility);
bindMethod("setTextDirection", &TestRunner::setTextDirection);
bindMethod("textSurroundingNode", &TestRunner::textSurroundingNode);
bindMethod("useUnfortunateSynchronousResizeMode", &TestRunner::useUnfortunateSynchronousResizeMode);
bindMethod("disableAutoResizeMode", &TestRunner::disableAutoResizeMode);
bindMethod("enableAutoResizeMode", &TestRunner::enableAutoResizeMode);
bindMethod("setMockDeviceMotion", &TestRunner::setMockDeviceMotion);
bindMethod("setMockDeviceOrientation", &TestRunner::setMockDeviceOrientation);
bindMethod("didAcquirePointerLock", &TestRunner::didAcquirePointerLock);
bindMethod("didLosePointerLock", &TestRunner::didLosePointerLock);
bindMethod("didNotAcquirePointerLock", &TestRunner::didNotAcquirePointerLock);
bindMethod("setPointerLockWillRespondAsynchronously", &TestRunner::setPointerLockWillRespondAsynchronously);
bindMethod("setPointerLockWillFailSynchronously", &TestRunner::setPointerLockWillFailSynchronously);
// The following modify WebPreferences.
bindMethod("setPopupBlockingEnabled", &TestRunner::setPopupBlockingEnabled);
bindMethod("setJavaScriptCanAccessClipboard", &TestRunner::setJavaScriptCanAccessClipboard);
bindMethod("setXSSAuditorEnabled", &TestRunner::setXSSAuditorEnabled);
bindMethod("setAllowUniversalAccessFromFileURLs", &TestRunner::setAllowUniversalAccessFromFileURLs);
bindMethod("setAllowFileAccessFromFileURLs", &TestRunner::setAllowFileAccessFromFileURLs);
bindMethod("overridePreference", &TestRunner::overridePreference);
bindMethod("setPluginsEnabled", &TestRunner::setPluginsEnabled);
// The following modify the state of the TestRunner.
bindMethod("dumpEditingCallbacks", &TestRunner::dumpEditingCallbacks);
bindMethod("dumpAsText", &TestRunner::dumpAsText);
bindMethod("dumpAsTextWithPixelResults", &TestRunner::dumpAsTextWithPixelResults);
bindMethod("dumpChildFramesAsText", &TestRunner::dumpChildFramesAsText);
bindMethod("dumpChildFrameScrollPositions", &TestRunner::dumpChildFrameScrollPositions);
bindMethod("dumpIconChanges", &TestRunner::dumpIconChanges);
bindMethod("setAudioData", &TestRunner::setAudioData);
bindMethod("dumpFrameLoadCallbacks", &TestRunner::dumpFrameLoadCallbacks);
bindMethod("dumpPingLoaderCallbacks", &TestRunner::dumpPingLoaderCallbacks);
bindMethod("dumpUserGestureInFrameLoadCallbacks", &TestRunner::dumpUserGestureInFrameLoadCallbacks);
bindMethod("dumpTitleChanges", &TestRunner::dumpTitleChanges);
bindMethod("dumpCreateView", &TestRunner::dumpCreateView);
bindMethod("setCanOpenWindows", &TestRunner::setCanOpenWindows);
bindMethod("dumpResourceLoadCallbacks", &TestRunner::dumpResourceLoadCallbacks);
bindMethod("dumpResourceRequestCallbacks", &TestRunner::dumpResourceRequestCallbacks);
bindMethod("dumpResourceResponseMIMETypes", &TestRunner::dumpResourceResponseMIMETypes);
bindMethod("dumpPermissionClientCallbacks", &TestRunner::dumpPermissionClientCallbacks);
bindMethod("setImagesAllowed", &TestRunner::setImagesAllowed);
bindMethod("setScriptsAllowed", &TestRunner::setScriptsAllowed);
bindMethod("setStorageAllowed", &TestRunner::setStorageAllowed);
bindMethod("setPluginsAllowed", &TestRunner::setPluginsAllowed);
bindMethod("setAllowDisplayOfInsecureContent", &TestRunner::setAllowDisplayOfInsecureContent);
bindMethod("setAllowRunningOfInsecureContent", &TestRunner::setAllowRunningOfInsecureContent);
bindMethod("dumpStatusCallbacks", &TestRunner::dumpWindowStatusChanges);
bindMethod("dumpProgressFinishedCallback", &TestRunner::dumpProgressFinishedCallback);
bindMethod("dumpBackForwardList", &TestRunner::dumpBackForwardList);
bindMethod("setDeferMainResourceDataLoad", &TestRunner::setDeferMainResourceDataLoad);
bindMethod("dumpSelectionRect", &TestRunner::dumpSelectionRect);
bindMethod("testRepaint", &TestRunner::testRepaint);
bindMethod("repaintSweepHorizontally", &TestRunner::repaintSweepHorizontally);
bindMethod("setPrinting", &TestRunner::setPrinting);
bindMethod("setShouldStayOnPageAfterHandlingBeforeUnload", &TestRunner::setShouldStayOnPageAfterHandlingBeforeUnload);
bindMethod("setWillSendRequestClearHeader", &TestRunner::setWillSendRequestClearHeader);
bindMethod("dumpResourceRequestPriorities", &TestRunner::dumpResourceRequestPriorities);
// The following methods interact with the WebTestProxy.
// The following methods interact with the WebTestDelegate.
bindMethod("showWebInspector", &TestRunner::showWebInspector);
bindMethod("closeWebInspector", &TestRunner::closeWebInspector);
bindMethod("evaluateInWebInspector", &TestRunner::evaluateInWebInspector);
bindMethod("clearAllDatabases", &TestRunner::clearAllDatabases);
bindMethod("setDatabaseQuota", &TestRunner::setDatabaseQuota);
bindMethod("setAlwaysAcceptCookies", &TestRunner::setAlwaysAcceptCookies);
bindMethod("setWindowIsKey", &TestRunner::setWindowIsKey);
bindMethod("pathToLocalResource", &TestRunner::pathToLocalResource);
bindMethod("setBackingScaleFactor", &TestRunner::setBackingScaleFactor);
bindMethod("setPOSIXLocale", &TestRunner::setPOSIXLocale);
bindMethod("numberOfPendingGeolocationPermissionRequests", &TestRunner:: numberOfPendingGeolocationPermissionRequests);
bindMethod("setGeolocationPermission", &TestRunner::setGeolocationPermission);
bindMethod("setMockGeolocationPositionUnavailableError", &TestRunner::setMockGeolocationPositionUnavailableError);
bindMethod("setMockGeolocationPosition", &TestRunner::setMockGeolocationPosition);
bindMethod("setMIDIAccessorResult", &TestRunner::setMIDIAccessorResult);
bindMethod("setMIDISysExPermission", &TestRunner::setMIDISysExPermission);
bindMethod("grantWebNotificationPermission", &TestRunner::grantWebNotificationPermission);
bindMethod("simulateLegacyWebNotificationClick", &TestRunner::simulateLegacyWebNotificationClick);
bindMethod("cancelAllActiveNotifications", &TestRunner::cancelAllActiveNotifications);
bindMethod("addMockSpeechInputResult", &TestRunner::addMockSpeechInputResult);
bindMethod("setMockSpeechInputDumpRect", &TestRunner::setMockSpeechInputDumpRect);
bindMethod("addMockSpeechRecognitionResult", &TestRunner::addMockSpeechRecognitionResult);
bindMethod("setMockSpeechRecognitionError", &TestRunner::setMockSpeechRecognitionError);
bindMethod("wasMockSpeechRecognitionAborted", &TestRunner::wasMockSpeechRecognitionAborted);
bindMethod("display", &TestRunner::display);
bindMethod("displayInvalidatedRegion", &TestRunner::displayInvalidatedRegion);
bindMethod("isChooserShown", &TestRunner::isChooserShown);
// The following modify WebPageOverlays.
bindMethod("addWebPageOverlay", &TestRunner::addWebPageOverlay);
bindMethod("removeWebPageOverlay", &TestRunner::removeWebPageOverlay);
// Properties.
bindProperty("globalFlag", &m_globalFlag);
bindProperty("platformName", &m_platformName);
bindProperty("tooltipText", &m_tooltipText);
bindProperty("disableNotifyDone", &m_disableNotifyDone);
// webHistoryItemCount is used by tests in LayoutTests\http\tests\history
bindProperty("webHistoryItemCount", &m_webHistoryItemCount);
bindProperty("interceptPostMessage", &m_interceptPostMessage);
// The following are stubs.
bindMethod("dumpDatabaseCallbacks", &TestRunner::notImplemented);
bindMethod("denyWebNotificationPermission", &TestRunner::notImplemented);
bindMethod("removeAllWebNotificationPermissions", &TestRunner::notImplemented);
bindMethod("simulateWebNotificationClick", &TestRunner::notImplemented);
bindMethod("setIconDatabaseEnabled", &TestRunner::notImplemented);
bindMethod("setScrollbarPolicy", &TestRunner::notImplemented);
bindMethod("clearAllApplicationCaches", &TestRunner::notImplemented);
bindMethod("clearApplicationCacheForOrigin", &TestRunner::notImplemented);
bindMethod("clearBackForwardList", &TestRunner::notImplemented);
bindMethod("keepWebHistory", &TestRunner::notImplemented);
bindMethod("setApplicationCacheOriginQuota", &TestRunner::notImplemented);
bindMethod("setCallCloseOnWebViews", &TestRunner::notImplemented);
bindMethod("setMainFrameIsFirstResponder", &TestRunner::notImplemented);
bindMethod("setUseDashboardCompatibilityMode", &TestRunner::notImplemented);
bindMethod("deleteAllLocalStorage", &TestRunner::notImplemented);
bindMethod("localStorageDiskUsageForOrigin", &TestRunner::notImplemented);
bindMethod("originsWithLocalStorage", &TestRunner::notImplemented);
bindMethod("deleteLocalStorageForOrigin", &TestRunner::notImplemented);
bindMethod("observeStorageTrackerNotifications", &TestRunner::notImplemented);
bindMethod("syncLocalStorage", &TestRunner::notImplemented);
bindMethod("addDisallowedURL", &TestRunner::notImplemented);
bindMethod("applicationCacheDiskUsageForOrigin", &TestRunner::notImplemented);
bindMethod("abortModal", &TestRunner::notImplemented);
// The fallback method is called when an unknown method is invoked.
bindFallbackMethod(&TestRunner::fallbackMethod);
}
TestRunner::~TestRunner()
{
}
void TestRunner::setDelegate(WebTestDelegate* delegate)
{
m_delegate = delegate;
m_webPermissions->setDelegate(delegate);
m_notificationPresenter->setDelegate(delegate);
}
void TestRunner::setWebView(WebView* webView, WebTestProxyBase* proxy)
{
m_webView = webView;
m_proxy = proxy;
}
void TestRunner::reset()
{
if (m_webView) {
m_webView->setZoomLevel(0);
m_webView->setTextZoomFactor(1);
m_webView->setTabKeyCyclesThroughElements(true);
#if !defined(__APPLE__) && !defined(WIN32) // Actually, TOOLKIT_GTK
// (Constants copied because we can't depend on the header that defined
// them from this file.)
m_webView->setSelectionColors(0xff1e90ff, 0xff000000, 0xffc8c8c8, 0xff323232);
#endif
m_webView->removeInjectedStyleSheets();
m_webView->setVisibilityState(WebPageVisibilityStateVisible, true);
m_webView->mainFrame()->enableViewSourceMode(false);
if (m_pageOverlay) {
m_webView->removePageOverlay(m_pageOverlay);
delete m_pageOverlay;
m_pageOverlay = 0;
}
}
m_topLoadingFrame = 0;
m_waitUntilDone = false;
m_policyDelegateEnabled = false;
m_policyDelegateIsPermissive = false;
m_policyDelegateShouldNotifyDone = false;
WebSecurityPolicy::resetOriginAccessWhitelists();
#if defined(__linux__) || defined(ANDROID)
WebFontRendering::setSubpixelPositioning(false);
#endif
if (m_delegate) {
// Reset the default quota for each origin to 5MB
m_delegate->setDatabaseQuota(5 * 1024 * 1024);
m_delegate->setDeviceScaleFactor(1);
m_delegate->setAcceptAllCookies(false);
m_delegate->setLocale("");
m_delegate->useUnfortunateSynchronousResizeMode(false);
m_delegate->disableAutoResizeMode(WebSize());
m_delegate->deleteAllCookies();
}
m_dumpEditingCallbacks = false;
m_dumpAsText = false;
m_dumpAsMarkup = false;
m_generatePixelResults = true;
m_dumpChildFrameScrollPositions = false;
m_dumpChildFramesAsText = false;
m_dumpIconChanges = false;
m_dumpAsAudio = false;
m_dumpFrameLoadCallbacks = false;
m_dumpPingLoaderCallbacks = false;
m_dumpUserGestureInFrameLoadCallbacks = false;
m_dumpTitleChanges = false;
m_dumpCreateView = false;
m_canOpenWindows = false;
m_dumpResourceLoadCallbacks = false;
m_dumpResourceRequestCallbacks = false;
m_dumpResourceResponseMIMETypes = false;
m_dumpWindowStatusChanges = false;
m_dumpProgressFinishedCallback = false;
m_dumpBackForwardList = false;
m_deferMainResourceDataLoad = true;
m_dumpSelectionRect = false;
m_testRepaint = false;
m_sweepHorizontally = false;
m_isPrinting = false;
m_midiAccessorResult = true;
m_shouldStayOnPageAfterHandlingBeforeUnload = false;
m_shouldDumpResourcePriorities = false;
m_httpHeadersToClear.clear();
m_globalFlag.set(false);
m_webHistoryItemCount.set(0);
m_interceptPostMessage.set(false);
m_platformName.set("chromium");
m_tooltipText.set("");
m_disableNotifyDone.set(false);
m_webPermissions->reset();
m_notificationPresenter->reset();
m_pointerLocked = false;
m_pointerLockPlannedResult = PointerLockWillSucceed;
m_taskList.revokeAll();
m_workQueue.reset();
if (m_closeRemainingWindows && m_delegate)
m_delegate->closeRemainingWindows();
else
m_closeRemainingWindows = true;
}
void TestRunner::setTestIsRunning(bool running)
{
m_testIsRunning = running;
}
bool TestRunner::shouldDumpEditingCallbacks() const
{
return m_dumpEditingCallbacks;
}
void TestRunner::checkResponseMimeType()
{
// Text output: the test page can request different types of output
// which we handle here.
if (!m_dumpAsText) {
string mimeType = m_webView->mainFrame()->dataSource()->response().mimeType().utf8();
if (mimeType == "text/plain") {
m_dumpAsText = true;
m_generatePixelResults = false;
}
}
}
bool TestRunner::shouldDumpAsText()
{
checkResponseMimeType();
return m_dumpAsText;
}
void TestRunner::setShouldDumpAsText(bool value)
{
m_dumpAsText = value;
}
bool TestRunner::shouldDumpAsMarkup()
{
return m_dumpAsMarkup;
}
void TestRunner::setShouldDumpAsMarkup(bool value)
{
m_dumpAsMarkup = value;
}
bool TestRunner::shouldGeneratePixelResults()
{
checkResponseMimeType();
return m_generatePixelResults;
}
void TestRunner::setShouldGeneratePixelResults(bool value)
{
m_generatePixelResults = value;
}
bool TestRunner::shouldDumpChildFrameScrollPositions() const
{
return m_dumpChildFrameScrollPositions;
}
bool TestRunner::shouldDumpChildFramesAsText() const
{
return m_dumpChildFramesAsText;
}
bool TestRunner::shouldDumpAsAudio() const
{
return m_dumpAsAudio;
}
const WebArrayBufferView* TestRunner::audioData() const
{
return &m_audioData;
}
bool TestRunner::shouldDumpFrameLoadCallbacks() const
{
return m_testIsRunning && m_dumpFrameLoadCallbacks;
}
void TestRunner::setShouldDumpFrameLoadCallbacks(bool value)
{
m_dumpFrameLoadCallbacks = value;
}
bool TestRunner::shouldDumpPingLoaderCallbacks() const
{
return m_testIsRunning && m_dumpPingLoaderCallbacks;
}
void TestRunner::setShouldDumpPingLoaderCallbacks(bool value)
{
m_dumpPingLoaderCallbacks = value;
}
void TestRunner::setShouldEnableViewSource(bool value)
{
m_webView->mainFrame()->enableViewSourceMode(value);
}
bool TestRunner::shouldDumpUserGestureInFrameLoadCallbacks() const
{
return m_testIsRunning && m_dumpUserGestureInFrameLoadCallbacks;
}
bool TestRunner::shouldDumpTitleChanges() const
{
return m_dumpTitleChanges;
}
bool TestRunner::shouldDumpIconChanges() const
{
return m_dumpIconChanges;
}
bool TestRunner::shouldDumpCreateView() const
{
return m_dumpCreateView;
}
bool TestRunner::canOpenWindows() const
{
return m_canOpenWindows;
}
bool TestRunner::shouldDumpResourceLoadCallbacks() const
{
return m_testIsRunning && m_dumpResourceLoadCallbacks;
}
bool TestRunner::shouldDumpResourceRequestCallbacks() const
{
return m_testIsRunning && m_dumpResourceRequestCallbacks;
}
bool TestRunner::shouldDumpResourceResponseMIMETypes() const
{
return m_testIsRunning && m_dumpResourceResponseMIMETypes;
}
WebPermissionClient* TestRunner::webPermissions() const
{
return m_webPermissions.get();
}
bool TestRunner::shouldDumpStatusCallbacks() const
{
return m_dumpWindowStatusChanges;
}
bool TestRunner::shouldDumpProgressFinishedCallback() const
{
return m_dumpProgressFinishedCallback;
}
bool TestRunner::shouldDumpBackForwardList() const
{
return m_dumpBackForwardList;
}
bool TestRunner::deferMainResourceDataLoad() const
{
return m_deferMainResourceDataLoad;
}
bool TestRunner::shouldDumpSelectionRect() const
{
return m_dumpSelectionRect;
}
bool TestRunner::testRepaint() const
{
return m_testRepaint;
}
bool TestRunner::sweepHorizontally() const
{
return m_sweepHorizontally;
}
bool TestRunner::isPrinting() const
{
return m_isPrinting;
}
bool TestRunner::shouldStayOnPageAfterHandlingBeforeUnload() const
{
return m_shouldStayOnPageAfterHandlingBeforeUnload;
}
const std::set<std::string>* TestRunner::httpHeadersToClear() const
{
return &m_httpHeadersToClear;
}
void TestRunner::setTopLoadingFrame(WebFrame* frame, bool clear)
{
if (frame->top()->view() != m_webView)
return;
if (!m_testIsRunning)
return;
if (clear) {
m_topLoadingFrame = 0;
locationChangeDone();
} else if (!m_topLoadingFrame)
m_topLoadingFrame = frame;
}
WebFrame* TestRunner::topLoadingFrame() const
{
return m_topLoadingFrame;
}
void TestRunner::policyDelegateDone()
{
BLINK_ASSERT(m_waitUntilDone);
m_delegate->testFinished();
m_waitUntilDone = false;
}
bool TestRunner::policyDelegateEnabled() const
{
return m_policyDelegateEnabled;
}
bool TestRunner::policyDelegateIsPermissive() const
{
return m_policyDelegateIsPermissive;
}
bool TestRunner::policyDelegateShouldNotifyDone() const
{
return m_policyDelegateShouldNotifyDone;
}
bool TestRunner::shouldInterceptPostMessage() const
{
return m_interceptPostMessage.isBool() && m_interceptPostMessage.toBoolean();
}
bool TestRunner::shouldDumpResourcePriorities() const
{
return m_shouldDumpResourcePriorities;
}
WebNotificationPresenter* TestRunner::notificationPresenter() const
{
return m_notificationPresenter.get();
}
bool TestRunner::requestPointerLock()
{
switch (m_pointerLockPlannedResult) {
case PointerLockWillSucceed:
m_delegate->postDelayedTask(new HostMethodTask(this, &TestRunner::didAcquirePointerLockInternal), 0);
return true;
case PointerLockWillRespondAsync:
BLINK_ASSERT(!m_pointerLocked);
return true;
case PointerLockWillFailSync:
BLINK_ASSERT(!m_pointerLocked);
return false;
default:
BLINK_ASSERT_NOT_REACHED();
return false;
}
}
void TestRunner::requestPointerUnlock()
{
m_delegate->postDelayedTask(new HostMethodTask(this, &TestRunner::didLosePointerLockInternal), 0);
}
bool TestRunner::isPointerLocked()
{
return m_pointerLocked;
}
void TestRunner::setToolTipText(const blink::WebString& text)
{
m_tooltipText.set(text.utf8());
}
bool TestRunner::midiAccessorResult()
{
return m_midiAccessorResult;
}
TestRunner::TestPageOverlay::TestPageOverlay(blink::WebView* webView) : m_webView(webView)
{
}
TestRunner::TestPageOverlay::~TestPageOverlay()
{
}
void TestRunner::TestPageOverlay::paintPageOverlay(blink::WebCanvas* canvas)
{
SkRect rect = SkRect::MakeWH(m_webView->size().width, m_webView->size().height);
SkPaint paint;
paint.setColor(SK_ColorCYAN);
paint.setStyle(SkPaint::kFill_Style);
canvas->drawRect(rect, paint);
}
void TestRunner::didAcquirePointerLockInternal()
{
m_pointerLocked = true;
m_webView->didAcquirePointerLock();
// Reset planned result to default.
m_pointerLockPlannedResult = PointerLockWillSucceed;
}
void TestRunner::didNotAcquirePointerLockInternal()
{
BLINK_ASSERT(!m_pointerLocked);
m_pointerLocked = false;
m_webView->didNotAcquirePointerLock();
// Reset planned result to default.
m_pointerLockPlannedResult = PointerLockWillSucceed;
}
void TestRunner::didLosePointerLockInternal()
{
bool wasLocked = m_pointerLocked;
m_pointerLocked = false;
if (wasLocked)
m_webView->didLosePointerLock();
}
void TestRunner::showDevTools()
{
m_delegate->showDevTools();
}
void TestRunner::waitUntilDone(const CppArgumentList&, CppVariant* result)
{
m_waitUntilDone = true;
result->setNull();
}
void TestRunner::notifyDone(const CppArgumentList&, CppVariant* result)
{
if (m_disableNotifyDone.toBoolean())
return;
// Test didn't timeout. Kill the timeout timer.
taskList()->revokeAll();
completeNotifyDone();
result->setNull();
}
void TestRunner::completeNotifyDone()
{
if (m_waitUntilDone && !topLoadingFrame() && m_workQueue.isEmpty())
m_delegate->testFinished();
m_waitUntilDone = false;
}
class WorkItemBackForward : public TestRunner::WorkItem {
public:
WorkItemBackForward(int distance) : m_distance(distance) { }
bool run(WebTestDelegate* delegate, WebView*)
{
delegate->goToOffset(m_distance);
return true; // FIXME: Did it really start a navigation?
}
private:
int m_distance;
};
void TestRunner::queueBackNavigation(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isNumber())
m_workQueue.addWork(new WorkItemBackForward(-arguments[0].toInt32()));
result->setNull();
}
void TestRunner::queueForwardNavigation(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isNumber())
m_workQueue.addWork(new WorkItemBackForward(arguments[0].toInt32()));
result->setNull();
}
class WorkItemReload : public TestRunner::WorkItem {
public:
bool run(WebTestDelegate* delegate, WebView*)
{
delegate->reload();
return true;
}
};
void TestRunner::queueReload(const CppArgumentList&, CppVariant* result)
{
m_workQueue.addWork(new WorkItemReload);
result->setNull();
}
class WorkItemLoadingScript : public TestRunner::WorkItem {
public:
WorkItemLoadingScript(const string& script) : m_script(script) { }
bool run(WebTestDelegate*, WebView* webView)
{
webView->mainFrame()->executeScript(WebScriptSource(WebString::fromUTF8(m_script)));
return true; // FIXME: Did it really start a navigation?
}
private:
string m_script;
};
class WorkItemNonLoadingScript : public TestRunner::WorkItem {
public:
WorkItemNonLoadingScript(const string& script) : m_script(script) { }
bool run(WebTestDelegate*, WebView* webView)
{
webView->mainFrame()->executeScript(WebScriptSource(WebString::fromUTF8(m_script)));
return false;
}
private:
string m_script;
};
void TestRunner::queueLoadingScript(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isString())
m_workQueue.addWork(new WorkItemLoadingScript(arguments[0].toString()));
result->setNull();
}
void TestRunner::queueNonLoadingScript(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isString())
m_workQueue.addWork(new WorkItemNonLoadingScript(arguments[0].toString()));
result->setNull();
}
class WorkItemLoad : public TestRunner::WorkItem {
public:
WorkItemLoad(const WebURL& url, const string& target)
: m_url(url)
, m_target(target) { }
bool run(WebTestDelegate* delegate, WebView*)
{
delegate->loadURLForFrame(m_url, m_target);
return true; // FIXME: Did it really start a navigation?
}
private:
WebURL m_url;
string m_target;
};
void TestRunner::queueLoad(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isString()) {
// FIXME: Implement WebURL::resolve() and avoid GURL.
GURL currentURL = m_webView->mainFrame()->document().url();
GURL fullURL = currentURL.Resolve(arguments[0].toString());
string target = "";
if (arguments.size() > 1 && arguments[1].isString())
target = arguments[1].toString();
m_workQueue.addWork(new WorkItemLoad(fullURL, target));
}
result->setNull();
}
class WorkItemLoadHTMLString : public TestRunner::WorkItem {
public:
WorkItemLoadHTMLString(const std::string& html, const WebURL& baseURL)
: m_html(html)
, m_baseURL(baseURL) { }
WorkItemLoadHTMLString(const std::string& html, const WebURL& baseURL, const WebURL& unreachableURL)
: m_html(html)
, m_baseURL(baseURL)
, m_unreachableURL(unreachableURL) { }
bool run(WebTestDelegate*, WebView* webView)
{
webView->mainFrame()->loadHTMLString(
blink::WebData(m_html.data(), m_html.length()), m_baseURL, m_unreachableURL);
return true;
}
private:
std::string m_html;
WebURL m_baseURL;
WebURL m_unreachableURL;
};
void TestRunner::queueLoadHTMLString(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isString()) {
string html = arguments[0].toString();
WebURL baseURL(GURL(""));
if (arguments.size() > 1 && arguments[1].isString())
baseURL = WebURL(GURL(arguments[1].toString()));
if (arguments.size() > 2 && arguments[2].isString())
m_workQueue.addWork(new WorkItemLoadHTMLString(html, baseURL, WebURL(GURL(arguments[2].toString()))));
else
m_workQueue.addWork(new WorkItemLoadHTMLString(html, baseURL));
}
result->setNull();
}
void TestRunner::locationChangeDone()
{
m_webHistoryItemCount.set(m_delegate->navigationEntryCount());
// No more new work after the first complete load.
m_workQueue.setFrozen(true);
if (!m_waitUntilDone)
m_workQueue.processWorkSoon();
}
void TestRunner::windowCount(const CppArgumentList&, CppVariant* result)
{
result->set(static_cast<int>(m_testInterfaces->windowList().size()));
}
void TestRunner::setCloseRemainingWindowsWhenComplete(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_closeRemainingWindows = arguments[0].value.boolValue;
result->setNull();
}
void TestRunner::resetTestHelperControllers(const CppArgumentList& arguments, CppVariant* result)
{
m_testInterfaces->resetTestHelperControllers();
result->setNull();
}
void TestRunner::setCustomPolicyDelegate(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool()) {
m_policyDelegateEnabled = arguments[0].value.boolValue;
m_policyDelegateIsPermissive = false;
if (arguments.size() > 1 && arguments[1].isBool())
m_policyDelegateIsPermissive = arguments[1].value.boolValue;
}
result->setNull();
}
void TestRunner::waitForPolicyDelegate(const CppArgumentList&, CppVariant* result)
{
m_policyDelegateEnabled = true;
m_policyDelegateShouldNotifyDone = true;
m_waitUntilDone = true;
result->setNull();
}
void TestRunner::dumpPermissionClientCallbacks(const CppArgumentList&, CppVariant* result)
{
m_webPermissions->setDumpCallbacks(true);
result->setNull();
}
void TestRunner::setImagesAllowed(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_webPermissions->setImagesAllowed(arguments[0].toBoolean());
result->setNull();
}
void TestRunner::setScriptsAllowed(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_webPermissions->setScriptsAllowed(arguments[0].toBoolean());
result->setNull();
}
void TestRunner::setStorageAllowed(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_webPermissions->setStorageAllowed(arguments[0].toBoolean());
result->setNull();
}
void TestRunner::setPluginsAllowed(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_webPermissions->setPluginsAllowed(arguments[0].toBoolean());
result->setNull();
}
void TestRunner::setAllowDisplayOfInsecureContent(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_webPermissions->setDisplayingInsecureContentAllowed(arguments[0].toBoolean());
result->setNull();
}
void TestRunner::setAllowRunningOfInsecureContent(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_webPermissions->setRunningInsecureContentAllowed(arguments[0].value.boolValue);
result->setNull();
}
void TestRunner::dumpWindowStatusChanges(const CppArgumentList&, CppVariant* result)
{
m_dumpWindowStatusChanges = true;
result->setNull();
}
void TestRunner::dumpProgressFinishedCallback(const CppArgumentList&, CppVariant* result)
{
m_dumpProgressFinishedCallback = true;
result->setNull();
}
void TestRunner::dumpBackForwardList(const CppArgumentList&, CppVariant* result)
{
m_dumpBackForwardList = true;
result->setNull();
}
void TestRunner::setDeferMainResourceDataLoad(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() == 1)
m_deferMainResourceDataLoad = cppVariantToBool(arguments[0]);
}
void TestRunner::dumpSelectionRect(const CppArgumentList& arguments, CppVariant* result)
{
m_dumpSelectionRect = true;
result->setNull();
}
void TestRunner::testRepaint(const CppArgumentList&, CppVariant* result)
{
m_testRepaint = true;
result->setNull();
}
void TestRunner::repaintSweepHorizontally(const CppArgumentList&, CppVariant* result)
{
m_sweepHorizontally = true;
result->setNull();
}
void TestRunner::setPrinting(const CppArgumentList& arguments, CppVariant* result)
{
m_isPrinting = true;
result->setNull();
}
void TestRunner::setShouldStayOnPageAfterHandlingBeforeUnload(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() == 1 && arguments[0].isBool())
m_shouldStayOnPageAfterHandlingBeforeUnload = arguments[0].toBoolean();
result->setNull();
}
void TestRunner::setWillSendRequestClearHeader(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isString()) {
string header = arguments[0].toString();
if (!header.empty())
m_httpHeadersToClear.insert(header);
}
result->setNull();
}
void TestRunner::setTabKeyCyclesThroughElements(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_webView->setTabKeyCyclesThroughElements(arguments[0].toBoolean());
result->setNull();
}
void TestRunner::execCommand(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() <= 0 || !arguments[0].isString())
return;
std::string command = arguments[0].toString();
std::string value("");
// Ignore the second parameter (which is userInterface)
// since this command emulates a manual action.
if (arguments.size() >= 3 && arguments[2].isString())
value = arguments[2].toString();
// Note: webkit's version does not return the boolean, so neither do we.
m_webView->focusedFrame()->executeCommand(WebString::fromUTF8(command), WebString::fromUTF8(value));
}
void TestRunner::isCommandEnabled(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() <= 0 || !arguments[0].isString()) {
result->setNull();
return;
}
std::string command = arguments[0].toString();
bool rv = m_webView->focusedFrame()->isCommandEnabled(WebString::fromUTF8(command));
result->set(rv);
}
void TestRunner::callShouldCloseOnWebView(const CppArgumentList&, CppVariant* result)
{
result->set(m_webView->dispatchBeforeUnloadEvent());
}
void TestRunner::setDomainRelaxationForbiddenForURLScheme(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() != 2 || !arguments[0].isBool() || !arguments[1].isString())
return;
m_webView->setDomainRelaxationForbidden(cppVariantToBool(arguments[0]), cppVariantToWebString(arguments[1]));
}
void TestRunner::evaluateScriptInIsolatedWorldAndReturnValue(const CppArgumentList& arguments, CppVariant* result)
{
v8::HandleScope scope(v8::Isolate::GetCurrent());
WebVector<v8::Local<v8::Value> > values;
if (arguments.size() >= 2 && arguments[0].isNumber() && arguments[1].isString()) {
WebScriptSource source(cppVariantToWebString(arguments[1]));
// This relies on the iframe focusing itself when it loads. This is a bit
// sketchy, but it seems to be what other tests do.
m_webView->focusedFrame()->executeScriptInIsolatedWorld(arguments[0].toInt32(), &source, 1, 1, &values);
}
result->setNull();
// Since only one script was added, only one result is expected
if (values.size() == 1 && !values[0].IsEmpty()) {
v8::Local<v8::Value> scriptValue = values[0];
// FIXME: There are many more types that can be handled.
if (scriptValue->IsString()) {
v8::String::Utf8Value utf8V8(scriptValue);
result->set(std::string(*utf8V8));
} else if (scriptValue->IsBoolean())
result->set(scriptValue->ToBoolean()->Value());
else if (scriptValue->IsNumber()) {
if (scriptValue->IsInt32())
result->set(scriptValue->ToInt32()->Value());
else
result->set(scriptValue->ToNumber()->Value());
} else if (scriptValue->IsNull())
result->setNull();
}
}
void TestRunner::evaluateScriptInIsolatedWorld(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() >= 2 && arguments[0].isNumber() && arguments[1].isString()) {
WebScriptSource source(cppVariantToWebString(arguments[1]));
// This relies on the iframe focusing itself when it loads. This is a bit
// sketchy, but it seems to be what other tests do.
m_webView->focusedFrame()->executeScriptInIsolatedWorld(arguments[0].toInt32(), &source, 1, 1);
}
result->setNull();
}
void TestRunner::setIsolatedWorldSecurityOrigin(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 2 || !arguments[0].isNumber() || !(arguments[1].isString() || arguments[1].isNull()))
return;
WebSecurityOrigin origin;
if (arguments[1].isString())
origin = WebSecurityOrigin::createFromString(cppVariantToWebString(arguments[1]));
m_webView->focusedFrame()->setIsolatedWorldSecurityOrigin(arguments[0].toInt32(), origin);
}
void TestRunner::setIsolatedWorldContentSecurityPolicy(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 2 || !arguments[0].isNumber() || !arguments[1].isString())
return;
m_webView->focusedFrame()->setIsolatedWorldContentSecurityPolicy(arguments[0].toInt32(), cppVariantToWebString(arguments[1]));
}
void TestRunner::addOriginAccessWhitelistEntry(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 4 || !arguments[0].isString() || !arguments[1].isString()
|| !arguments[2].isString() || !arguments[3].isBool())
return;
blink::WebURL url(GURL(arguments[0].toString()));
if (!url.isValid())
return;
WebSecurityPolicy::addOriginAccessWhitelistEntry(
url,
cppVariantToWebString(arguments[1]),
cppVariantToWebString(arguments[2]),
arguments[3].toBoolean());
}
void TestRunner::removeOriginAccessWhitelistEntry(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 4 || !arguments[0].isString() || !arguments[1].isString()
|| !arguments[2].isString() || !arguments[3].isBool())
return;
blink::WebURL url(GURL(arguments[0].toString()));
if (!url.isValid())
return;
WebSecurityPolicy::removeOriginAccessWhitelistEntry(
url,
cppVariantToWebString(arguments[1]),
cppVariantToWebString(arguments[2]),
arguments[3].toBoolean());
}
void TestRunner::hasCustomPageSizeStyle(const CppArgumentList& arguments, CppVariant* result)
{
result->set(false);
int pageIndex = 0;
if (arguments.size() > 1)
return;
if (arguments.size() == 1)
pageIndex = cppVariantToInt32(arguments[0]);
WebFrame* frame = m_webView->mainFrame();
if (!frame)
return;
result->set(frame->hasCustomPageSizeStyle(pageIndex));
}
void TestRunner::forceRedSelectionColors(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
m_webView->setSelectionColors(0xffee0000, 0xff00ee00, 0xff000000, 0xffc0c0c0);
}
void TestRunner::injectStyleSheet(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 2 || !arguments[0].isString() || !arguments[1].isBool())
return;
WebView::injectStyleSheet(
cppVariantToWebString(arguments[0]), WebVector<WebString>(),
arguments[1].toBoolean() ? WebView::InjectStyleInAllFrames : WebView::InjectStyleInTopFrameOnly);
}
void TestRunner::startSpeechInput(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 1)
return;
WebElement element;
if (!WebBindings::getElement(arguments[0].value.objectValue, &element))
return;
WebInputElement* input = toWebInputElement(&element);
if (!input)
return;
if (!input->isSpeechInputEnabled())
return;
input->startSpeechInput();
}
void TestRunner::findString(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() < 1 || !arguments[0].isString())
return;
WebFindOptions findOptions;
bool wrapAround = false;
if (arguments.size() >= 2) {
vector<string> optionsArray = arguments[1].toStringVector();
findOptions.matchCase = true;
findOptions.findNext = true;
for (size_t i = 0; i < optionsArray.size(); ++i) {
const std::string& option = optionsArray[i];
if (option == "CaseInsensitive")
findOptions.matchCase = false;
else if (option == "Backwards")
findOptions.forward = false;
else if (option == "StartInSelection")
findOptions.findNext = false;
else if (option == "AtWordStarts")
findOptions.wordStart = true;
else if (option == "TreatMedialCapitalAsWordStart")
findOptions.medialCapitalAsWordStart = true;
else if (option == "WrapAround")
wrapAround = true;
}
}
WebFrame* frame = m_webView->mainFrame();
const bool findResult = frame->find(0, cppVariantToWebString(arguments[0]), findOptions, wrapAround, 0);
frame->stopFinding(false);
result->set(findResult);
}
void TestRunner::setValueForUser(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 2)
return;
WebElement element;
if (!WebBindings::getElement(arguments[0].value.objectValue, &element))
return;
WebInputElement* input = toWebInputElement(&element);
if (!input)
return;
input->setValue(cppVariantToWebString(arguments[1]), true);
}
void TestRunner::selectionAsMarkup(const CppArgumentList& arguments, CppVariant* result)
{
result->set(m_webView->mainFrame()->selectionAsMarkup().utf8());
}
void TestRunner::setTextSubpixelPositioning(const CppArgumentList& arguments, CppVariant* result)
{
#if defined(__linux__) || defined(ANDROID)
// Since FontConfig doesn't provide a variable to control subpixel positioning, we'll fall back
// to setting it globally for all fonts.
if (arguments.size() > 0 && arguments[0].isBool())
WebFontRendering::setSubpixelPositioning(arguments[0].value.boolValue);
#endif
result->setNull();
}
void TestRunner::setPageVisibility(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isString()) {
string newVisibility = arguments[0].toString();
if (newVisibility == "visible")
m_webView->setVisibilityState(WebPageVisibilityStateVisible, false);
else if (newVisibility == "hidden")
m_webView->setVisibilityState(WebPageVisibilityStateHidden, false);
else if (newVisibility == "prerender")
m_webView->setVisibilityState(WebPageVisibilityStatePrerender, false);
}
}
void TestRunner::setTextDirection(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 1 || !arguments[0].isString())
return;
// Map a direction name to a WebTextDirection value.
std::string directionName = arguments[0].toString();
blink::WebTextDirection direction;
if (directionName == "auto")
direction = blink::WebTextDirectionDefault;
else if (directionName == "rtl")
direction = blink::WebTextDirectionRightToLeft;
else if (directionName == "ltr")
direction = blink::WebTextDirectionLeftToRight;
else
return;
m_webView->setTextDirection(direction);
}
void TestRunner::textSurroundingNode(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 4 || !arguments[0].isObject() || !arguments[1].isNumber() || !arguments[2].isNumber() || !arguments[3].isNumber())
return;
WebNode node;
if (!WebBindings::getNode(arguments[0].value.objectValue, &node))
return;
if (node.isNull() || !node.isTextNode())
return;
WebPoint point(arguments[1].toInt32(), arguments[2].toInt32());
unsigned maxLength = arguments[3].toInt32();
WebSurroundingText surroundingText;
surroundingText.initialize(node, point, maxLength);
if (surroundingText.isNull())
return;
result->set(surroundingText.textContent().utf8());
}
void TestRunner::dumpResourceRequestPriorities(const CppArgumentList& arguments, CppVariant* result)
{
m_shouldDumpResourcePriorities = true;
result->setNull();
}
void TestRunner::useUnfortunateSynchronousResizeMode(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
m_delegate->useUnfortunateSynchronousResizeMode(true);
}
void TestRunner::enableAutoResizeMode(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() != 4) {
result->set(false);
return;
}
int minWidth = cppVariantToInt32(arguments[0]);
int minHeight = cppVariantToInt32(arguments[1]);
blink::WebSize minSize(minWidth, minHeight);
int maxWidth = cppVariantToInt32(arguments[2]);
int maxHeight = cppVariantToInt32(arguments[3]);
blink::WebSize maxSize(maxWidth, maxHeight);
m_delegate->enableAutoResizeMode(minSize, maxSize);
result->set(true);
}
void TestRunner::disableAutoResizeMode(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() !=2) {
result->set(false);
return;
}
int newWidth = cppVariantToInt32(arguments[0]);
int newHeight = cppVariantToInt32(arguments[1]);
blink::WebSize newSize(newWidth, newHeight);
m_delegate->disableAutoResizeMode(newSize);
result->set(true);
}
void TestRunner::setMockDeviceMotion(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 19
|| !arguments[0].isBool() || !arguments[1].isNumber() // acceleration.x
|| !arguments[2].isBool() || !arguments[3].isNumber() // acceleration.y
|| !arguments[4].isBool() || !arguments[5].isNumber() // acceleration.z
|| !arguments[6].isBool() || !arguments[7].isNumber() // accelerationIncludingGravity.x
|| !arguments[8].isBool() || !arguments[9].isNumber() // accelerationIncludingGravity.y
|| !arguments[10].isBool() || !arguments[11].isNumber() // accelerationIncludingGravity.z
|| !arguments[12].isBool() || !arguments[13].isNumber() // rotationRate.alpha
|| !arguments[14].isBool() || !arguments[15].isNumber() // rotationRate.beta
|| !arguments[16].isBool() || !arguments[17].isNumber() // rotationRate.gamma
|| !arguments[18].isNumber()) // interval
return;
WebDeviceMotionData motion;
// acceleration
motion.hasAccelerationX = arguments[0].toBoolean();
motion.accelerationX = arguments[1].toDouble();
motion.hasAccelerationY = arguments[2].toBoolean();
motion.accelerationY = arguments[3].toDouble();
motion.hasAccelerationZ = arguments[4].toBoolean();
motion.accelerationZ = arguments[5].toDouble();
// accelerationIncludingGravity
motion.hasAccelerationIncludingGravityX = arguments[6].toBoolean();
motion.accelerationIncludingGravityX = arguments[7].toDouble();
motion.hasAccelerationIncludingGravityY = arguments[8].toBoolean();
motion.accelerationIncludingGravityY = arguments[9].toDouble();
motion.hasAccelerationIncludingGravityZ = arguments[10].toBoolean();
motion.accelerationIncludingGravityZ = arguments[11].toDouble();
// rotationRate
motion.hasRotationRateAlpha = arguments[12].toBoolean();
motion.rotationRateAlpha = arguments[13].toDouble();
motion.hasRotationRateBeta = arguments[14].toBoolean();
motion.rotationRateBeta = arguments[15].toDouble();
motion.hasRotationRateGamma = arguments[16].toBoolean();
motion.rotationRateGamma = arguments[17].toDouble();
// interval
motion.interval = arguments[18].toDouble();
m_delegate->setDeviceMotionData(motion);
}
void TestRunner::setMockDeviceOrientation(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 8
|| !arguments[0].isBool() || !arguments[1].isNumber() // alpha
|| !arguments[2].isBool() || !arguments[3].isNumber() // beta
|| !arguments[4].isBool() || !arguments[5].isNumber() // gamma
|| !arguments[6].isBool() || !arguments[7].isBool()) // absolute
return;
WebDeviceOrientationData orientation;
// alpha
orientation.hasAlpha = arguments[0].toBoolean();
orientation.alpha = arguments[1].toDouble();
// beta
orientation.hasBeta = arguments[2].toBoolean();
orientation.beta = arguments[3].toDouble();
// gamma
orientation.hasGamma = arguments[4].toBoolean();
orientation.gamma = arguments[5].toDouble();
// absolute
orientation.hasAbsolute = arguments[6].toBoolean();
orientation.absolute = arguments[7].toBoolean();
m_delegate->setDeviceOrientationData(orientation);
}
void TestRunner::setPopupBlockingEnabled(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool()) {
bool blockPopups = arguments[0].toBoolean();
m_delegate->preferences()->javaScriptCanOpenWindowsAutomatically = !blockPopups;
m_delegate->applyPreferences();
}
result->setNull();
}
void TestRunner::setJavaScriptCanAccessClipboard(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool()) {
m_delegate->preferences()->javaScriptCanAccessClipboard = arguments[0].value.boolValue;
m_delegate->applyPreferences();
}
result->setNull();
}
void TestRunner::setXSSAuditorEnabled(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool()) {
m_delegate->preferences()->XSSAuditorEnabled = arguments[0].value.boolValue;
m_delegate->applyPreferences();
}
result->setNull();
}
void TestRunner::setAllowUniversalAccessFromFileURLs(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool()) {
m_delegate->preferences()->allowUniversalAccessFromFileURLs = arguments[0].value.boolValue;
m_delegate->applyPreferences();
}
result->setNull();
}
void TestRunner::setAllowFileAccessFromFileURLs(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool()) {
m_delegate->preferences()->allowFileAccessFromFileURLs = arguments[0].value.boolValue;
m_delegate->applyPreferences();
}
result->setNull();
}
void TestRunner::overridePreference(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 2 || !arguments[0].isString())
return;
string key = arguments[0].toString();
CppVariant value = arguments[1];
WebPreferences* prefs = m_delegate->preferences();
if (key == "WebKitDefaultFontSize")
prefs->defaultFontSize = cppVariantToInt32(value);
else if (key == "WebKitMinimumFontSize")
prefs->minimumFontSize = cppVariantToInt32(value);
else if (key == "WebKitDefaultTextEncodingName")
prefs->defaultTextEncodingName = cppVariantToWebString(value);
else if (key == "WebKitJavaScriptEnabled")
prefs->javaScriptEnabled = cppVariantToBool(value);
else if (key == "WebKitSupportsMultipleWindows")
prefs->supportsMultipleWindows = cppVariantToBool(value);
else if (key == "WebKitDisplayImagesKey")
prefs->loadsImagesAutomatically = cppVariantToBool(value);
else if (key == "WebKitPluginsEnabled")
prefs->pluginsEnabled = cppVariantToBool(value);
else if (key == "WebKitJavaEnabled")
prefs->javaEnabled = cppVariantToBool(value);
else if (key == "WebKitOfflineWebApplicationCacheEnabled")
prefs->offlineWebApplicationCacheEnabled = cppVariantToBool(value);
else if (key == "WebKitTabToLinksPreferenceKey")
prefs->tabsToLinks = cppVariantToBool(value);
else if (key == "WebKitWebGLEnabled")
prefs->experimentalWebGLEnabled = cppVariantToBool(value);
else if (key == "WebKitCSSRegionsEnabled")
prefs->experimentalCSSRegionsEnabled = cppVariantToBool(value);
else if (key == "WebKitCSSGridLayoutEnabled")
prefs->experimentalCSSGridLayoutEnabled = cppVariantToBool(value);
else if (key == "WebKitHyperlinkAuditingEnabled")
prefs->hyperlinkAuditingEnabled = cppVariantToBool(value);
else if (key == "WebKitEnableCaretBrowsing")
prefs->caretBrowsingEnabled = cppVariantToBool(value);
else if (key == "WebKitAllowDisplayingInsecureContent")
prefs->allowDisplayOfInsecureContent = cppVariantToBool(value);
else if (key == "WebKitAllowRunningInsecureContent")
prefs->allowRunningOfInsecureContent = cppVariantToBool(value);
else if (key == "WebKitCSSCustomFilterEnabled")
prefs->cssCustomFilterEnabled = cppVariantToBool(value);
else if (key == "WebKitShouldRespectImageOrientation")
prefs->shouldRespectImageOrientation = cppVariantToBool(value);
else if (key == "WebKitWebAudioEnabled")
BLINK_ASSERT(cppVariantToBool(value));
else {
string message("Invalid name for preference: ");
message.append(key);
printErrorMessage(message);
}
m_delegate->applyPreferences();
}
void TestRunner::setPluginsEnabled(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool()) {
m_delegate->preferences()->pluginsEnabled = arguments[0].toBoolean();
m_delegate->applyPreferences();
}
result->setNull();
}
void TestRunner::showWebInspector(const CppArgumentList&, CppVariant* result)
{
showDevTools();
result->setNull();
}
void TestRunner::closeWebInspector(const CppArgumentList& args, CppVariant* result)
{
m_delegate->closeDevTools();
result->setNull();
}
void TestRunner::isChooserShown(const CppArgumentList&, CppVariant* result)
{
result->set(m_proxy->isChooserShown());
}
void TestRunner::evaluateInWebInspector(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 2 || !arguments[0].isNumber() || !arguments[1].isString())
return;
m_delegate->evaluateInWebInspector(arguments[0].toInt32(), arguments[1].toString());
}
void TestRunner::clearAllDatabases(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
m_delegate->clearAllDatabases();
}
void TestRunner::setDatabaseQuota(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if ((arguments.size() >= 1) && arguments[0].isNumber())
m_delegate->setDatabaseQuota(arguments[0].toInt32());
}
void TestRunner::setAlwaysAcceptCookies(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0)
m_delegate->setAcceptAllCookies(cppVariantToBool(arguments[0]));
result->setNull();
}
void TestRunner::setWindowIsKey(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() > 0 && arguments[0].isBool())
m_delegate->setFocus(m_proxy, arguments[0].value.boolValue);
result->setNull();
}
void TestRunner::pathToLocalResource(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() <= 0 || !arguments[0].isString())
return;
result->set(m_delegate->pathToLocalResource(arguments[0].toString()));
}
void TestRunner::setBackingScaleFactor(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() < 2 || !arguments[0].isNumber() || !arguments[1].isObject())
return;
float value = arguments[0].value.doubleValue;
m_delegate->setDeviceScaleFactor(value);
m_proxy->discardBackingStore();
WebScopedPtr<CppVariant> callbackArguments(new CppVariant());
callbackArguments->set(arguments[1]);
result->setNull();
m_delegate->postTask(new InvokeCallbackTask(this, callbackArguments));
}
void TestRunner::setPOSIXLocale(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() == 1 && arguments[0].isString())
m_delegate->setLocale(arguments[0].toString());
}
void TestRunner::numberOfPendingGeolocationPermissionRequests(const CppArgumentList& arguments, CppVariant* result)
{
result->set(m_proxy->geolocationClientMock()->numberOfPendingPermissionRequests());
}
// FIXME: For greater test flexibility, we should be able to set each page's geolocation mock individually.
// https://bugs.webkit.org/show_bug.cgi?id=52368
void TestRunner::setGeolocationPermission(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 1 || !arguments[0].isBool())
return;
const vector<WebTestProxyBase*>& windowList = m_testInterfaces->windowList();
for (unsigned i = 0; i < windowList.size(); ++i)
windowList.at(i)->geolocationClientMock()->setPermission(arguments[0].toBoolean());
}
void TestRunner::setMockGeolocationPosition(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 3 || !arguments[0].isNumber() || !arguments[1].isNumber() || !arguments[2].isNumber())
return;
const vector<WebTestProxyBase*>& windowList = m_testInterfaces->windowList();
for (unsigned i = 0; i < windowList.size(); ++i)
windowList.at(i)->geolocationClientMock()->setPosition(arguments[0].toDouble(), arguments[1].toDouble(), arguments[2].toDouble());
}
void TestRunner::setMockGeolocationPositionUnavailableError(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 1 || !arguments[0].isString())
return;
const vector<WebTestProxyBase*>& windowList = m_testInterfaces->windowList();
for (unsigned i = 0; i < windowList.size(); ++i)
windowList.at(i)->geolocationClientMock()->setPositionUnavailableError(WebString::fromUTF8(arguments[0].toString()));
}
void TestRunner::setMIDIAccessorResult(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 1 || !arguments[0].isBool())
return;
m_midiAccessorResult = arguments[0].toBoolean();
}
void TestRunner::setMIDISysExPermission(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 1 || !arguments[0].isBool())
return;
const vector<WebTestProxyBase*>& windowList = m_testInterfaces->windowList();
for (unsigned i = 0; i < windowList.size(); ++i)
windowList.at(i)->midiClientMock()->setSysExPermission(arguments[0].toBoolean());
}
void TestRunner::grantWebNotificationPermission(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() != 1 || !arguments[0].isString()) {
result->set(false);
return;
}
m_notificationPresenter->grantPermission(WebString::fromUTF8(arguments[0].toString()));
result->set(true);
}
void TestRunner::simulateLegacyWebNotificationClick(const CppArgumentList& arguments, CppVariant* result)
{
if (arguments.size() != 1 || !arguments[0].isString()) {
result->set(false);
return;
}
result->set(m_notificationPresenter->simulateClick(WebString::fromUTF8(arguments[0].toString())));
}
void TestRunner::cancelAllActiveNotifications(const CppArgumentList& arguments, CppVariant* result)
{
m_notificationPresenter->cancelAllActiveNotifications();
result->set(true);
}
void TestRunner::addMockSpeechInputResult(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 3 || !arguments[0].isString() || !arguments[1].isNumber() || !arguments[2].isString())
return;
#if ENABLE_INPUT_SPEECH
m_proxy->speechInputControllerMock()->addMockRecognitionResult(WebString::fromUTF8(arguments[0].toString()), arguments[1].toDouble(), WebString::fromUTF8(arguments[2].toString()));
#endif
}
void TestRunner::setMockSpeechInputDumpRect(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 1 || !arguments[0].isBool())
return;
#if ENABLE_INPUT_SPEECH
m_proxy->speechInputControllerMock()->setDumpRect(arguments[0].toBoolean());
#endif
}
void TestRunner::addMockSpeechRecognitionResult(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 2 || !arguments[0].isString() || !arguments[1].isNumber())
return;
m_proxy->speechRecognizerMock()->addMockResult(WebString::fromUTF8(arguments[0].toString()), arguments[1].toDouble());
}
void TestRunner::setMockSpeechRecognitionError(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() != 2 || !arguments[0].isString() || !arguments[1].isString())
return;
m_proxy->speechRecognizerMock()->setError(WebString::fromUTF8(arguments[0].toString()), WebString::fromUTF8(arguments[1].toString()));
}
void TestRunner::wasMockSpeechRecognitionAborted(const CppArgumentList&, CppVariant* result)
{
result->set(m_proxy->speechRecognizerMock()->wasAborted());
}
void TestRunner::addWebPageOverlay(const CppArgumentList&, CppVariant* result)
{
if (m_webView && !m_pageOverlay) {
m_pageOverlay = new TestPageOverlay(m_webView);
m_webView->addPageOverlay(m_pageOverlay, 0);
}
result->setNull();
}
void TestRunner::removeWebPageOverlay(const CppArgumentList&, CppVariant* result)
{
if (m_webView && m_pageOverlay) {
m_webView->removePageOverlay(m_pageOverlay);
delete m_pageOverlay;
m_pageOverlay = 0;
}
result->setNull();
}
void TestRunner::display(const CppArgumentList& arguments, CppVariant* result)
{
m_proxy->display();
result->setNull();
}
void TestRunner::displayInvalidatedRegion(const CppArgumentList& arguments, CppVariant* result)
{
m_proxy->displayInvalidatedRegion();
result->setNull();
}
void TestRunner::dumpEditingCallbacks(const CppArgumentList&, CppVariant* result)
{
m_dumpEditingCallbacks = true;
result->setNull();
}
void TestRunner::dumpAsText(const CppArgumentList&, CppVariant* result)
{
m_dumpAsText = true;
m_generatePixelResults = false;
result->setNull();
}
void TestRunner::dumpAsTextWithPixelResults(const CppArgumentList&, CppVariant* result)
{
m_dumpAsText = true;
m_generatePixelResults = true;
result->setNull();
}
void TestRunner::dumpChildFrameScrollPositions(const CppArgumentList&, CppVariant* result)
{
m_dumpChildFrameScrollPositions = true;
result->setNull();
}
void TestRunner::dumpChildFramesAsText(const CppArgumentList&, CppVariant* result)
{
m_dumpChildFramesAsText = true;
result->setNull();
}
void TestRunner::dumpIconChanges(const CppArgumentList&, CppVariant* result)
{
m_dumpIconChanges = true;
result->setNull();
}
void TestRunner::setAudioData(const CppArgumentList& arguments, CppVariant* result)
{
result->setNull();
if (arguments.size() < 1 || !arguments[0].isObject())
return;
// Check that passed-in object is, in fact, an ArrayBufferView.
NPObject* npobject = NPVARIANT_TO_OBJECT(arguments[0]);
if (!npobject)
return;
if (!WebBindings::getArrayBufferView(npobject, &m_audioData))
return;
m_dumpAsAudio = true;
}
void TestRunner::dumpFrameLoadCallbacks(const CppArgumentList&, CppVariant* result)
{
m_dumpFrameLoadCallbacks = true;
result->setNull();
}
void TestRunner::dumpPingLoaderCallbacks(const CppArgumentList&, CppVariant* result)
{
m_dumpPingLoaderCallbacks = true;
result->setNull();
}
void TestRunner::dumpUserGestureInFrameLoadCallbacks(const CppArgumentList&, CppVariant* result)
{
m_dumpUserGestureInFrameLoadCallbacks = true;
result->setNull();
}
void TestRunner::dumpTitleChanges(const CppArgumentList&, CppVariant* result)
{
m_dumpTitleChanges = true;
result->setNull();
}
void TestRunner::dumpCreateView(const CppArgumentList&, CppVariant* result)
{
m_dumpCreateView = true;
result->setNull();
}
void TestRunner::setCanOpenWindows(const CppArgumentList&, CppVariant* result)
{
m_canOpenWindows = true;
result->setNull();
}
void TestRunner::dumpResourceLoadCallbacks(const CppArgumentList&, CppVariant* result)
{
m_dumpResourceLoadCallbacks = true;
result->setNull();
}
void TestRunner::dumpResourceRequestCallbacks(const CppArgumentList&, CppVariant* result)
{
m_dumpResourceRequestCallbacks = true;
result->setNull();
}
void TestRunner::dumpResourceResponseMIMETypes(const CppArgumentList&, CppVariant* result)
{
m_dumpResourceResponseMIMETypes = true;
result->setNull();
}
// Need these conversions because the format of the value for booleans
// may vary - for example, on mac "1" and "0" are used for boolean.
bool TestRunner::cppVariantToBool(const CppVariant& value)
{
if (value.isBool())
return value.toBoolean();
if (value.isNumber())
return value.toInt32();
if (value.isString()) {
string valueString = value.toString();
if (valueString == "true" || valueString == "1")
return true;
if (valueString == "false" || valueString == "0")
return false;
}
printErrorMessage("Invalid value. Expected boolean value.");
return false;
}
int32_t TestRunner::cppVariantToInt32(const CppVariant& value)
{
if (value.isNumber())
return value.toInt32();
if (value.isString()) {
string stringSource = value.toString();
const char* source = stringSource.data();
char* end;
long number = strtol(source, &end, 10);
if (end == source + stringSource.length() && number >= numeric_limits<int32_t>::min() && number <= numeric_limits<int32_t>::max())
return static_cast<int32_t>(number);
}
printErrorMessage("Invalid value for preference. Expected integer value.");
return 0;
}
WebString TestRunner::cppVariantToWebString(const CppVariant& value)
{
if (!value.isString()) {
printErrorMessage("Invalid value for preference. Expected string value.");
return WebString();
}
return WebString::fromUTF8(value.toString());
}
void TestRunner::printErrorMessage(const string& text)
{
m_delegate->printMessage(string("CONSOLE MESSAGE: ") + text + "\n");
}
void TestRunner::fallbackMethod(const CppArgumentList&, CppVariant* result)
{
printErrorMessage("JavaScript ERROR: unknown method called on TestRunner");
result->setNull();
}
void TestRunner::notImplemented(const CppArgumentList&, CppVariant* result)
{
result->setNull();
}
void TestRunner::didAcquirePointerLock(const CppArgumentList&, CppVariant* result)
{
didAcquirePointerLockInternal();
result->setNull();
}
void TestRunner::didNotAcquirePointerLock(const CppArgumentList&, CppVariant* result)
{
didNotAcquirePointerLockInternal();
result->setNull();
}
void TestRunner::didLosePointerLock(const CppArgumentList&, CppVariant* result)
{
didLosePointerLockInternal();
result->setNull();
}
void TestRunner::setPointerLockWillRespondAsynchronously(const CppArgumentList&, CppVariant* result)
{
m_pointerLockPlannedResult = PointerLockWillRespondAsync;
result->setNull();
}
void TestRunner::setPointerLockWillFailSynchronously(const CppArgumentList&, CppVariant* result)
{
m_pointerLockPlannedResult = PointerLockWillFailSync;
result->setNull();
}
}