/* * Copyright (C) 2007 Apple Inc. All rights reserved. * Copyright (C) 2007 Eric Seidel * Copyright (C) 2008 Nuanti Ltd. * Copyright (C) 2009 Jan Michael Alonzo * Copyright (C) 2009,2011 Collabora Ltd. * Copyright (C) 2010 Joone Hur * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. 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. * 3. Neither the name of Apple Computer, Inc. ("Apple") 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 APPLE AND ITS 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 APPLE OR ITS 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 "config.h" #include "LayoutTestController.h" #include "DumpRenderTree.h" #include "WebCoreSupport/DumpRenderTreeSupportGtk.h" #include "WorkQueue.h" #include "WorkQueueItem.h" #include #include #include #include #include #include #include #include #include #include extern "C" { void webkit_web_inspector_execute_script(WebKitWebInspector* inspector, long callId, const gchar* script); } LayoutTestController::~LayoutTestController() { // FIXME: implement } void LayoutTestController::addDisallowedURL(JSStringRef url) { // FIXME: implement } void LayoutTestController::clearBackForwardList() { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); WebKitWebBackForwardList* list = webkit_web_view_get_back_forward_list(webView); WebKitWebHistoryItem* item = webkit_web_back_forward_list_get_current_item(list); g_object_ref(item); // We clear the history by setting the back/forward list's capacity to 0 // then restoring it back and adding back the current item. gint limit = webkit_web_back_forward_list_get_limit(list); webkit_web_back_forward_list_set_limit(list, 0); webkit_web_back_forward_list_set_limit(list, limit); webkit_web_back_forward_list_add_item(list, item); webkit_web_back_forward_list_go_to_item(list, item); g_object_unref(item); } JSStringRef LayoutTestController::copyDecodedHostName(JSStringRef name) { // FIXME: implement return 0; } JSStringRef LayoutTestController::copyEncodedHostName(JSStringRef name) { // FIXME: implement return 0; } void LayoutTestController::dispatchPendingLoadRequests() { // FIXME: Implement for testing fix for 6727495 } void LayoutTestController::display() { displayWebView(); } void LayoutTestController::keepWebHistory() { // FIXME: implement } JSValueRef LayoutTestController::computedStyleIncludingVisitedInfo(JSContextRef context, JSValueRef value) { return DumpRenderTreeSupportGtk::computedStyleIncludingVisitedInfo(context, value); } JSRetainPtr LayoutTestController::layerTreeAsText() const { // FIXME: implement JSRetainPtr string(Adopt, JSStringCreateWithUTF8CString("")); return string; } int LayoutTestController::pageNumberForElementById(JSStringRef id, float pageWidth, float pageHeight) { gchar* idGChar = JSStringCopyUTF8CString(id); int pageNumber = DumpRenderTreeSupportGtk::pageNumberForElementById(mainFrame, idGChar, pageWidth, pageHeight); g_free(idGChar); return pageNumber; } int LayoutTestController::numberOfPages(float pageWidth, float pageHeight) { return DumpRenderTreeSupportGtk::numberOfPagesForFrame(mainFrame, pageWidth, pageHeight); } JSRetainPtr LayoutTestController::pageProperty(const char* propertyName, int pageNumber) const { JSRetainPtr propertyValue(Adopt, JSStringCreateWithUTF8CString(DumpRenderTreeSupportGtk::pageProperty(mainFrame, propertyName, pageNumber).data())); return propertyValue; } JSRetainPtr LayoutTestController::pageSizeAndMarginsInPixels(int pageNumber, int width, int height, int marginTop, int marginRight, int marginBottom, int marginLeft) const { JSRetainPtr propertyValue(Adopt, JSStringCreateWithUTF8CString(DumpRenderTreeSupportGtk::pageSizeAndMarginsInPixels(mainFrame, pageNumber, width, height, marginTop, marginRight, marginBottom, marginLeft).data())); return propertyValue; } size_t LayoutTestController::webHistoryItemCount() { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); WebKitWebBackForwardList* list = webkit_web_view_get_back_forward_list(webView); if (!list) return -1; // We do not add the current page to the total count as it's not // considered in DRT tests return webkit_web_back_forward_list_get_back_length(list) + webkit_web_back_forward_list_get_forward_length(list); } unsigned LayoutTestController::workerThreadCount() const { return DumpRenderTreeSupportGtk::workerThreadCount(); } JSRetainPtr LayoutTestController::platformName() const { JSRetainPtr platformName(Adopt, JSStringCreateWithUTF8CString("gtk")); return platformName; } void LayoutTestController::notifyDone() { if (m_waitToDump && !topLoadingFrame && !WorkQueue::shared()->count()) dump(); m_waitToDump = false; waitForPolicy = false; } JSStringRef LayoutTestController::pathToLocalResource(JSContextRef context, JSStringRef url) { GOwnPtr urlCString(JSStringCopyUTF8CString(url)); if (!g_str_has_prefix(urlCString.get(), "file:///tmp/LayoutTests/")) return JSStringRetain(url); const char* layoutTestsSuffix = urlCString.get() + strlen("file:///tmp/"); GOwnPtr testPath(g_build_filename(getTopLevelPath().data(), layoutTestsSuffix, NULL)); GOwnPtr testURI(g_filename_to_uri(testPath.get(), 0, 0)); return JSStringCreateWithUTF8CString(testURI.get()); } void LayoutTestController::queueLoad(JSStringRef url, JSStringRef target) { gchar* relativeURL = JSStringCopyUTF8CString(url); SoupURI* baseURI = soup_uri_new(webkit_web_frame_get_uri(mainFrame)); SoupURI* absoluteURI = soup_uri_new_with_base(baseURI, relativeURL); soup_uri_free(baseURI); g_free(relativeURL); gchar* absoluteCString; if (absoluteURI) { absoluteCString = soup_uri_to_string(absoluteURI, FALSE); soup_uri_free(absoluteURI); } else absoluteCString = JSStringCopyUTF8CString(url); JSRetainPtr absoluteURL(Adopt, JSStringCreateWithUTF8CString(absoluteCString)); g_free(absoluteCString); WorkQueue::shared()->queue(new LoadItem(absoluteURL.get(), target)); } void LayoutTestController::setAcceptsEditing(bool acceptsEditing) { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); webkit_web_view_set_editable(webView, acceptsEditing); } void LayoutTestController::setAlwaysAcceptCookies(bool alwaysAcceptCookies) { SoupSession* session = webkit_get_default_session(); SoupCookieJar* jar = reinterpret_cast(soup_session_get_feature(session, SOUP_TYPE_COOKIE_JAR)); /* If the jar was not created - we create it on demand, i.e, just in case we have HTTP requests - then we must create it here in order to set the proper accept policy */ if (!jar) { jar = soup_cookie_jar_new(); soup_session_add_feature(session, SOUP_SESSION_FEATURE(jar)); g_object_unref(jar); } SoupCookieJarAcceptPolicy policy; if (alwaysAcceptCookies) policy = SOUP_COOKIE_JAR_ACCEPT_ALWAYS; else policy = SOUP_COOKIE_JAR_ACCEPT_NO_THIRD_PARTY; g_object_set(G_OBJECT(jar), SOUP_COOKIE_JAR_ACCEPT_POLICY, policy, NULL); } void LayoutTestController::setCustomPolicyDelegate(bool setDelegate, bool permissive) { // FIXME: implement } void LayoutTestController::waitForPolicyDelegate() { waitForPolicy = true; setWaitToDump(true); } void LayoutTestController::setScrollbarPolicy(JSStringRef orientation, JSStringRef policy) { // FIXME: implement } void LayoutTestController::addOriginAccessWhitelistEntry(JSStringRef sourceOrigin, JSStringRef protocol, JSStringRef host, bool includeSubdomains) { gchar* sourceOriginGChar = JSStringCopyUTF8CString(sourceOrigin); gchar* protocolGChar = JSStringCopyUTF8CString(protocol); gchar* hostGChar = JSStringCopyUTF8CString(host); DumpRenderTreeSupportGtk::whiteListAccessFromOrigin(sourceOriginGChar, protocolGChar, hostGChar, includeSubdomains); g_free(sourceOriginGChar); g_free(protocolGChar); g_free(hostGChar); } void LayoutTestController::removeOriginAccessWhitelistEntry(JSStringRef sourceOrigin, JSStringRef protocol, JSStringRef host, bool includeSubdomains) { GOwnPtr sourceOriginGChar(JSStringCopyUTF8CString(sourceOrigin)); GOwnPtr protocolGChar(JSStringCopyUTF8CString(protocol)); GOwnPtr hostGChar(JSStringCopyUTF8CString(host)); DumpRenderTreeSupportGtk::removeWhiteListAccessFromOrigin(sourceOriginGChar.get(), protocolGChar.get(), hostGChar.get(), includeSubdomains); } void LayoutTestController::setMainFrameIsFirstResponder(bool flag) { // FIXME: implement } void LayoutTestController::setTabKeyCyclesThroughElements(bool cycles) { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); WebKitWebSettings* settings = webkit_web_view_get_settings(webView); g_object_set(G_OBJECT(settings), "tab-key-cycles-through-elements", cycles, NULL); } void LayoutTestController::setUseDashboardCompatibilityMode(bool flag) { // FIXME: implement } static gchar* userStyleSheet = NULL; static gboolean userStyleSheetEnabled = TRUE; void LayoutTestController::setUserStyleSheetEnabled(bool flag) { userStyleSheetEnabled = flag; WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); WebKitWebSettings* settings = webkit_web_view_get_settings(webView); if (flag && userStyleSheet) g_object_set(G_OBJECT(settings), "user-stylesheet-uri", userStyleSheet, NULL); else g_object_set(G_OBJECT(settings), "user-stylesheet-uri", "", NULL); } void LayoutTestController::setUserStyleSheetLocation(JSStringRef path) { g_free(userStyleSheet); userStyleSheet = JSStringCopyUTF8CString(path); if (userStyleSheetEnabled) setUserStyleSheetEnabled(true); } void LayoutTestController::setValueForUser(JSContextRef context, JSValueRef nodeObject, JSStringRef value) { DumpRenderTreeSupportGtk::setValueForUser(context, nodeObject, value); } void LayoutTestController::setViewModeMediaFeature(JSStringRef mode) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); char* viewMode = JSStringCopyUTF8CString(mode); if (!g_strcmp0(viewMode, "windowed")) webkit_web_view_set_view_mode(view, WEBKIT_WEB_VIEW_VIEW_MODE_WINDOWED); else if (!g_strcmp0(viewMode, "floating")) webkit_web_view_set_view_mode(view, WEBKIT_WEB_VIEW_VIEW_MODE_FLOATING); else if (!g_strcmp0(viewMode, "fullscreen")) webkit_web_view_set_view_mode(view, WEBKIT_WEB_VIEW_VIEW_MODE_FULLSCREEN); else if (!g_strcmp0(viewMode, "maximized")) webkit_web_view_set_view_mode(view, WEBKIT_WEB_VIEW_VIEW_MODE_MAXIMIZED); else if (!g_strcmp0(viewMode, "minimized")) webkit_web_view_set_view_mode(view, WEBKIT_WEB_VIEW_VIEW_MODE_MINIMIZED); g_free(viewMode); } void LayoutTestController::setWindowIsKey(bool windowIsKey) { // FIXME: implement } void LayoutTestController::setSmartInsertDeleteEnabled(bool flag) { DumpRenderTreeSupportGtk::setSmartInsertDeleteEnabled(webkit_web_frame_get_web_view(mainFrame), flag); } static gboolean waitToDumpWatchdogFired(void*) { setWaitToDumpWatchdog(0); gLayoutTestController->waitToDumpWatchdogTimerFired(); return FALSE; } void LayoutTestController::setWaitToDump(bool waitUntilDone) { static const int timeoutSeconds = 30; m_waitToDump = waitUntilDone; if (m_waitToDump && shouldSetWaitToDumpWatchdog()) setWaitToDumpWatchdog(g_timeout_add_seconds(timeoutSeconds, waitToDumpWatchdogFired, 0)); } int LayoutTestController::windowCount() { // +1 -> including the main view return g_slist_length(webViewList) + 1; } void LayoutTestController::setPrivateBrowsingEnabled(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "enable-private-browsing", flag, NULL); } void LayoutTestController::setJavaScriptCanAccessClipboard(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "javascript-can-access-clipboard", flag, NULL); } void LayoutTestController::setXSSAuditorEnabled(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "enable-xss-auditor", flag, NULL); } void LayoutTestController::setFrameFlatteningEnabled(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "enable-frame-flattening", flag, NULL); } void LayoutTestController::setSpatialNavigationEnabled(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "enable-spatial-navigation", flag, NULL); } void LayoutTestController::setAllowUniversalAccessFromFileURLs(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "enable-universal-access-from-file-uris", flag, NULL); } void LayoutTestController::setAllowFileAccessFromFileURLs(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "enable-file-access-from-file-uris", flag, NULL); } void LayoutTestController::setAuthorAndUserStylesEnabled(bool flag) { // FIXME: implement } void LayoutTestController::setAutofilled(JSContextRef context, JSValueRef nodeObject, bool isAutofilled) { DumpRenderTreeSupportGtk::setAutofilled(context, nodeObject, isAutofilled); } void LayoutTestController::disableImageLoading() { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "auto-load-images", FALSE, NULL); } void LayoutTestController::setMockDeviceOrientation(bool canProvideAlpha, double alpha, bool canProvideBeta, double beta, bool canProvideGamma, double gamma) { // FIXME: Implement for DeviceOrientation layout tests. // See https://bugs.webkit.org/show_bug.cgi?id=30335. } void LayoutTestController::setMockGeolocationPosition(double latitude, double longitude, double accuracy) { WebKitWebView* view = WEBKIT_WEB_VIEW(g_slist_nth_data(webViewList, 0)); if (!view) view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); DumpRenderTreeSupportGtk::setMockGeolocationPosition(view, latitude, longitude, accuracy); } void LayoutTestController::setMockGeolocationError(int code, JSStringRef message) { WebKitWebView* view = WEBKIT_WEB_VIEW(g_slist_nth_data(webViewList, 0)); if (!view) view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); GOwnPtr cMessage(JSStringCopyUTF8CString(message)); DumpRenderTreeSupportGtk::setMockGeolocationError(view, code, cMessage.get()); } void LayoutTestController::setGeolocationPermission(bool allow) { setGeolocationPermissionCommon(allow); WebKitWebView* view = WEBKIT_WEB_VIEW(g_slist_nth_data(webViewList, 0)); if (!view) view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); DumpRenderTreeSupportGtk::setMockGeolocationPermission(view, allow); } int LayoutTestController::numberOfPendingGeolocationPermissionRequests() { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); if (!view) view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); return DumpRenderTreeSupportGtk::numberOfPendingGeolocationPermissionRequests(view); } void LayoutTestController::addMockSpeechInputResult(JSStringRef result, double confidence, JSStringRef language) { // FIXME: Implement for speech input layout tests. // See https://bugs.webkit.org/show_bug.cgi?id=39485. } void LayoutTestController::setMockSpeechInputDumpRect(bool flag) { // FIXME: Implement for speech input layout tests. // See https://bugs.webkit.org/show_bug.cgi?id=39485. } void LayoutTestController::startSpeechInput(JSContextRef inputElement) { // FIXME: Implement for speech input layout tests. // See https://bugs.webkit.org/show_bug.cgi?id=39485. } void LayoutTestController::setIconDatabaseEnabled(bool enabled) { WebKitIconDatabase* database = webkit_get_icon_database(); if (enabled) { GOwnPtr iconDatabasePath(g_build_filename(g_get_tmp_dir(), "DumpRenderTree", "icondatabase", NULL)); webkit_icon_database_set_path(database, iconDatabasePath.get()); } else webkit_icon_database_set_path(database, 0); } void LayoutTestController::setSelectTrailingWhitespaceEnabled(bool flag) { DumpRenderTreeSupportGtk::setSelectTrailingWhitespaceEnabled(flag); } void LayoutTestController::setPopupBlockingEnabled(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "javascript-can-open-windows-automatically", !flag, NULL); } void LayoutTestController::setPluginsEnabled(bool flag) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); WebKitWebSettings* settings = webkit_web_view_get_settings(view); g_object_set(G_OBJECT(settings), "enable-plugins", flag, NULL); } bool LayoutTestController::elementDoesAutoCompleteForElementWithId(JSStringRef id) { return DumpRenderTreeSupportGtk::elementDoesAutoCompleteForElementWithId(mainFrame, id); } void LayoutTestController::execCommand(JSStringRef name, JSStringRef value) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); gchar* cName = JSStringCopyUTF8CString(name); gchar* cValue = JSStringCopyUTF8CString(value); DumpRenderTreeSupportGtk::executeCoreCommandByName(view, cName, cValue); g_free(cName); g_free(cValue); } bool LayoutTestController::findString(JSContextRef context, JSStringRef target, JSObjectRef optionsArray) { WebKitFindOptions findOptions = 0; WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); ASSERT(webView); JSRetainPtr lengthPropertyName(Adopt, JSStringCreateWithUTF8CString("length")); JSValueRef lengthValue = JSObjectGetProperty(context, optionsArray, lengthPropertyName.get(), 0); if (!JSValueIsNumber(context, lengthValue)) return false; GOwnPtr targetString(JSStringCopyUTF8CString(target)); size_t length = static_cast(JSValueToNumber(context, lengthValue, 0)); for (size_t i = 0; i < length; ++i) { JSValueRef value = JSObjectGetPropertyAtIndex(context, optionsArray, i, 0); if (!JSValueIsString(context, value)) continue; JSRetainPtr optionName(Adopt, JSValueToStringCopy(context, value, 0)); if (JSStringIsEqualToUTF8CString(optionName.get(), "CaseInsensitive")) findOptions |= WebKit::WebFindOptionsCaseInsensitive; else if (JSStringIsEqualToUTF8CString(optionName.get(), "AtWordStarts")) findOptions |= WebKit::WebFindOptionsAtWordStarts; else if (JSStringIsEqualToUTF8CString(optionName.get(), "TreatMedialCapitalAsWordStart")) findOptions |= WebKit::WebFindOptionsTreatMedialCapitalAsWordStart; else if (JSStringIsEqualToUTF8CString(optionName.get(), "Backwards")) findOptions |= WebKit::WebFindOptionsBackwards; else if (JSStringIsEqualToUTF8CString(optionName.get(), "WrapAround")) findOptions |= WebKit::WebFindOptionsWrapAround; else if (JSStringIsEqualToUTF8CString(optionName.get(), "StartInSelection")) findOptions |= WebKit::WebFindOptionsStartInSelection; } return DumpRenderTreeSupportGtk::findString(webView, targetString.get(), findOptions); } bool LayoutTestController::isCommandEnabled(JSStringRef name) { WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); gchar* cName = JSStringCopyUTF8CString(name); bool result = DumpRenderTreeSupportGtk::isCommandEnabled(view, cName); g_free(cName); return result; } void LayoutTestController::setCacheModel(int cacheModel) { // These constants are derived from the Mac cache model enum in Source/WebKit/mac/WebView/WebPreferences.h. switch (cacheModel) { case 0: webkit_set_cache_model(WEBKIT_CACHE_MODEL_DOCUMENT_VIEWER); break; case 1: webkit_set_cache_model(WEBKIT_CACHE_MODEL_DOCUMENT_BROWSER); break; case 2: webkit_set_cache_model(WEBKIT_CACHE_MODEL_WEB_BROWSER); break; default: ASSERT_NOT_REACHED(); } } void LayoutTestController::setPersistentUserStyleSheetLocation(JSStringRef jsURL) { // FIXME: implement } void LayoutTestController::clearPersistentUserStyleSheet() { // FIXME: implement } void LayoutTestController::clearAllApplicationCaches() { // FIXME: Implement to support application cache quotas. } void LayoutTestController::setApplicationCacheOriginQuota(unsigned long long quota) { // FIXME: Implement to support application cache quotas. } void LayoutTestController::clearApplicationCacheForOrigin(OpaqueJSString*) { // FIXME: Implement to support deleting all application caches for an origin. } long long LayoutTestController::localStorageDiskUsageForOrigin(JSStringRef originIdentifier) { // FIXME: Implement to support getting disk usage in bytes for an origin. return 0; } JSValueRef LayoutTestController::originsWithApplicationCache(JSContextRef context) { // FIXME: Implement to get origins that contain application caches. return JSValueMakeUndefined(context); } long long LayoutTestController::applicationCacheDiskUsageForOrigin(JSStringRef name) { // FIXME: implement return 0; } void LayoutTestController::clearAllDatabases() { webkit_remove_all_web_databases(); } void LayoutTestController::setDatabaseQuota(unsigned long long quota) { WebKitSecurityOrigin* origin = webkit_web_frame_get_security_origin(mainFrame); webkit_security_origin_set_web_database_quota(origin, quota); } JSValueRef LayoutTestController::originsWithLocalStorage(JSContextRef context) { // FIXME: implement return JSValueMakeUndefined(context); } void LayoutTestController::deleteAllLocalStorage() { // FIXME: implement } void LayoutTestController::deleteLocalStorageForOrigin(JSStringRef originIdentifier) { // FIXME: implement } void LayoutTestController::observeStorageTrackerNotifications(unsigned number) { // FIXME: implement } void LayoutTestController::syncLocalStorage() { // FIXME: implement } void LayoutTestController::setDomainRelaxationForbiddenForURLScheme(bool forbidden, JSStringRef scheme) { GOwnPtr urlScheme(JSStringCopyUTF8CString(scheme)); DumpRenderTreeSupportGtk::setDomainRelaxationForbiddenForURLScheme(forbidden, urlScheme.get()); } void LayoutTestController::goBack() { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); webkit_web_view_go_back(webView); } void LayoutTestController::setDefersLoading(bool defers) { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); DumpRenderTreeSupportGtk::setDefersLoading(webView, defers); } void LayoutTestController::setAppCacheMaximumSize(unsigned long long size) { webkit_application_cache_set_maximum_size(size); } bool LayoutTestController::pauseAnimationAtTimeOnElementWithId(JSStringRef animationName, double time, JSStringRef elementId) { gchar* name = JSStringCopyUTF8CString(animationName); gchar* element = JSStringCopyUTF8CString(elementId); bool returnValue = DumpRenderTreeSupportGtk::pauseAnimation(mainFrame, name, time, element); g_free(name); g_free(element); return returnValue; } bool LayoutTestController::pauseTransitionAtTimeOnElementWithId(JSStringRef propertyName, double time, JSStringRef elementId) { gchar* name = JSStringCopyUTF8CString(propertyName); gchar* element = JSStringCopyUTF8CString(elementId); bool returnValue = DumpRenderTreeSupportGtk::pauseTransition(mainFrame, name, time, element); g_free(name); g_free(element); return returnValue; } unsigned LayoutTestController::numberOfActiveAnimations() const { return DumpRenderTreeSupportGtk::numberOfActiveAnimations(mainFrame); } static gboolean booleanFromValue(gchar* value) { return !g_ascii_strcasecmp(value, "true") || !g_ascii_strcasecmp(value, "1"); } void LayoutTestController::overridePreference(JSStringRef key, JSStringRef value) { GOwnPtr originalName(JSStringCopyUTF8CString(key)); GOwnPtr valueAsString(JSStringCopyUTF8CString(value)); WebKitWebView* view = webkit_web_frame_get_web_view(mainFrame); ASSERT(view); // This transformation could be handled by a hash table (and it once was), but // having it prominent, makes it easier for people from other ports to keep the // list up to date. const gchar* propertyName = 0; if (g_str_equal(originalName.get(), "WebKitJavaScriptEnabled")) propertyName = "enable-scripts"; else if (g_str_equal(originalName.get(), "WebKitDefaultFontSize")) propertyName = "default-font-size"; else if (g_str_equal(originalName.get(), "WebKitEnableCaretBrowsing")) propertyName = "enable-caret-browsing"; else if (g_str_equal(originalName.get(), "WebKitUsesPageCachePreferenceKey")) propertyName = "enable-page-cache"; else if (g_str_equal(originalName.get(), "WebKitPluginsEnabled")) propertyName = "enable-plugins"; else if (g_str_equal(originalName.get(), "WebKitHyperlinkAuditingEnabled")) propertyName = "enable-hyperlink-auditing"; else if (g_str_equal(originalName.get(), "WebKitWebGLEnabled")) propertyName = "enable-webgl"; else if (g_str_equal(originalName.get(), "WebKitWebAudioEnabled")) propertyName = "enable-webaudio"; else if (g_str_equal(originalName.get(), "WebKitTabToLinksPreferenceKey")) { DumpRenderTreeSupportGtk::setLinksIncludedInFocusChain(booleanFromValue(valueAsString.get())); return; } else if (g_str_equal(originalName.get(), "WebKitPageCacheSupportsPluginsPreferenceKey")) { DumpRenderTreeSupportGtk::setPageCacheSupportsPlugins(webkit_web_frame_get_web_view(mainFrame), booleanFromValue(valueAsString.get())); return; } else if (g_str_equal(originalName.get(), "WebKitCSSGridLayoutEnabled")) { DumpRenderTreeSupportGtk::setCSSGridLayoutEnabled(webkit_web_frame_get_web_view(mainFrame), booleanFromValue(valueAsString.get())); return; } else if (g_str_equal(originalName.get(), "WebKitCSSRegionsEnabled")) { DumpRenderTreeSupportGtk::setCSSRegionsEnabled(webkit_web_frame_get_web_view(mainFrame), booleanFromValue(valueAsString.get())); return; } else { fprintf(stderr, "LayoutTestController::overridePreference tried to override " "unknown preference '%s'.\n", originalName.get()); return; } WebKitWebSettings* settings = webkit_web_view_get_settings(view); GParamSpec* pspec = g_object_class_find_property(G_OBJECT_CLASS( WEBKIT_WEB_SETTINGS_GET_CLASS(settings)), propertyName); GValue currentPropertyValue = { 0, { { 0 } } }; g_value_init(¤tPropertyValue, pspec->value_type); if (G_VALUE_HOLDS_STRING(¤tPropertyValue)) g_object_set(settings, propertyName, valueAsString.get(), NULL); else if (G_VALUE_HOLDS_BOOLEAN(¤tPropertyValue)) g_object_set(G_OBJECT(settings), propertyName, booleanFromValue(valueAsString.get()), NULL); else if (G_VALUE_HOLDS_INT(¤tPropertyValue)) g_object_set(G_OBJECT(settings), propertyName, atoi(valueAsString.get()), NULL); else if (G_VALUE_HOLDS_FLOAT(¤tPropertyValue)) { gfloat newValue = g_ascii_strtod(valueAsString.get(), 0); g_object_set(G_OBJECT(settings), propertyName, newValue, NULL); } else fprintf(stderr, "LayoutTestController::overridePreference failed to override " "preference '%s'.\n", originalName.get()); } void LayoutTestController::addUserScript(JSStringRef source, bool runAtStart, bool allFrames) { printf("LayoutTestController::addUserScript not implemented.\n"); } void LayoutTestController::addUserStyleSheet(JSStringRef source, bool allFrames) { GOwnPtr sourceCode(JSStringCopyUTF8CString(source)); DumpRenderTreeSupportGtk::addUserStyleSheet(mainFrame, sourceCode.get(), allFrames); // FIXME: needs more investigation why userscripts/user-style-top-frame-only.html fails when allFrames is false. } void LayoutTestController::setDeveloperExtrasEnabled(bool enabled) { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); WebKitWebSettings* webSettings = webkit_web_view_get_settings(webView); g_object_set(webSettings, "enable-developer-extras", enabled, NULL); } void LayoutTestController::setAsynchronousSpellCheckingEnabled(bool) { // FIXME: Implement this. } void LayoutTestController::showWebInspector() { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); WebKitWebInspector* inspector = webkit_web_view_get_inspector(webView); webkit_web_inspector_show(inspector); } void LayoutTestController::closeWebInspector() { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); WebKitWebInspector* inspector = webkit_web_view_get_inspector(webView); webkit_web_inspector_close(inspector); } void LayoutTestController::evaluateInWebInspector(long callId, JSStringRef script) { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); WebKitWebInspector* inspector = webkit_web_view_get_inspector(webView); char* scriptString = JSStringCopyUTF8CString(script); webkit_web_inspector_execute_script(inspector, callId, scriptString); g_free(scriptString); } void LayoutTestController::evaluateScriptInIsolatedWorldAndReturnValue(unsigned worldID, JSObjectRef globalObject, JSStringRef script) { // FIXME: Implement this. } void LayoutTestController::evaluateScriptInIsolatedWorld(unsigned worldID, JSObjectRef globalObject, JSStringRef script) { // FIXME: Implement this. } void LayoutTestController::removeAllVisitedLinks() { // FIXME: Implement this. } bool LayoutTestController::callShouldCloseOnWebView() { return DumpRenderTreeSupportGtk::shouldClose(mainFrame); } void LayoutTestController::apiTestNewWindowDataLoadBaseURL(JSStringRef utf8Data, JSStringRef baseURL) { } void LayoutTestController::apiTestGoToCurrentBackForwardItem() { } void LayoutTestController::setWebViewEditable(bool) { } JSRetainPtr LayoutTestController::markerTextForListItem(JSContextRef context, JSValueRef nodeObject) const { CString markerTextGChar = DumpRenderTreeSupportGtk::markerTextForListItem(mainFrame, context, nodeObject); if (markerTextGChar.isNull()) return 0; JSRetainPtr markerText(Adopt, JSStringCreateWithUTF8CString(markerTextGChar.data())); return markerText; } void LayoutTestController::authenticateSession(JSStringRef, JSStringRef, JSStringRef) { } void LayoutTestController::abortModal() { } void LayoutTestController::setSerializeHTTPLoads(bool serialize) { DumpRenderTreeSupportGtk::setSerializeHTTPLoads(serialize); } void LayoutTestController::setMinimumTimerInterval(double minimumTimerInterval) { WebKitWebView* webView = webkit_web_frame_get_web_view(mainFrame); DumpRenderTreeSupportGtk::setMinimumTimerInterval(webView, minimumTimerInterval); } void LayoutTestController::setTextDirection(JSStringRef direction) { // FIXME: Implement. } void LayoutTestController::addChromeInputField() { } void LayoutTestController::removeChromeInputField() { } void LayoutTestController::focusWebView() { } void LayoutTestController::setBackingScaleFactor(double) { } void LayoutTestController::simulateDesktopNotificationClick(JSStringRef title) { } void LayoutTestController::resetPageVisibility() { // FIXME: Implement this. } void LayoutTestController::setPageVisibility(const char*) { // FIXME: Implement this. } void LayoutTestController::setAutomaticLinkDetectionEnabled(bool) { // FIXME: Implement this. } void LayoutTestController::sendWebIntentResponse(JSStringRef) { // FIXME: Implement this. } void LayoutTestController::deliverWebIntent(JSStringRef, JSStringRef, JSStringRef) { // FIXME: Implement this. } void LayoutTestController::setStorageDatabaseIdleInterval(double) { // FIXME: Implement this. }