| Index: content/shell/renderer/test_runner/test_runner.h
|
| diff --git a/content/shell/renderer/test_runner/test_runner.h b/content/shell/renderer/test_runner/test_runner.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..4b010351ee6db3e153f3ee3aec3542f91217228f
|
| --- /dev/null
|
| +++ b/content/shell/renderer/test_runner/test_runner.h
|
| @@ -0,0 +1,704 @@
|
| +// Copyright 2014 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 CONTENT_SHELL_RENDERER_TEST_RUNNER_TEST_RUNNER_H_
|
| +#define CONTENT_SHELL_RENDERER_TEST_RUNNER_TEST_RUNNER_H_
|
| +
|
| +#include <deque>
|
| +#include <set>
|
| +#include <string>
|
| +
|
| +#include "base/memory/scoped_ptr.h"
|
| +#include "base/memory/weak_ptr.h"
|
| +#include "content/shell/renderer/test_runner/WebTask.h"
|
| +#include "content/shell/renderer/test_runner/WebTestRunner.h"
|
| +#include "v8/include/v8.h"
|
| +
|
| +namespace blink {
|
| +class WebFrame;
|
| +class WebNotificationPresenter;
|
| +class WebPermissionClient;
|
| +class WebString;
|
| +class WebView;
|
| +}
|
| +
|
| +namespace gin {
|
| +class ArrayBufferView;
|
| +class Arguments;
|
| +}
|
| +
|
| +namespace WebTestRunner {
|
| +class TestInterfaces;
|
| +class WebPermissions;
|
| +class WebTestDelegate;
|
| +class WebTestProxyBase;
|
| +}
|
| +
|
| +namespace content {
|
| +
|
| +class NotificationPresenter;
|
| +class TestPageOverlay;
|
| +
|
| +class TestRunner : public ::WebTestRunner::WebTestRunner,
|
| + public base::SupportsWeakPtr<TestRunner> {
|
| + public:
|
| + explicit TestRunner(::WebTestRunner::TestInterfaces*);
|
| + virtual ~TestRunner();
|
| +
|
| + void Install(blink::WebFrame* frame);
|
| +
|
| + void SetDelegate(::WebTestRunner::WebTestDelegate*);
|
| + void SetWebView(blink::WebView*, ::WebTestRunner::WebTestProxyBase*);
|
| +
|
| + void Reset();
|
| +
|
| + ::WebTestRunner::WebTaskList* taskList() { return &task_list_; }
|
| +
|
| + void SetTestIsRunning(bool);
|
| + bool TestIsRunning() const { return test_is_running_; }
|
| +
|
| + bool UseMockTheme() const { return use_mock_theme_; }
|
| +
|
| + // WebTestRunner implementation.
|
| + virtual bool shouldGeneratePixelResults() OVERRIDE;
|
| + virtual bool shouldDumpAsAudio() const OVERRIDE;
|
| + virtual void getAudioData(std::vector<unsigned char>* bufferView) const
|
| + OVERRIDE;
|
| + virtual bool shouldDumpBackForwardList() const OVERRIDE;
|
| + virtual blink::WebPermissionClient* webPermissions() const OVERRIDE;
|
| +
|
| + // Methods used by WebTestProxyBase.
|
| + bool shouldDumpSelectionRect() const;
|
| + bool testRepaint() const;
|
| + bool sweepHorizontally() const;
|
| + bool isPrinting() const;
|
| + bool shouldDumpAsText();
|
| + bool shouldDumpAsTextWithPixelResults();
|
| + bool shouldDumpAsMarkup();
|
| + bool shouldDumpChildFrameScrollPositions() const;
|
| + bool shouldDumpChildFramesAsText() const;
|
| + void showDevTools(const std::string& settings);
|
| + void clearDevToolsLocalStorage();
|
| + void setShouldDumpAsText(bool);
|
| + void setShouldDumpAsMarkup(bool);
|
| + void setShouldGeneratePixelResults(bool);
|
| + void setShouldDumpFrameLoadCallbacks(bool);
|
| + void setShouldDumpPingLoaderCallbacks(bool);
|
| + void setShouldEnableViewSource(bool);
|
| + bool shouldDumpEditingCallbacks() const;
|
| + bool shouldDumpFrameLoadCallbacks() const;
|
| + bool shouldDumpPingLoaderCallbacks() const;
|
| + bool shouldDumpUserGestureInFrameLoadCallbacks() const;
|
| + bool shouldDumpTitleChanges() const;
|
| + bool shouldDumpIconChanges() const;
|
| + bool shouldDumpCreateView() const;
|
| + bool canOpenWindows() const;
|
| + bool shouldDumpResourceLoadCallbacks() const;
|
| + bool shouldDumpResourceRequestCallbacks() const;
|
| + bool shouldDumpResourceResponseMIMETypes() const;
|
| + bool shouldDumpStatusCallbacks() const;
|
| + bool shouldDumpProgressFinishedCallback() const;
|
| + bool shouldDumpSpellCheckCallbacks() const;
|
| + bool shouldStayOnPageAfterHandlingBeforeUnload() const;
|
| + const std::set<std::string>* httpHeadersToClear() const;
|
| + void setTopLoadingFrame(blink::WebFrame*, bool);
|
| + blink::WebFrame* topLoadingFrame() const;
|
| + void policyDelegateDone();
|
| + bool policyDelegateEnabled() const;
|
| + bool policyDelegateIsPermissive() const;
|
| + bool policyDelegateShouldNotifyDone() const;
|
| + bool shouldInterceptPostMessage() const;
|
| + bool shouldDumpResourcePriorities() const;
|
| + blink::WebNotificationPresenter* notification_presenter() const;
|
| + bool RequestPointerLock();
|
| + void RequestPointerUnlock();
|
| + bool isPointerLocked();
|
| + void setToolTipText(const blink::WebString&);
|
| +
|
| + bool midiAccessorResult();
|
| +
|
| + // A single item in the work queue.
|
| + class WorkItem {
|
| + public:
|
| + virtual ~WorkItem() {}
|
| +
|
| + // Returns true if this started a load.
|
| + virtual bool Run(::WebTestRunner::WebTestDelegate*, blink::WebView*) = 0;
|
| + };
|
| +
|
| + private:
|
| + friend class InvokeCallbackTask;
|
| + friend class TestRunnerBindings;
|
| + friend class WorkQueue;
|
| +
|
| + // Helper class for managing events queued by methods like queueLoad or
|
| + // queueScript.
|
| + class WorkQueue {
|
| + public:
|
| + explicit WorkQueue(TestRunner* controller);
|
| + virtual ~WorkQueue();
|
| + void ProcessWorkSoon();
|
| +
|
| + // Reset the state of the class between tests.
|
| + void Reset();
|
| +
|
| + void AddWork(WorkItem*);
|
| +
|
| + void set_frozen(bool frozen) { frozen_ = frozen; }
|
| + bool is_empty() { return queue_.empty(); }
|
| + ::WebTestRunner::WebTaskList* taskList() { return &task_list_; }
|
| +
|
| + private:
|
| + void ProcessWork();
|
| +
|
| + class WorkQueueTask : public ::WebTestRunner::WebMethodTask<WorkQueue> {
|
| + public:
|
| + WorkQueueTask(WorkQueue* object) :
|
| + ::WebTestRunner::WebMethodTask<WorkQueue>(object) { }
|
| +
|
| + virtual void runIfValid() OVERRIDE;
|
| + };
|
| +
|
| + ::WebTestRunner::WebTaskList task_list_;
|
| + std::deque<WorkItem*> queue_;
|
| + bool frozen_;
|
| + TestRunner* controller_;
|
| + };
|
| +
|
| + ///////////////////////////////////////////////////////////////////////////
|
| + // Methods dealing with the test logic
|
| +
|
| + // By default, tests end when page load is complete. These methods are used
|
| + // to delay the completion of the test until notifyDone is called.
|
| + void NotifyDone();
|
| + void WaitUntilDone();
|
| +
|
| + // Methods for adding actions to the work queue. Used in conjunction with
|
| + // waitUntilDone/notifyDone above.
|
| + void QueueBackNavigation(int how_far_back);
|
| + void QueueForwardNavigation(int how_far_forward);
|
| + void QueueReload();
|
| + void QueueLoadingScript(const std::string& script);
|
| + void QueueNonLoadingScript(const std::string& script);
|
| + void QueueLoad(const std::string& url, const std::string& target);
|
| + void QueueLoadHTMLString(gin::Arguments* args);
|
| +
|
| + // Causes navigation actions just printout the intended navigation instead
|
| + // of taking you to the page. This is used for cases like mailto, where you
|
| + // don't actually want to open the mail program.
|
| + void SetCustomPolicyDelegate(gin::Arguments* args);
|
| +
|
| + // Delays completion of the test until the policy delegate runs.
|
| + void WaitForPolicyDelegate();
|
| +
|
| + // Functions for dealing with windows. By default we block all new windows.
|
| + int WindowCount();
|
| + void SetCloseRemainingWindowsWhenComplete(bool close_remaining_windows);
|
| + void ResetTestHelperControllers();
|
| +
|
| + ///////////////////////////////////////////////////////////////////////////
|
| + // Methods implemented entirely in terms of chromium's public WebKit API
|
| +
|
| + // Method that controls whether pressing Tab key cycles through page elements
|
| + // or inserts a '\t' char in text area
|
| + void SetTabKeyCyclesThroughElements(bool tab_key_cycles_through_elements);
|
| +
|
| + // Executes an internal command (superset of document.execCommand() commands).
|
| + void ExecCommand(gin::Arguments* args);
|
| +
|
| + // Checks if an internal command is currently available.
|
| + bool IsCommandEnabled(const std::string& command);
|
| +
|
| + bool CallShouldCloseOnWebView();
|
| + void SetDomainRelaxationForbiddenForURLScheme(bool forbidden,
|
| + const std::string& scheme);
|
| + v8::Handle<v8::Value> EvaluateScriptInIsolatedWorldAndReturnValue(
|
| + int world_id, const std::string& script);
|
| + void EvaluateScriptInIsolatedWorld(int world_id, const std::string& script);
|
| + void SetIsolatedWorldSecurityOrigin(int world_id,
|
| + v8::Handle<v8::Value> origin);
|
| + void SetIsolatedWorldContentSecurityPolicy(int world_id,
|
| + const std::string& policy);
|
| +
|
| + // Allows layout tests to manage origins' whitelisting.
|
| + void AddOriginAccessWhitelistEntry(const std::string& source_origin,
|
| + const std::string& destination_protocol,
|
| + const std::string& destination_host,
|
| + bool allow_destination_subdomains);
|
| + void RemoveOriginAccessWhitelistEntry(const std::string& source_origin,
|
| + const std::string& destination_protocol,
|
| + const std::string& destination_host,
|
| + bool allow_destination_subdomains);
|
| +
|
| + // Returns true if the current page box has custom page size style for
|
| + // printing.
|
| + bool HasCustomPageSizeStyle(int page_index);
|
| +
|
| + // Forces the selection colors for testing under Linux.
|
| + void ForceRedSelectionColors();
|
| +
|
| + // Adds a style sheet to be injected into new documents.
|
| + void InjectStyleSheet(const std::string& source_code, bool all_frames);
|
| +
|
| + bool FindString(const std::string& search_text,
|
| + const std::vector<std::string>& options_array);
|
| +
|
| + std::string SelectionAsMarkup();
|
| +
|
| + // Enables or disables subpixel positioning (i.e. fractional X positions for
|
| + // glyphs) in text rendering on Linux. Since this method changes global
|
| + // settings, tests that call it must use their own custom font family for
|
| + // all text that they render. If not, an already-cached style will be used,
|
| + // resulting in the changed setting being ignored.
|
| + void SetTextSubpixelPositioning(bool value);
|
| +
|
| + // Switch the visibility of the page.
|
| + void SetPageVisibility(const std::string& new_visibility);
|
| +
|
| + // Changes the direction of the focused element.
|
| + void SetTextDirection(const std::string& direction_name);
|
| +
|
| + // After this function is called, 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.
|
| + void UseUnfortunateSynchronousResizeMode();
|
| +
|
| + bool EnableAutoResizeMode(int min_width,
|
| + int min_height,
|
| + int max_width,
|
| + int max_height);
|
| + bool DisableAutoResizeMode(int new_width, int new_height);
|
| +
|
| + // Device Motion / Device Orientation related functions
|
| + void SetMockDeviceMotion(bool has_acceleration_x, double acceleration_x,
|
| + bool has_acceleration_y, double acceleration_y,
|
| + bool has_acceleration_z, double acceleration_z,
|
| + bool has_acceleration_including_gravity_x,
|
| + double acceleration_including_gravity_x,
|
| + bool has_acceleration_including_gravity_y,
|
| + double acceleration_including_gravity_y,
|
| + bool has_acceleration_including_gravity_z,
|
| + double acceleration_including_gravity_z,
|
| + bool has_rotation_rate_alpha,
|
| + double rotation_rate_alpha,
|
| + bool has_rotation_rate_beta,
|
| + double rotation_rate_beta,
|
| + bool has_rotation_rate_gamma,
|
| + double rotation_rate_gamma,
|
| + double interval);
|
| + void SetMockDeviceOrientation(bool has_alpha, double alpha,
|
| + bool has_beta, double beta,
|
| + bool has_gamma, double gamma,
|
| + bool has_absolute, bool absolute);
|
| +
|
| + void DidAcquirePointerLock();
|
| + void DidNotAcquirePointerLock();
|
| + void DidLosePointerLock();
|
| + void SetPointerLockWillFailSynchronously();
|
| + void SetPointerLockWillRespondAsynchronously();
|
| +
|
| + ///////////////////////////////////////////////////////////////////////////
|
| + // Methods modifying WebPreferences.
|
| +
|
| + // Set the WebPreference that controls webkit's popup blocking.
|
| + void SetPopupBlockingEnabled(bool block_popups);
|
| +
|
| + void SetJavaScriptCanAccessClipboard(bool can_access);
|
| + void SetXSSAuditorEnabled(bool enabled);
|
| + void SetAllowUniversalAccessFromFileURLs(bool allow);
|
| + void SetAllowFileAccessFromFileURLs(bool allow);
|
| + void OverridePreference(const std::string key, v8::Handle<v8::Value> value);
|
| +
|
| + // Enable or disable plugins.
|
| + void SetPluginsEnabled(bool enabled);
|
| +
|
| + ///////////////////////////////////////////////////////////////////////////
|
| + // Methods that modify the state of TestRunner
|
| +
|
| + // This function sets a flag that tells the test_shell to print a line of
|
| + // descriptive text for each editing command. It takes no arguments, and
|
| + // ignores any that may be present.
|
| + void DumpEditingCallbacks();
|
| +
|
| + // This function sets a flag that tells the test_shell to dump pages as
|
| + // plain text, rather than as a text representation of the renderer's state.
|
| + // The pixel results will not be generated for this test.
|
| + void DumpAsText();
|
| +
|
| + // This function sets a flag that tells the test_shell to dump pages as
|
| + // plain text, rather than as a text representation of the renderer's state.
|
| + // It will also generate a pixel dump for the test.
|
| + void DumpAsTextWithPixelResults();
|
| +
|
| + // This function sets a flag that tells the test_shell to print out the
|
| + // scroll offsets of the child frames. It ignores all.
|
| + void DumpChildFrameScrollPositions();
|
| +
|
| + // This function sets a flag that tells the test_shell to recursively
|
| + // dump all frames as plain text if the DumpAsText flag is set.
|
| + // It takes no arguments, and ignores any that may be present.
|
| + void DumpChildFramesAsText();
|
| +
|
| + // This function sets a flag that tells the test_shell to print out the
|
| + // information about icon changes notifications from WebKit.
|
| + void DumpIconChanges();
|
| +
|
| + // Deals with Web Audio WAV file data.
|
| + void SetAudioData(const gin::ArrayBufferView& view);
|
| +
|
| + // This function sets a flag that tells the test_shell to print a line of
|
| + // descriptive text for each frame load callback. It takes no arguments, and
|
| + // ignores any that may be present.
|
| + void DumpFrameLoadCallbacks();
|
| +
|
| + // This function sets a flag that tells the test_shell to print a line of
|
| + // descriptive text for each PingLoader dispatch. It takes no arguments, and
|
| + // ignores any that may be present.
|
| + void DumpPingLoaderCallbacks();
|
| +
|
| + // This function sets a flag that tells the test_shell to print a line of
|
| + // user gesture status text for some frame load callbacks. It takes no
|
| + // arguments, and ignores any that may be present.
|
| + void DumpUserGestureInFrameLoadCallbacks();
|
| +
|
| + void DumpTitleChanges();
|
| +
|
| + // This function sets a flag that tells the test_shell to dump all calls to
|
| + // WebViewClient::createView().
|
| + // It takes no arguments, and ignores any that may be present.
|
| + void DumpCreateView();
|
| +
|
| + void SetCanOpenWindows();
|
| +
|
| + // This function sets a flag that tells the test_shell to dump a descriptive
|
| + // line for each resource load callback. It takes no arguments, and ignores
|
| + // any that may be present.
|
| + void DumpResourceLoadCallbacks();
|
| +
|
| + // This function sets a flag that tells the test_shell to print a line of
|
| + // descriptive text for each element that requested a resource. It takes no
|
| + // arguments, and ignores any that may be present.
|
| + void DumpResourceRequestCallbacks();
|
| +
|
| + // This function sets a flag that tells the test_shell to dump the MIME type
|
| + // for each resource that was loaded. It takes no arguments, and ignores any
|
| + // that may be present.
|
| + void DumpResourceResponseMIMETypes();
|
| +
|
| + // WebPermissionClient related.
|
| + void SetImagesAllowed(bool allowed);
|
| + void SetScriptsAllowed(bool allowed);
|
| + void SetStorageAllowed(bool allowed);
|
| + void SetPluginsAllowed(bool allowed);
|
| + void SetAllowDisplayOfInsecureContent(bool allowed);
|
| + void SetAllowRunningOfInsecureContent(bool allowed);
|
| + void DumpPermissionClientCallbacks();
|
| +
|
| + // This function sets a flag that tells the test_shell to dump all calls
|
| + // to window.status().
|
| + // It takes no arguments, and ignores any that may be present.
|
| + void DumpWindowStatusChanges();
|
| +
|
| + // This function sets a flag that tells the test_shell to print a line of
|
| + // descriptive text for the progress finished callback. It takes no
|
| + // arguments, and ignores any that may be present.
|
| + void DumpProgressFinishedCallback();
|
| +
|
| + // This function sets a flag that tells the test_shell to dump all
|
| + // the lines of descriptive text about spellcheck execution.
|
| + void DumpSpellCheckCallbacks();
|
| +
|
| + // This function sets a flag that tells the test_shell to print out a text
|
| + // representation of the back/forward list. It ignores all arguments.
|
| + void DumpBackForwardList();
|
| +
|
| + void DumpSelectionRect();
|
| + void TestRepaint();
|
| + void RepaintSweepHorizontally();
|
| +
|
| + // Causes layout to happen as if targetted to printed pages.
|
| + void SetPrinting();
|
| +
|
| + void SetShouldStayOnPageAfterHandlingBeforeUnload(bool value);
|
| +
|
| + // Causes WillSendRequest to clear certain headers.
|
| + void SetWillSendRequestClearHeader(const std::string& header);
|
| +
|
| + // This function sets a flag that tells the test_shell to dump a descriptive
|
| + // line for each resource load's priority and any time that priority
|
| + // changes. It takes no arguments, and ignores any that may be present.
|
| + void DumpResourceRequestPriorities();
|
| +
|
| + // Sets a flag to enable the mock theme.
|
| + void SetUseMockTheme(bool use);
|
| +
|
| + ///////////////////////////////////////////////////////////////////////////
|
| + // Methods interacting with the WebTestProxy
|
| +
|
| + ///////////////////////////////////////////////////////////////////////////
|
| + // Methods forwarding to the WebTestDelegate
|
| +
|
| + // Shows DevTools window.
|
| + void ShowWebInspector(const std::string& str);
|
| + void CloseWebInspector();
|
| +
|
| + // Inspect chooser state
|
| + bool IsChooserShown();
|
| +
|
| + // Allows layout tests to exec scripts at WebInspector side.
|
| + void EvaluateInWebInspector(int call_id, const std::string& script);
|
| +
|
| + // Clears all databases.
|
| + void ClearAllDatabases();
|
| + // Sets the default quota for all origins
|
| + void SetDatabaseQuota(int quota);
|
| +
|
| + // Changes the cookie policy from the default to allow all cookies.
|
| + void SetAlwaysAcceptCookies(bool accept);
|
| +
|
| + // Gives focus to the window.
|
| + void SetWindowIsKey(bool value);
|
| +
|
| + // Converts a URL starting with file:///tmp/ to the local mapping.
|
| + std::string PathToLocalResource(const std::string& path);
|
| +
|
| + // Used to set the device scale factor.
|
| + void SetBackingScaleFactor(double value, v8::Handle<v8::Function> callback);
|
| +
|
| + // Calls setlocale(LC_ALL, ...) for a specified locale.
|
| + // Resets between tests.
|
| + void SetPOSIXLocale(const std::string& locale);
|
| +
|
| + // MIDI function to control permission handling.
|
| + void SetMIDIAccessorResult(bool result);
|
| + void SetMIDISysExPermission(bool value);
|
| +
|
| + // Grants permission for desktop notifications to an origin
|
| + void GrantWebNotificationPermission(const std::string& origin,
|
| + bool permission_granted);
|
| + // Simulates a click on a desktop notification.
|
| + bool SimulateWebNotificationClick(const std::string& value);
|
| +
|
| + // Speech input related functions.
|
| + void AddMockSpeechInputResult(const std::string& result,
|
| + double confidence,
|
| + const std::string& language);
|
| + void SetMockSpeechInputDumpRect(bool value);
|
| + void AddMockSpeechRecognitionResult(const std::string& transcript,
|
| + double confidence);
|
| + void SetMockSpeechRecognitionError(const std::string& error,
|
| + const std::string& message);
|
| + bool WasMockSpeechRecognitionAborted();
|
| +
|
| + // WebPageOverlay related functions. Permits the adding and removing of only
|
| + // one opaque overlay.
|
| + void AddWebPageOverlay();
|
| + void RemoveWebPageOverlay();
|
| +
|
| + void Display();
|
| + void DisplayInvalidatedRegion();
|
| +
|
| + ///////////////////////////////////////////////////////////////////////////
|
| + // Internal helpers
|
| + void CheckResponseMimeType();
|
| + void CompleteNotifyDone();
|
| +
|
| + void DidAcquirePointerLockInternal();
|
| + void DidNotAcquirePointerLockInternal();
|
| + void DidLosePointerLockInternal();
|
| +
|
| + // In the Mac code, this is called to trigger the end of a test after the
|
| + // page has finished loading. From here, we can generate the dump for the
|
| + // test.
|
| + void LocationChangeDone();
|
| +
|
| + bool test_is_running_;
|
| +
|
| + // When reset is called, go through and close all but the main test shell
|
| + // window. By default, set to true but toggled to false using
|
| + // setCloseRemainingWindowsWhenComplete().
|
| + bool close_remaining_windows_;
|
| +
|
| + // If true, don't dump output until notifyDone is called.
|
| + bool wait_until_done_;
|
| +
|
| + // Causes navigation actions just printout the intended navigation instead
|
| + // of taking you to the page. This is used for cases like mailto, where you
|
| + // don't actually want to open the mail program.
|
| + bool policy_delegate_enabled_;
|
| +
|
| + // Toggles the behavior of the policy delegate. If true, then navigations
|
| + // will be allowed. Otherwise, they will be ignored (dropped).
|
| + bool policy_delegate_is_permissive_;
|
| +
|
| + // If true, the policy delegate will signal layout test completion.
|
| + bool policy_delegate_should_notify_done_;
|
| +
|
| + WorkQueue work_queue_;
|
| +
|
| + // Used by a number of layout tests in http/tests/security/dataURL.
|
| + bool global_flag_;
|
| +
|
| + // Bound variable to return the name of this platform (chromium).
|
| + std::string platform_name_;
|
| +
|
| + // Bound variable to store the last tooltip text
|
| + std::string tooltip_text_;
|
| +
|
| + // Bound variable to disable notifyDone calls. This is used in GC leak
|
| + // tests, where existing LayoutTests are loaded within an iframe. The GC
|
| + // test harness will set this flag to ignore the notifyDone calls from the
|
| + // target LayoutTest.
|
| + bool disable_notify_done_;
|
| +
|
| + // Bound variable counting the number of top URLs visited.
|
| + int web_history_item_count_;
|
| +
|
| + // Bound variable to set whether postMessages should be intercepted or not
|
| + bool intercept_post_message_;
|
| +
|
| + // If true, the test_shell will write a descriptive line for each editing
|
| + // command.
|
| + bool dump_editting_callbacks_;
|
| +
|
| + // If true, the test_shell will generate pixel results in DumpAsText mode
|
| + bool generate_pixel_results_;
|
| +
|
| + // If true, the test_shell will produce a plain text dump rather than a
|
| + // text representation of the renderer.
|
| + bool dump_as_text_;
|
| +
|
| + // If true and if dump_as_text_ is true, the test_shell will recursively
|
| + // dump all frames as plain text.
|
| + bool dump_child_frames_as_text_;
|
| +
|
| + // If true, the test_shell will produce a dump of the DOM rather than a text
|
| + // representation of the renderer.
|
| + bool dump_as_markup_;
|
| +
|
| + // If true, the test_shell will print out the child frame scroll offsets as
|
| + // well.
|
| + bool dump_child_frame_scroll_positions_;
|
| +
|
| + // If true, the test_shell will print out the icon change notifications.
|
| + bool dump_icon_changes_;
|
| +
|
| + // If true, the test_shell will output a base64 encoded WAVE file.
|
| + bool dump_as_audio_;
|
| +
|
| + // If true, the test_shell will output a descriptive line for each frame
|
| + // load callback.
|
| + bool dump_frame_load_callbacks_;
|
| +
|
| + // If true, the test_shell will output a descriptive line for each
|
| + // PingLoader dispatched.
|
| + bool dump_ping_loader_callbacks_;
|
| +
|
| + // If true, the test_shell will output a line of the user gesture status
|
| + // text for some frame load callbacks.
|
| + bool dump_user_gesture_in_frame_load_callbacks_;
|
| +
|
| + // If true, output a message when the page title is changed.
|
| + bool dump_title_changes_;
|
| +
|
| + // If true, output a descriptive line each time WebViewClient::createView
|
| + // is invoked.
|
| + bool dump_create_view_;
|
| +
|
| + // If true, new windows can be opened via javascript or by plugins. By
|
| + // default, set to false and can be toggled to true using
|
| + // setCanOpenWindows().
|
| + bool can_open_windows_;
|
| +
|
| + // If true, the test_shell will output a descriptive line for each resource
|
| + // load callback.
|
| + bool dump_resource_load_callbacks_;
|
| +
|
| + // If true, the test_shell will output a descriptive line for each resource
|
| + // request callback.
|
| + bool dump_resource_request_callbacks_;
|
| +
|
| + // If true, the test_shell will output the MIME type for each resource that
|
| + // was loaded.
|
| + bool dump_resource_reqponse_mime_types_;
|
| +
|
| + // If true, the test_shell will dump all changes to window.status.
|
| + bool dump_window_status_changes_;
|
| +
|
| + // If true, the test_shell will output a descriptive line for the progress
|
| + // finished callback.
|
| + bool dump_progress_finished_callback_;
|
| +
|
| + // If true, the test_shell will output descriptive test for spellcheck
|
| + // execution.
|
| + bool dump_spell_check_callbacks_;
|
| +
|
| + // If true, the test_shell will produce a dump of the back forward list as
|
| + // well.
|
| + bool dump_back_forward_list_;
|
| +
|
| + // If true, the test_shell will draw the bounds of the current selection rect
|
| + // taking possible transforms of the selection rect into account.
|
| + bool dump_selection_rect_;
|
| +
|
| + // If true, pixel dump will be produced as a series of 1px-tall, view-wide
|
| + // individual paints over the height of the view.
|
| + bool test_repaint_;
|
| +
|
| + // If true and test_repaint_ is true as well, pixel dump will be produced as
|
| + // a series of 1px-wide, view-tall paints across the width of the view.
|
| + bool sweep_horizontally_;
|
| +
|
| + // If true, layout is to target printed pages.
|
| + bool is_printing_;
|
| +
|
| + // If false, MockWebMIDIAccessor fails on startSession() for testing.
|
| + bool midi_accessor_result_;
|
| +
|
| + bool should_stay_on_page_after_handling_before_unload_;
|
| +
|
| + bool should_dump_resource_priorities_;
|
| +
|
| + std::set<std::string> http_headers_to_clear_;
|
| +
|
| + // WAV audio data is stored here.
|
| + std::vector<unsigned char> audio_data_;
|
| +
|
| + // Used for test timeouts.
|
| + ::WebTestRunner::WebTaskList task_list_;
|
| +
|
| + ::WebTestRunner::TestInterfaces* test_interfaces_;
|
| + ::WebTestRunner::WebTestDelegate* delegate_;
|
| + blink::WebView* web_view_;
|
| + TestPageOverlay* page_overlay_;
|
| + ::WebTestRunner::WebTestProxyBase* proxy_;
|
| +
|
| + // This is non-0 IFF a load is in progress.
|
| + blink::WebFrame* top_loading_frame_;
|
| +
|
| + // WebPermissionClient mock object.
|
| + scoped_ptr< ::WebTestRunner::WebPermissions> web_permissions_;
|
| +
|
| + scoped_ptr<content::NotificationPresenter> notification_presenter_;
|
| +
|
| + bool pointer_locked_;
|
| + enum {
|
| + PointerLockWillSucceed,
|
| + PointerLockWillRespondAsync,
|
| + PointerLockWillFailSync,
|
| + } pointer_lock_planned_result_;
|
| + bool use_mock_theme_;
|
| +
|
| + base::WeakPtrFactory<TestRunner> weak_factory_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(TestRunner);
|
| +};
|
| +
|
| +} // namespace content
|
| +
|
| +#endif // CONTENT_SHELL_RENDERER_TEST_RUNNER_TEST_RUNNER_H_
|
|
|