blob: d53852ec509b1c8603ba75c5b39899b209f9f934 [file] [log] [blame]
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_TEST_RUNNER_WEB_TEST_DELEGATE_H_
#define COMPONENTS_TEST_RUNNER_WEB_TEST_DELEGATE_H_
#include <string>
#include <vector>
#include "base/callback_forward.h"
#include "base/memory/ref_counted.h"
#include "third_party/WebKit/public/platform/WebString.h"
#include "third_party/WebKit/public/platform/WebURL.h"
#include "third_party/WebKit/public/platform/WebVector.h"
#include "third_party/WebKit/public/platform/modules/screen_orientation/WebScreenOrientationType.h"
#define WEBTESTRUNNER_NEW_HISTORY_CAPTURE
namespace blink {
class WebBatteryStatus;
class WebDeviceMotionData;
class WebDeviceOrientationData;
class WebFrame;
class WebGamepad;
class WebGamepads;
class WebHistoryItem;
class WebLayer;
class WebLocalFrame;
class WebMediaStream;
class WebPlugin;
struct WebPluginParams;
struct WebRect;
struct WebSize;
struct WebURLError;
class WebURLResponse;
class WebView;
}
namespace cc {
class TextureLayer;
class TextureLayerClient;
class SharedBitmapManager;
}
namespace test_runner {
class DeviceLightData;
class GamepadController;
class WebTask;
class WebTestProxyBase;
struct TestPreferences;
class WebTestDelegate {
public:
// Set and clear the edit command to execute on the next call to
// WebViewClient::handleCurrentKeyboardEvent().
virtual void ClearEditCommand() = 0;
virtual void SetEditCommand(const std::string& name,
const std::string& value) = 0;
// Sets gamepad provider to be used for tests.
virtual void SetGamepadProvider(GamepadController* controller) = 0;
// Set data to return when registering via
// Platform::setDeviceLightListener().
virtual void SetDeviceLightData(const double data) = 0;
// Set data to return when registering via
// Platform::setDeviceMotionListener().
virtual void SetDeviceMotionData(const blink::WebDeviceMotionData& data) = 0;
// Set data to return when registering via
// Platform::setDeviceOrientationListener().
virtual void SetDeviceOrientationData(
const blink::WebDeviceOrientationData& data) = 0;
// Set orientation to set when registering via
// Platform::setScreenOrientationListener().
virtual void SetScreenOrientation(
const blink::WebScreenOrientationType& orientation) = 0;
// Reset the screen orientation data used for testing.
virtual void ResetScreenOrientation() = 0;
// Notifies blink about a change in battery status.
virtual void DidChangeBatteryStatus(
const blink::WebBatteryStatus& status) = 0;
// Add a message to the text dump for the layout test.
virtual void PrintMessage(const std::string& message) = 0;
// The delegate takes ownership of the WebTask objects and is responsible
// for deleting them.
virtual void PostTask(WebTask* task) = 0;
virtual void PostDelayedTask(WebTask* task, long long ms) = 0;
// Register a new isolated filesystem with the given files, and return the
// new filesystem id.
virtual blink::WebString RegisterIsolatedFileSystem(
const blink::WebVector<blink::WebString>& absolute_filenames) = 0;
// Gets the current time in milliseconds since the UNIX epoch.
virtual long long GetCurrentTimeInMillisecond() = 0;
// Convert the provided relative path into an absolute path.
virtual blink::WebString GetAbsoluteWebStringFromUTF8Path(
const std::string& path) = 0;
// Reads in the given file and returns its contents as data URL.
virtual blink::WebURL LocalFileToDataURL(const blink::WebURL& file_url) = 0;
// Replaces file:///tmp/LayoutTests/ with the actual path to the
// LayoutTests directory.
virtual blink::WebURL RewriteLayoutTestsURL(const std::string& utf8_url) = 0;
// Manages the settings to used for layout tests.
virtual TestPreferences* Preferences() = 0;
virtual void ApplyPreferences() = 0;
// Enables or disables synchronous resize mode. When enabled, all
// window-sizing machinery is
// short-circuited inside the renderer. This mode is necessary for some tests
// that were written
// before browsers had multi-process architecture and rely on window resizes
// to happen synchronously.
// The function has "unfortunate" it its name because we must strive to remove
// all tests
// that rely on this... well, unfortunate behavior. See
// http://crbug.com/309760 for the plan.
virtual void UseUnfortunateSynchronousResizeMode(bool enable) = 0;
// Controls auto resize mode.
virtual void EnableAutoResizeMode(const blink::WebSize& min_size,
const blink::WebSize& max_size) = 0;
virtual void DisableAutoResizeMode(const blink::WebSize& new_size) = 0;
// Clears DevTools' localStorage when an inspector test is started.
virtual void ClearDevToolsLocalStorage() = 0;
// Opens and closes the inspector.
virtual void ShowDevTools(const std::string& settings,
const std::string& frontend_url) = 0;
virtual void CloseDevTools() = 0;
// Evaluate the given script in the DevTools agent.
virtual void EvaluateInWebInspector(long call_id,
const std::string& script) = 0;
// Controls WebSQL databases.
virtual void ClearAllDatabases() = 0;
virtual void SetDatabaseQuota(int quota) = 0;
// Controls Web Notifications.
virtual void SimulateWebNotificationClick(const std::string& title,
int action_index) = 0;
// Controls the device scale factor of the main WebView for hidpi tests.
virtual void SetDeviceScaleFactor(float factor) = 0;
// Change the device color profile while running a layout test.
virtual void SetDeviceColorProfile(const std::string& name) = 0;
// Change the bluetooth test data while running a layout test.
virtual void SetBluetoothMockDataSet(const std::string& data_set) = 0;
// Makes the Bluetooth chooser record its input and wait for instructions from
// the test program on how to proceed.
virtual void SetBluetoothManualChooser() = 0;
// Returns the events recorded since the last call to this function.
virtual void GetBluetoothManualChooserEvents(
const base::Callback<void(const std::vector<std::string>& events)>&
callback) = 0;
// Calls the BluetoothChooser::EventHandler with the arguments here. Valid
// event strings are:
// * "cancel" - simulates the user canceling the chooser.
// * "select" - simulates the user selecting a device whose device ID is in
// |argument|.
virtual void SendBluetoothManualChooserEvent(const std::string& event,
const std::string& argument) = 0;
// Enables mock geofencing service while running a layout test.
// |service_available| indicates if the mock service should mock geofencing
// being available or not.
virtual void SetGeofencingMockProvider(bool service_available) = 0;
// Disables mock geofencing service while running a layout test.
virtual void ClearGeofencingMockProvider() = 0;
// Set the mock geofencing position while running a layout test.
virtual void SetGeofencingMockPosition(double latitude, double longitude) = 0;
// Controls which WebView should be focused.
virtual void SetFocus(WebTestProxyBase* proxy, bool focus) = 0;
// Controls whether all cookies should be accepted or writing cookies in a
// third-party context is blocked.
virtual void SetAcceptAllCookies(bool accept) = 0;
// The same as RewriteLayoutTestsURL unless the resource is a path starting
// with /tmp/, then return a file URL to a temporary file.
virtual std::string PathToLocalResource(const std::string& resource) = 0;
// Sets the POSIX locale of the current process.
virtual void SetLocale(const std::string& locale) = 0;
// Invoked when the test finished.
virtual void TestFinished() = 0;
// Invoked when the embedder should close all but the main WebView.
virtual void CloseRemainingWindows() = 0;
virtual void DeleteAllCookies() = 0;
// Returns the length of the back/forward history of the main WebView.
virtual int NavigationEntryCount() = 0;
// The following trigger navigations on the main WebViwe.
virtual void GoToOffset(int offset) = 0;
virtual void Reload() = 0;
virtual void LoadURLForFrame(const blink::WebURL& url,
const std::string& frame_name) = 0;
// Returns true if resource requests to external URLs should be permitted.
virtual bool AllowExternalPages() = 0;
// Returns a text dump the back/forward history for the WebView associated
// with the given WebTestProxyBase.
virtual std::string DumpHistoryForWindow(WebTestProxyBase* proxy) = 0;
// Fetch the manifest for a given WebView from the given url.
virtual void FetchManifest(
blink::WebView* view,
const GURL& url,
const base::Callback<void(const blink::WebURLResponse& response,
const std::string& data)>& callback) = 0;
// Sends a message to the LayoutTestPermissionManager in order for it to
// update its database.
virtual void SetPermission(const std::string& permission_name,
const std::string& permission_value,
const GURL& origin,
const GURL& embedding_origin) = 0;
// Clear all the permissions set via SetPermission().
virtual void ResetPermissions() = 0;
// Add content MediaStream classes to the Blink MediaStream ones.
virtual bool AddMediaStreamSourceAndTrack(blink::WebMediaStream* stream) = 0;
virtual cc::SharedBitmapManager* GetSharedBitmapManager() = 0;
// Causes the beforeinstallprompt event to be sent to the renderer with a
// request id of |request_id|. |event_platforms| are the platforms to be sent
// with the event. Once the event listener completes, |callback| will be
// called with a boolean argument. This argument will be true if the event is
// canceled, and false otherwise.
virtual void DispatchBeforeInstallPromptEvent(
int request_id,
const std::vector<std::string>& event_platforms,
const base::Callback<void(bool)>& callback) = 0;
// Resolve the promise associated with the beforeinstallprompt even with
// request id |request_id|. The promise is resolved with a result.platform set
// to |platform|. If |platform| is not empty, result.outcome will be
// 'accepted', otherwise it will be 'dismissed'.
virtual void ResolveBeforeInstallPromptPromise(
int request_id,
const std::string& platform) = 0;
virtual blink::WebPlugin* CreatePluginPlaceholder(
blink::WebLocalFrame* frame,
const blink::WebPluginParams& params) = 0;
virtual void OnWebTestProxyBaseDestroy(WebTestProxyBase* proxy) = 0;
};
} // namespace test_runner
#endif // COMPONENTS_TEST_RUNNER_WEB_TEST_DELEGATE_H_