blob: 38ecbab3f95428c7f70d9a4bd82040134b8f1000 [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.
#include "content/test/test_blink_web_unit_test_support.h"
#include "base/command_line.h"
#include "base/files/file_path.h"
#include "base/files/file_util.h"
#include "base/files/scoped_temp_dir.h"
#include "base/metrics/stats_counters.h"
#include "base/path_service.h"
#include "base/strings/utf_string_conversions.h"
#include "content/public/common/content_switches.h"
#include "content/renderer/scheduler/renderer_scheduler.h"
#include "content/renderer/scheduler/web_scheduler_impl.h"
#include "content/test/mock_webclipboard_impl.h"
#include "content/test/web_gesture_curve_mock.h"
#include "content/test/web_layer_tree_view_impl_for_testing.h"
#include "content/test/weburl_loader_mock_factory.h"
#include "media/base/media.h"
#include "net/cookies/cookie_monster.h"
#include "net/test/spawned_test_server/spawned_test_server.h"
#include "storage/browser/database/vfs_backend.h"
#include "third_party/WebKit/public/platform/WebData.h"
#include "third_party/WebKit/public/platform/WebFileSystem.h"
#include "third_party/WebKit/public/platform/WebStorageArea.h"
#include "third_party/WebKit/public/platform/WebStorageNamespace.h"
#include "third_party/WebKit/public/platform/WebString.h"
#include "third_party/WebKit/public/platform/WebURL.h"
#include "third_party/WebKit/public/web/WebDatabase.h"
#include "third_party/WebKit/public/web/WebKit.h"
#include "third_party/WebKit/public/web/WebRuntimeFeatures.h"
#include "third_party/WebKit/public/web/WebSecurityPolicy.h"
#include "third_party/WebKit/public/web/WebStorageEventDispatcher.h"
#include "v8/include/v8.h"
#if defined(OS_MACOSX)
#include "base/mac/foundation_util.h"
#include "base/mac/scoped_nsautorelease_pool.h"
#endif
#ifdef V8_USE_EXTERNAL_STARTUP_DATA
#include "gin/public/isolate_holder.h"
#endif
namespace content {
TestBlinkWebUnitTestSupport::TestBlinkWebUnitTestSupport() {
#if defined(OS_MACOSX)
base::mac::ScopedNSAutoreleasePool autorelease_pool;
#endif
url_loader_factory_.reset(new WebURLLoaderMockFactory());
mock_clipboard_.reset(new MockWebClipboardImpl());
// Create an anonymous stats table since we don't need to share between
// processes.
stats_table_.reset(
new base::StatsTable(base::StatsTable::TableIdentifier(), 20, 200));
base::StatsTable::set_current(stats_table_.get());
#ifdef V8_USE_EXTERNAL_STARTUP_DATA
gin::IsolateHolder::LoadV8Snapshot();
#endif
if (base::MessageLoopProxy::current()) {
renderer_scheduler_ = RendererScheduler::Create();
web_scheduler_.reset(new WebSchedulerImpl(renderer_scheduler_.get()));
}
blink::initialize(this);
blink::mainThreadIsolate()->SetCounterFunction(
base::StatsTable::FindLocation);
blink::setLayoutTestMode(true);
blink::WebSecurityPolicy::registerURLSchemeAsLocal(
blink::WebString::fromUTF8("test-shell-resource"));
blink::WebSecurityPolicy::registerURLSchemeAsNoAccess(
blink::WebString::fromUTF8("test-shell-resource"));
blink::WebSecurityPolicy::registerURLSchemeAsDisplayIsolated(
blink::WebString::fromUTF8("test-shell-resource"));
blink::WebSecurityPolicy::registerURLSchemeAsEmptyDocument(
blink::WebString::fromUTF8("test-shell-resource"));
blink::WebRuntimeFeatures::enableApplicationCache(true);
blink::WebRuntimeFeatures::enableDatabase(true);
blink::WebRuntimeFeatures::enableNotifications(true);
blink::WebRuntimeFeatures::enableTouch(true);
// Load libraries for media and enable the media player.
bool enable_media = false;
base::FilePath module_path;
if (PathService::Get(base::DIR_MODULE, &module_path)) {
#if defined(OS_MACOSX)
if (base::mac::AmIBundled())
module_path = module_path.DirName().DirName().DirName();
#endif
if (media::InitializeMediaLibrary(module_path))
enable_media = true;
}
blink::WebRuntimeFeatures::enableMediaPlayer(enable_media);
LOG_IF(WARNING, !enable_media) << "Failed to initialize the media library.\n";
file_utilities_.set_sandbox_enabled(false);
if (!file_system_root_.CreateUniqueTempDir()) {
LOG(WARNING) << "Failed to create a temp dir for the filesystem."
"FileSystem feature will be disabled.";
DCHECK(file_system_root_.path().empty());
}
#if defined(OS_WIN)
// Ensure we pick up the default theme engine.
SetThemeEngine(NULL);
#endif
base::CommandLine::ForCurrentProcess()->AppendSwitch(
switches::kEnableFileCookies);
// Test shell always exposes the GC.
std::string flags("--expose-gc");
v8::V8::SetFlagsFromString(flags.c_str(), static_cast<int>(flags.size()));
}
TestBlinkWebUnitTestSupport::~TestBlinkWebUnitTestSupport() {
url_loader_factory_.reset();
mock_clipboard_.reset();
blink::shutdown();
base::StatsTable::set_current(NULL);
stats_table_.reset();
}
blink::WebBlobRegistry* TestBlinkWebUnitTestSupport::blobRegistry() {
return &blob_registry_;
}
blink::WebClipboard* TestBlinkWebUnitTestSupport::clipboard() {
// Mock out clipboard calls so that tests don't mess
// with each other's copies/pastes when running in parallel.
return mock_clipboard_.get();
}
blink::WebFileUtilities* TestBlinkWebUnitTestSupport::fileUtilities() {
return &file_utilities_;
}
blink::WebIDBFactory* TestBlinkWebUnitTestSupport::idbFactory() {
NOTREACHED() <<
"IndexedDB cannot be tested with in-process harnesses.";
return NULL;
}
blink::WebMimeRegistry* TestBlinkWebUnitTestSupport::mimeRegistry() {
return &mime_registry_;
}
blink::WebURLLoader* TestBlinkWebUnitTestSupport::createURLLoader() {
return url_loader_factory_->CreateURLLoader(
BlinkPlatformImpl::createURLLoader());
}
blink::WebString TestBlinkWebUnitTestSupport::userAgent() {
return blink::WebString::fromUTF8("DumpRenderTree/0.0.0.0");
}
blink::WebData TestBlinkWebUnitTestSupport::loadResource(const char* name) {
if (!strcmp(name, "deleteButton")) {
// Create a red 30x30 square.
const char red_square[] =
"\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52"
"\x00\x00\x00\x1e\x00\x00\x00\x1e\x04\x03\x00\x00\x00\xc9\x1e\xb3"
"\x91\x00\x00\x00\x30\x50\x4c\x54\x45\x00\x00\x00\x80\x00\x00\x00"
"\x80\x00\x80\x80\x00\x00\x00\x80\x80\x00\x80\x00\x80\x80\x80\x80"
"\x80\xc0\xc0\xc0\xff\x00\x00\x00\xff\x00\xff\xff\x00\x00\x00\xff"
"\xff\x00\xff\x00\xff\xff\xff\xff\xff\x7b\x1f\xb1\xc4\x00\x00\x00"
"\x09\x70\x48\x59\x73\x00\x00\x0b\x13\x00\x00\x0b\x13\x01\x00\x9a"
"\x9c\x18\x00\x00\x00\x17\x49\x44\x41\x54\x78\x01\x63\x98\x89\x0a"
"\x18\x50\xb9\x33\x47\xf9\xa8\x01\x32\xd4\xc2\x03\x00\x33\x84\x0d"
"\x02\x3a\x91\xeb\xa5\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60"
"\x82";
return blink::WebData(red_square, arraysize(red_square));
}
return BlinkPlatformImpl::loadResource(name);
}
blink::WebString TestBlinkWebUnitTestSupport::queryLocalizedString(
blink::WebLocalizedString::Name name) {
// Returns placeholder strings to check if they are correctly localized.
switch (name) {
case blink::WebLocalizedString::OtherDateLabel:
return base::ASCIIToUTF16("<<OtherDateLabel>>");
case blink::WebLocalizedString::OtherMonthLabel:
return base::ASCIIToUTF16("<<OtherMonthLabel>>");
case blink::WebLocalizedString::OtherTimeLabel:
return base::ASCIIToUTF16("<<OtherTimeLabel>>");
case blink::WebLocalizedString::OtherWeekLabel:
return base::ASCIIToUTF16("<<OtherWeekLabel>>");
case blink::WebLocalizedString::CalendarClear:
return base::ASCIIToUTF16("<<CalendarClear>>");
case blink::WebLocalizedString::CalendarToday:
return base::ASCIIToUTF16("<<CalendarToday>>");
case blink::WebLocalizedString::ThisMonthButtonLabel:
return base::ASCIIToUTF16("<<ThisMonthLabel>>");
case blink::WebLocalizedString::ThisWeekButtonLabel:
return base::ASCIIToUTF16("<<ThisWeekLabel>>");
case blink::WebLocalizedString::WeekFormatTemplate:
return base::ASCIIToUTF16("Week $2, $1");
default:
return blink::WebString();
}
}
blink::WebString TestBlinkWebUnitTestSupport::queryLocalizedString(
blink::WebLocalizedString::Name name,
const blink::WebString& value) {
if (name == blink::WebLocalizedString::ValidationRangeUnderflow)
return base::ASCIIToUTF16("range underflow");
if (name == blink::WebLocalizedString::ValidationRangeOverflow)
return base::ASCIIToUTF16("range overflow");
if (name == blink::WebLocalizedString::SelectMenuListText)
return base::ASCIIToUTF16("$1 selected");
return BlinkPlatformImpl::queryLocalizedString(name, value);
}
blink::WebString TestBlinkWebUnitTestSupport::queryLocalizedString(
blink::WebLocalizedString::Name name,
const blink::WebString& value1,
const blink::WebString& value2) {
if (name == blink::WebLocalizedString::ValidationTooLong)
return base::ASCIIToUTF16("too long");
if (name == blink::WebLocalizedString::ValidationStepMismatch)
return base::ASCIIToUTF16("step mismatch");
return BlinkPlatformImpl::queryLocalizedString(name, value1, value2);
}
blink::WebString TestBlinkWebUnitTestSupport::defaultLocale() {
return base::ASCIIToUTF16("en-US");
}
#if defined(OS_WIN) || defined(OS_MACOSX)
void TestBlinkWebUnitTestSupport::SetThemeEngine(
blink::WebThemeEngine* engine) {
active_theme_engine_ = engine ? engine : BlinkPlatformImpl::themeEngine();
}
blink::WebThemeEngine* TestBlinkWebUnitTestSupport::themeEngine() {
return active_theme_engine_;
}
#endif
blink::WebCompositorSupport* TestBlinkWebUnitTestSupport::compositorSupport() {
return &compositor_support_;
}
blink::WebGestureCurve* TestBlinkWebUnitTestSupport::createFlingAnimationCurve(
blink::WebGestureDevice device_source,
const blink::WebFloatPoint& velocity,
const blink::WebSize& cumulative_scroll) {
// Caller will retain and release.
return new WebGestureCurveMock(velocity, cumulative_scroll);
}
blink::WebUnitTestSupport* TestBlinkWebUnitTestSupport::unitTestSupport() {
return this;
}
void TestBlinkWebUnitTestSupport::registerMockedURL(
const blink::WebURL& url,
const blink::WebURLResponse& response,
const blink::WebString& file_path) {
url_loader_factory_->RegisterURL(url, response, file_path);
}
void TestBlinkWebUnitTestSupport::registerMockedErrorURL(
const blink::WebURL& url,
const blink::WebURLResponse& response,
const blink::WebURLError& error) {
url_loader_factory_->RegisterErrorURL(url, response, error);
}
void TestBlinkWebUnitTestSupport::unregisterMockedURL(
const blink::WebURL& url) {
url_loader_factory_->UnregisterURL(url);
}
void TestBlinkWebUnitTestSupport::unregisterAllMockedURLs() {
url_loader_factory_->UnregisterAllURLs();
}
void TestBlinkWebUnitTestSupport::serveAsynchronousMockedRequests() {
url_loader_factory_->ServeAsynchronousRequests();
}
blink::WebString TestBlinkWebUnitTestSupport::webKitRootDir() {
base::FilePath path;
PathService::Get(base::DIR_SOURCE_ROOT, &path);
path = path.Append(FILE_PATH_LITERAL("third_party/WebKit"));
path = base::MakeAbsoluteFilePath(path);
CHECK(!path.empty());
std::string path_ascii = path.MaybeAsASCII();
CHECK(!path_ascii.empty());
return blink::WebString::fromUTF8(path_ascii.c_str());
}
blink::WebLayerTreeView*
TestBlinkWebUnitTestSupport::createLayerTreeViewForTesting() {
scoped_ptr<WebLayerTreeViewImplForTesting> view(
new WebLayerTreeViewImplForTesting());
view->Initialize();
return view.release();
}
blink::WebData TestBlinkWebUnitTestSupport::readFromFile(
const blink::WebString& path) {
base::FilePath file_path = base::FilePath::FromUTF16Unsafe(path);
std::string buffer;
base::ReadFileToString(file_path, &buffer);
return blink::WebData(buffer.data(), buffer.size());
}
bool TestBlinkWebUnitTestSupport::getBlobItems(
const blink::WebString& uuid,
blink::WebVector<blink::WebBlobData::Item*>* items) {
return blob_registry_.GetBlobItems(uuid, items);
}
blink::WebScheduler* TestBlinkWebUnitTestSupport::scheduler() {
return web_scheduler_.get();
}
} // namespace content