// Copyright (c) 2012 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 <cstring>
#include "base/strings/utf_string_conversions.h"
#include "ppapi/c/dev/ppb_memory_dev.h"
#include "ppapi/c/pp_errors.h"
#include "ppapi/c/ppb_image_data.h"
#include "ppapi/proxy/pdf_resource.h"
#include "ppapi/proxy/ppapi_messages.h"
#include "ppapi/proxy/ppapi_proxy_test.h"
#include "ppapi/proxy/ppb_image_data_proxy.h"
#include "ppapi/proxy/serialized_handle.h"
#include "ppapi/shared_impl/proxy_lock.h"
#include "ppapi/shared_impl/scoped_pp_var.h"
#include "ppapi/shared_impl/var.h"
#include "ppapi/thunk/thunk.h"
namespace ppapi {
namespace proxy {
namespace {
typedef PluginProxyTest PDFResourceTest;
} // namespace
TEST_F(PDFResourceTest, GetLocalizedString) {
const PPB_PDF* pdf_iface = thunk::GetPPB_PDF_Thunk();
std::string expected_string = "hello";
PpapiPluginMsg_PDF_GetLocalizedStringReply reply_msg(expected_string);
ResourceSyncCallHandler handler(
&sink(),
PpapiHostMsg_PDF_GetLocalizedString::ID,
PP_OK,
reply_msg);
sink().AddFilter(&handler);
PP_Var var = pdf_iface->GetLocalizedString(
pp_instance(), PP_RESOURCESTRING_PDFGETPASSWORD);
{
ProxyAutoLock lock;
ScopedPPVar release_var(ScopedPPVar::PassRef(), var);
StringVar* string_var = StringVar::FromPPVar(var);
ASSERT_TRUE(string_var != NULL);
std::string actual_string = string_var->value();
ASSERT_EQ(PpapiHostMsg_PDF_GetLocalizedString::ID,
handler.last_handled_msg().type());
ASSERT_EQ(expected_string, actual_string);
}
// Remove the filter or it will be destroyed before the sink() is destroyed.
sink().RemoveFilter(&handler);
}
TEST_F(PDFResourceTest, SearchString) {
ProxyAutoLock lock;
// Instantiate a resource explicitly so we can specify the locale.
scoped_refptr<PDFResource> pdf_resource(
new PDFResource(Connection(&sink(), &sink()), pp_instance()));
pdf_resource->SetLocaleForTest("en-US");
string16 input;
string16 term;
UTF8ToUTF16("abcdefabcdef", 12, &input);
UTF8ToUTF16("bc", 2, &term);
PP_PrivateFindResult* results;
int count = 0;
pdf_resource->SearchString(
reinterpret_cast<const unsigned short*>(input.c_str()),
reinterpret_cast<const unsigned short*>(term.c_str()),
true,
&results,
&count);
ASSERT_EQ(2, count);
ASSERT_EQ(1, results[0].start_index);
ASSERT_EQ(2, results[0].length);
ASSERT_EQ(7, results[1].start_index);
ASSERT_EQ(2, results[1].length);
const PPB_Memory_Dev* memory_iface = thunk::GetPPB_Memory_Dev_0_1_Thunk();
memory_iface->MemFree(results);
}
TEST_F(PDFResourceTest, DidStartLoading) {
const PPB_PDF* pdf_iface = thunk::GetPPB_PDF_Thunk();
pdf_iface->DidStartLoading(pp_instance());
ResourceMessageCallParams params;
IPC::Message msg;
ASSERT_TRUE(sink().GetFirstResourceCallMatching(
PpapiHostMsg_PDF_DidStartLoading::ID, ¶ms, &msg));
}
TEST_F(PDFResourceTest, DidStopLoading) {
const PPB_PDF* pdf_iface = thunk::GetPPB_PDF_Thunk();
pdf_iface->DidStopLoading(pp_instance());
ResourceMessageCallParams params;
IPC::Message msg;
ASSERT_TRUE(sink().GetFirstResourceCallMatching(
PpapiHostMsg_PDF_DidStopLoading::ID, ¶ms, &msg));
}
TEST_F(PDFResourceTest, SetContentRestriction) {
const PPB_PDF* pdf_iface = thunk::GetPPB_PDF_Thunk();
int restrictions = 5;
pdf_iface->SetContentRestriction(pp_instance(), restrictions);
ResourceMessageCallParams params;
IPC::Message msg;
ASSERT_TRUE(sink().GetFirstResourceCallMatching(
PpapiHostMsg_PDF_SetContentRestriction::ID, ¶ms, &msg));
}
TEST_F(PDFResourceTest, HasUnsupportedFeature) {
const PPB_PDF* pdf_iface = thunk::GetPPB_PDF_Thunk();
pdf_iface->HasUnsupportedFeature(pp_instance());
ResourceMessageCallParams params;
IPC::Message msg;
ASSERT_TRUE(sink().GetFirstResourceCallMatching(
PpapiHostMsg_PDF_HasUnsupportedFeature::ID, ¶ms, &msg));
}
TEST_F(PDFResourceTest, Print) {
const PPB_PDF* pdf_iface = thunk::GetPPB_PDF_Thunk();
pdf_iface->Print(pp_instance());
ResourceMessageCallParams params;
IPC::Message msg;
ASSERT_TRUE(sink().GetFirstResourceCallMatching(
PpapiHostMsg_PDF_Print::ID, ¶ms, &msg));
}
TEST_F(PDFResourceTest, SaveAs) {
const PPB_PDF* pdf_iface = thunk::GetPPB_PDF_Thunk();
pdf_iface->SaveAs(pp_instance());
ResourceMessageCallParams params;
IPC::Message msg;
ASSERT_TRUE(sink().GetFirstResourceCallMatching(
PpapiHostMsg_PDF_SaveAs::ID, ¶ms, &msg));
}
TEST_F(PDFResourceTest, GetResourceImageForScale) {
const PPB_PDF* pdf_iface = thunk::GetPPB_PDF_Thunk();
HostResource expected_resource;
expected_resource.SetHostResource(pp_instance(), 5);
PP_ImageDataDesc expected_desc = {
PP_IMAGEDATAFORMAT_BGRA_PREMUL,
{ 5, 10 },
20,
};
SerializedHandle serialized_handle(SerializedHandle::SHARED_MEMORY);
PpapiPluginMsg_PDF_GetResourceImageReply reply_msg(expected_resource,
expected_desc);
ResourceSyncCallHandler handler(
&sink(),
PpapiHostMsg_PDF_GetResourceImage::ID,
PP_OK,
reply_msg);
handler.set_serialized_handle(&serialized_handle);
sink().AddFilter(&handler);
PP_Resource resource = pdf_iface->GetResourceImageForScale(pp_instance(),
PP_RESOURCEIMAGE_PDF_BUTTON_FTP, 1.0f);
{
ProxyAutoLock lock;
PluginResourceTracker* resource_tracker =
static_cast<PluginResourceTracker*>(
PluginGlobals::Get()->GetResourceTracker());
Resource* resource_object = resource_tracker->GetResource(resource);
ImageData* image_data_object = static_cast<ImageData*>(resource_object);
PP_ImageDataDesc actual_desc = image_data_object->desc();
ASSERT_EQ(expected_desc.format, actual_desc.format);
ASSERT_EQ(expected_desc.size.width, actual_desc.size.width);
ASSERT_EQ(expected_desc.size.height, actual_desc.size.height);
ASSERT_EQ(expected_desc.stride, actual_desc.stride);
ASSERT_EQ(resource_tracker->PluginResourceForHostResource(
expected_resource), resource);
resource_tracker->ReleaseResource(resource);
}
// Remove the filter or it will be destroyed before the sink() is destroyed.
sink().RemoveFilter(&handler);
}
} // namespace proxy
} // namespace ppapi