blob: 4fc609fecd827ce7792a6cad0cb039d731e14ff8 [file] [log] [blame]
// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/public/test/test_web_ui.h"
#include <string_view>
#include <utility>
#include "base/functional/callback.h"
#include "base/memory/ptr_util.h"
#include "base/no_destructor.h"
#include "base/notimplemented.h"
#include "content/public/browser/web_ui_controller.h"
#include "content/public/browser/web_ui_message_handler.h"
namespace content {
TestWebUI::TestWebUI() = default;
TestWebUI::~TestWebUI() {
ClearTrackedCalls();
}
void TestWebUI::ClearTrackedCalls() {
call_data_.clear();
}
void TestWebUI::HandleReceivedMessage(const std::string& handler_name,
const base::Value::List& args) {
const auto callbacks_map_it = message_callbacks_.find(handler_name);
if (callbacks_map_it != message_callbacks_.end()) {
// Create a copy of the callbacks before running them. Without this, it
// could be possible for the callback's handler to register a new message
// handler during iteration of the vector, resulting in undefined behavior.
std::vector<MessageCallback> callbacks_to_run = callbacks_map_it->second;
for (auto& callback : callbacks_to_run)
callback.Run(args);
return;
}
}
WebContents* TestWebUI::GetWebContents() {
return web_contents_;
}
WebUIController* TestWebUI::GetController() {
return controller_.get();
}
RenderFrameHost* TestWebUI::GetRenderFrameHost() {
return render_frame_host_.get();
}
void TestWebUI::SetController(std::unique_ptr<WebUIController> controller) {
controller_ = std::move(controller);
}
float TestWebUI::GetDeviceScaleFactor() {
return 1.0f;
}
void TestWebUI::OverrideTitle(const std::u16string& title) {
temp_string_ = title;
}
const std::u16string& TestWebUI::GetOverriddenTitle() {
return temp_string_;
}
BindingsPolicySet TestWebUI::GetBindings() {
return bindings_;
}
void TestWebUI::SetBindings(BindingsPolicySet bindings) {
bindings_ = bindings;
}
const std::vector<std::string>& TestWebUI::GetRequestableSchemes() {
NOTIMPLEMENTED();
static base::NoDestructor<std::vector<std::string>> dummy;
return *dummy;
}
void TestWebUI::AddRequestableScheme(const char* scheme) {
NOTIMPLEMENTED();
return;
}
void TestWebUI::AddMessageHandler(
std::unique_ptr<WebUIMessageHandler> handler) {
handler->set_web_ui(this);
handler->RegisterMessages();
handlers_.push_back(std::move(handler));
}
void TestWebUI::RegisterMessageCallback(std::string_view message,
MessageCallback callback) {
message_callbacks_[static_cast<std::string>(message)].push_back(
std::move(callback));
}
void TestWebUI::ProcessWebUIMessage(const GURL& source_url,
const std::string& message,
base::Value::List args) {
auto callback_entry = message_callbacks_.find(message);
if (callback_entry == message_callbacks_.end()) {
return;
}
for (auto& callback : callback_entry->second) {
callback.Run(args);
}
}
bool TestWebUI::CanCallJavascript() {
return true;
}
void TestWebUI::CallJavascriptFunctionUnsafe(
std::string_view function_name,
base::span<const base::ValueView> args) {
call_data_.push_back(base::WrapUnique(new CallData(function_name)));
for (const auto& arg : args) {
call_data_.back()->AppendArgument(arg.ToValue());
}
OnJavascriptCall(*call_data_.back());
}
void TestWebUI::OnJavascriptCall(const CallData& call_data) {
for (JavascriptCallObserver& observer : javascript_call_observers_)
observer.OnJavascriptFunctionCalled(call_data);
}
std::vector<std::unique_ptr<WebUIMessageHandler>>*
TestWebUI::GetHandlersForTesting() {
return &handlers_;
}
TestWebUI::CallData::CallData(std::string_view function_name)
: function_name_(function_name.data(), function_name.size()) {}
TestWebUI::CallData::~CallData() {
}
void TestWebUI::CallData::AppendArgument(base::Value arg) {
args_.Append(std::move(arg));
}
} // namespace content