mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
Add a shared memory variant of CefProcessMessage (fixes issue #3126)
CefSharedProcessMessageBuilder supports creation of a CefProcessMessage backed by a CefSharedMemoryRegion. Performance tests comparing the existing ArgumentList approach and the new SharedMemoryRegion approach have been added to cefclient at http://tests/ipc_performance. CefMessageRouter has been updated to use SharedMemoryRegion as transport for larger message payloads. The threshold is configurable via |CefMessageRouterConfig.message_size_threshold|. To test: run `ceftests --gtest_filter=SendSharedProcessMessageTest.*:SharedProcessMessageTest.*:MessageRouterTest.Threshold*`
This commit is contained in:
committed by
Marshall Greenblatt
parent
a931d49f3e
commit
81e892d19e
94
tests/ceftests/shared_process_message_unittest.cc
Normal file
94
tests/ceftests/shared_process_message_unittest.cc
Normal file
@@ -0,0 +1,94 @@
|
||||
// Copyright (c) 2022 The Chromium Embedded Framework 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 "include/cef_shared_process_message_builder.h"
|
||||
|
||||
#include "testing/gtest/include/gtest/gtest.h"
|
||||
|
||||
#include <array>
|
||||
|
||||
namespace {
|
||||
|
||||
constexpr bool kTestFlag = true;
|
||||
constexpr int kTestValue = 42;
|
||||
constexpr double kTestDoubleValue = 123.456;
|
||||
|
||||
struct TestData {
|
||||
bool flag = kTestFlag;
|
||||
int value = kTestValue;
|
||||
double doubleValue = kTestDoubleValue;
|
||||
std::array<size_t, 50> buffer{};
|
||||
};
|
||||
|
||||
const char kSharedMessageName[] = "SharedProcessMessageTest";
|
||||
|
||||
CefRefPtr<CefSharedProcessMessageBuilder> CreateTestBuilder() {
|
||||
auto builder = CefSharedProcessMessageBuilder::Create(kSharedMessageName,
|
||||
sizeof(TestData));
|
||||
EXPECT_NE(builder, nullptr);
|
||||
EXPECT_TRUE(builder->IsValid());
|
||||
|
||||
auto data = static_cast<TestData*>(builder->Memory());
|
||||
EXPECT_NE(data, nullptr);
|
||||
|
||||
data->value = kTestValue;
|
||||
data->doubleValue = kTestDoubleValue;
|
||||
data->flag = kTestFlag;
|
||||
for (size_t i = 0; i < data->buffer.size(); ++i) {
|
||||
data->buffer[i] = i;
|
||||
}
|
||||
|
||||
return builder;
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
||||
TEST(SharedProcessMessageTest, CanBuildSharedMessageUsingBuilder) {
|
||||
auto builder = CreateTestBuilder();
|
||||
|
||||
auto message = builder->Build();
|
||||
EXPECT_FALSE(builder->IsValid());
|
||||
EXPECT_NE(message, nullptr);
|
||||
EXPECT_TRUE(message->IsValid());
|
||||
EXPECT_TRUE(message->IsReadOnly());
|
||||
|
||||
auto region = message->GetSharedMemoryRegion();
|
||||
EXPECT_TRUE(region->IsValid());
|
||||
auto read_data = static_cast<const TestData*>(region->Memory());
|
||||
|
||||
EXPECT_EQ(read_data->flag, kTestFlag);
|
||||
EXPECT_EQ(read_data->value, kTestValue);
|
||||
EXPECT_EQ(read_data->doubleValue, kTestDoubleValue);
|
||||
for (size_t i = 0; i < read_data->buffer.size(); ++i) {
|
||||
EXPECT_EQ(read_data->buffer[i], i);
|
||||
}
|
||||
}
|
||||
|
||||
TEST(SharedProcessMessageTest, CopyingIsNotSupportedBySharedMessage) {
|
||||
auto builder = CefSharedProcessMessageBuilder::Create(kSharedMessageName,
|
||||
sizeof(TestData));
|
||||
CefRefPtr<CefProcessMessage> message = builder->Build();
|
||||
CefRefPtr<CefProcessMessage> message_copy = message->Copy();
|
||||
EXPECT_EQ(message_copy, nullptr);
|
||||
}
|
||||
|
||||
TEST(SharedProcessMessageTest,
|
||||
RegionRemainsValidAfterSharedMessageDestruction) {
|
||||
CefRefPtr<CefSharedMemoryRegion> region;
|
||||
{
|
||||
auto builder = CreateTestBuilder();
|
||||
auto message = builder->Build();
|
||||
region = message->GetSharedMemoryRegion();
|
||||
}
|
||||
|
||||
EXPECT_TRUE(region->IsValid());
|
||||
auto read_data = static_cast<const TestData*>(region->Memory());
|
||||
|
||||
EXPECT_EQ(read_data->flag, kTestFlag);
|
||||
EXPECT_EQ(read_data->value, kTestValue);
|
||||
EXPECT_EQ(read_data->doubleValue, kTestDoubleValue);
|
||||
for (size_t i = 0; i < read_data->buffer.size(); ++i) {
|
||||
EXPECT_EQ(read_data->buffer[i], i);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user