blob: a5c590791a19a4cd1ad91f8c45e27fe3d36d8acf [file] [log] [blame]
// 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.
#include "content/shell/test_runner/test_interfaces.h"
#include <stddef.h>
#include <string>
#include "base/json/json_writer.h"
#include "base/json/string_escape.h"
#include "base/logging.h"
#include "base/strings/stringprintf.h"
#include "base/values.h"
#include "content/shell/test_runner/gamepad_controller.h"
#include "content/shell/test_runner/gc_controller.h"
#include "content/shell/test_runner/test_runner.h"
#include "content/shell/test_runner/text_input_controller.h"
#include "content/shell/test_runner/web_view_test_proxy.h"
#include "third_party/blink/public/platform/web_cache.h"
#include "third_party/blink/public/platform/web_url.h"
#include "third_party/blink/public/web/blink.h"
#include "third_party/blink/public/web/web_view.h"
namespace test_runner {
TestInterfaces::TestInterfaces()
: gamepad_controller_(new GamepadController()),
test_runner_(new TestRunner(this)),
delegate_(nullptr),
main_view_(nullptr) {
blink::SetWebTestMode(true);
// NOTE: please don't put feature specific enable flags here,
// instead add them to runtime_enabled_features.json5
ResetAll();
}
TestInterfaces::~TestInterfaces() {
// gamepad_controller_ doesn't depend on WebView.
test_runner_->SetMainView(nullptr);
// gamepad_controller_ ignores SetDelegate(nullptr)
test_runner_->SetDelegate(nullptr);
}
void TestInterfaces::SetMainView(blink::WebView* web_view) {
// gamepad_controller_ doesn't depend on WebView.
main_view_ = web_view;
test_runner_->SetMainView(web_view);
}
void TestInterfaces::SetDelegate(WebTestDelegate* delegate) {
test_runner_->SetDelegate(delegate);
delegate_ = delegate;
}
void TestInterfaces::BindTo(blink::WebLocalFrame* frame) {
gamepad_controller_->Install(frame);
GCController::Install(this, frame);
}
void TestInterfaces::ResetTestHelperControllers() {
gamepad_controller_->Reset();
blink::WebCache::Clear();
for (WebViewTestProxyBase* web_view_test_proxy_base : window_list_)
web_view_test_proxy_base->Reset();
}
void TestInterfaces::ResetAll() {
ResetTestHelperControllers();
test_runner_->Reset();
}
bool TestInterfaces::TestIsRunning() {
return test_runner_->TestIsRunning();
}
void TestInterfaces::SetTestIsRunning(bool running) {
test_runner_->SetTestIsRunning(running);
}
void TestInterfaces::ConfigureForTestWithURL(const blink::WebURL& test_url,
bool protocol_mode) {
std::string spec = GURL(test_url).spec();
size_t path_start = spec.rfind("web_tests/");
if (path_start != std::string::npos)
spec = spec.substr(path_start);
bool is_devtools_test = spec.find("/devtools/") != std::string::npos;
if (is_devtools_test) {
test_runner_->SetDumpConsoleMessages(false);
}
// In protocol mode (see TestInfo::protocol_mode), we dump layout only when
// requested by the test. In non-protocol mode, we dump layout by default
// because the layout may be the only interesting thing to the user while
// we don't dump non-human-readable binary data. In non-protocol mode, we
// still generate pixel results (though don't dump them) to let the renderer
// execute the same code regardless of the protocol mode, e.g. for ease of
// debugging a web test issue.
if (!protocol_mode)
test_runner_->setShouldDumpAsLayout(true);
// For http/tests/loading/, which is served via httpd and becomes /loading/.
if (spec.find("/loading/") != std::string::npos)
test_runner_->setShouldDumpFrameLoadCallbacks(true);
if (spec.find("/dumpAsText/") != std::string::npos) {
test_runner_->setShouldDumpAsText(true);
test_runner_->setShouldGeneratePixelResults(false);
}
test_runner_->SetV8CacheDisabled(is_devtools_test);
if (spec.find("/viewsource/") != std::string::npos) {
test_runner_->setShouldEnableViewSource(true);
test_runner_->setShouldGeneratePixelResults(false);
test_runner_->setShouldDumpAsMarkup(true);
}
if (spec.find("/external/wpt/") != std::string::npos ||
spec.find("/external/csswg-test/") != std::string::npos ||
spec.find("://web-platform.test") != std::string::npos ||
spec.find("/harness-tests/wpt/") != std::string::npos)
test_runner_->set_is_web_platform_tests_mode();
}
void TestInterfaces::WindowOpened(WebViewTestProxyBase* proxy) {
window_list_.push_back(proxy);
}
void TestInterfaces::WindowClosed(WebViewTestProxyBase* proxy) {
std::vector<WebViewTestProxyBase*>::iterator pos =
std::find(window_list_.begin(), window_list_.end(), proxy);
if (pos == window_list_.end()) {
NOTREACHED();
return;
}
window_list_.erase(pos);
if (proxy->web_view() == main_view_)
SetMainView(nullptr);
}
TestRunner* TestInterfaces::GetTestRunner() {
return test_runner_.get();
}
WebTestDelegate* TestInterfaces::GetDelegate() {
return delegate_;
}
const std::vector<WebViewTestProxyBase*>& TestInterfaces::GetWindowList() {
return window_list_;
}
blink::WebThemeEngine* TestInterfaces::GetThemeEngine() {
if (!test_runner_->UseMockTheme())
return nullptr;
if (!theme_engine_.get())
theme_engine_.reset(new MockWebThemeEngine());
return theme_engine_.get();
}
} // namespace test_runner