Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(617)

Unified Diff: ui/display/mojo/display_struct_traits_unittest.cc

Issue 2857033002: Remove DisplayStructTraitsTest interface. (Closed)
Patch Set: SerializeAndDeserialize. Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ui/display/mojo/display_struct_traits_test.mojom ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/display/mojo/display_struct_traits_unittest.cc
diff --git a/ui/display/mojo/display_struct_traits_unittest.cc b/ui/display/mojo/display_struct_traits_unittest.cc
index 1edac9f82c5036aa8e4bd75884073e3631fa2502..8bcfd6b2a26436da719e4c7fa9e1b8cb41aed0d9 100644
--- a/ui/display/mojo/display_struct_traits_unittest.cc
+++ b/ui/display/mojo/display_struct_traits_unittest.cc
@@ -5,12 +5,14 @@
#include <memory>
#include "base/macros.h"
-#include "base/message_loop/message_loop.h"
-#include "mojo/public/cpp/bindings/binding_set.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "ui/display/display.h"
#include "ui/display/display_layout.h"
-#include "ui/display/mojo/display_struct_traits_test.mojom.h"
+#include "ui/display/mojo/display_layout_struct_traits.h"
+#include "ui/display/mojo/display_mode_struct_traits.h"
+#include "ui/display/mojo/display_snapshot_mojo_struct_traits.h"
+#include "ui/display/mojo/display_struct_traits.h"
+#include "ui/display/mojo/gamma_ramp_rgb_entry_struct_traits.h"
#include "ui/display/types/display_constants.h"
#include "ui/display/types/display_mode.h"
#include "ui/display/types/display_snapshot_mojo.h"
@@ -25,62 +27,6 @@ constexpr int64_t kDisplayId1 = 123;
constexpr int64_t kDisplayId2 = 456;
constexpr int64_t kDisplayId3 = 789;
-class DisplayStructTraitsTest : public testing::Test,
- public mojom::DisplayStructTraitsTest {
- public:
- DisplayStructTraitsTest() {}
-
- protected:
- mojom::DisplayStructTraitsTestPtr GetTraitsTestProxy() {
- return traits_test_bindings_.CreateInterfacePtrAndBind(this);
- }
-
- private:
- // mojom::DisplayStructTraitsTest:
- void EchoDisplay(const Display& in,
- const EchoDisplayCallback& callback) override {
- callback.Run(in);
- }
-
- void EchoDisplayMode(std::unique_ptr<DisplayMode> in,
- const EchoDisplayModeCallback& callback) override {
- callback.Run(std::move(in));
- }
-
- void EchoDisplaySnapshotMojo(
- std::unique_ptr<DisplaySnapshotMojo> in,
- const EchoDisplaySnapshotMojoCallback& callback) override {
- callback.Run(std::move(in));
- }
-
- void EchoDisplayPlacement(
- const DisplayPlacement& in,
- const EchoDisplayPlacementCallback& callback) override {
- callback.Run(in);
- }
-
- void EchoDisplayLayout(std::unique_ptr<display::DisplayLayout> in,
- const EchoDisplayLayoutCallback& callback) override {
- callback.Run(std::move(in));
- }
-
- void EchoHDCPState(display::HDCPState in,
- const EchoHDCPStateCallback& callback) override {
- callback.Run(in);
- }
-
- void EchoGammaRampRGBEntry(
- const GammaRampRGBEntry& in,
- const EchoGammaRampRGBEntryCallback& callback) override {
- callback.Run(in);
- }
-
- base::MessageLoop loop_; // A MessageLoop is needed for Mojo IPC to work.
- mojo::BindingSet<mojom::DisplayStructTraitsTest> traits_test_bindings_;
-
- DISALLOW_COPY_AND_ASSIGN(DisplayStructTraitsTest);
-};
-
void CheckDisplaysEqual(const Display& input, const Display& output) {
EXPECT_NE(&input, &output); // Make sure they aren't the same object.
EXPECT_EQ(input.id(), output.id());
@@ -144,18 +90,31 @@ void CheckDisplaySnapShotMojoEqual(const DisplaySnapshotMojo& input,
EXPECT_EQ(input.maximum_cursor_size(), output.maximum_cursor_size());
}
+// Test StructTrait serialization and deserialization for copyable type. |input|
+// will be serialized and then deserialized into |output|.
+template <class MojomType, class Type>
+void SerializeAndDeserialize(const Type& input, Type* output) {
+ MojomType::Deserialize(MojomType::Serialize(&input), output);
+}
+
+// Test StructTrait serialization and deserialization for move only type.
+// |input| will be serialized and then deserialized into |output|.
+template <class MojomType, class Type>
+void SerializeAndDeserialize(Type&& input, Type* output) {
+ MojomType::Deserialize(MojomType::Serialize(&input), output);
+}
} // namespace
-TEST_F(DisplayStructTraitsTest, DefaultDisplayValues) {
+TEST(DisplayStructTraitsTest, DefaultDisplayValues) {
Display input(5);
Display output;
- GetTraitsTestProxy()->EchoDisplay(input, &output);
+ SerializeAndDeserialize<mojom::Display>(input, &output);
CheckDisplaysEqual(input, output);
}
-TEST_F(DisplayStructTraitsTest, SetAllDisplayValues) {
+TEST(DisplayStructTraitsTest, SetAllDisplayValues) {
const gfx::Rect bounds(100, 200, 500, 600);
const gfx::Rect work_area(150, 250, 400, 500);
const gfx::Size maximum_cursor_size(64, 64);
@@ -168,19 +127,17 @@ TEST_F(DisplayStructTraitsTest, SetAllDisplayValues) {
input.set_maximum_cursor_size(maximum_cursor_size);
Display output;
- GetTraitsTestProxy()->EchoDisplay(input, &output);
+ SerializeAndDeserialize<mojom::Display>(input, &output);
CheckDisplaysEqual(input, output);
}
-TEST_F(DisplayStructTraitsTest, DefaultDisplayMode) {
+TEST(DisplayStructTraitsTest, DefaultDisplayMode) {
std::unique_ptr<DisplayMode> input =
base::MakeUnique<DisplayMode>(gfx::Size(1024, 768), true, 61.0);
- mojom::DisplayStructTraitsTestPtr proxy = GetTraitsTestProxy();
std::unique_ptr<DisplayMode> output;
-
- proxy->EchoDisplayMode(input->Clone(), &output);
+ SerializeAndDeserialize<mojom::DisplayMode>(input->Clone(), &output);
// We want to test each component individually to make sure each data member
// was correctly serialized and deserialized.
@@ -189,7 +146,7 @@ TEST_F(DisplayStructTraitsTest, DefaultDisplayMode) {
EXPECT_EQ(input->refresh_rate(), output->refresh_rate());
}
-TEST_F(DisplayStructTraitsTest, DisplayPlacementFlushAtTop) {
+TEST(DisplayStructTraitsTest, DisplayPlacementFlushAtTop) {
DisplayPlacement input;
input.display_id = kDisplayId1;
input.parent_display_id = kDisplayId2;
@@ -198,12 +155,12 @@ TEST_F(DisplayStructTraitsTest, DisplayPlacementFlushAtTop) {
input.offset_reference = DisplayPlacement::TOP_LEFT;
DisplayPlacement output;
- GetTraitsTestProxy()->EchoDisplayPlacement(input, &output);
+ SerializeAndDeserialize<mojom::DisplayPlacement>(input, &output);
EXPECT_EQ(input, output);
}
-TEST_F(DisplayStructTraitsTest, DisplayPlacementWithOffset) {
+TEST(DisplayStructTraitsTest, DisplayPlacementWithOffset) {
DisplayPlacement input;
input.display_id = kDisplayId1;
input.parent_display_id = kDisplayId2;
@@ -212,12 +169,12 @@ TEST_F(DisplayStructTraitsTest, DisplayPlacementWithOffset) {
input.offset_reference = DisplayPlacement::BOTTOM_RIGHT;
DisplayPlacement output;
- GetTraitsTestProxy()->EchoDisplayPlacement(input, &output);
+ SerializeAndDeserialize<mojom::DisplayPlacement>(input, &output);
EXPECT_EQ(input, output);
}
-TEST_F(DisplayStructTraitsTest, DisplayLayoutTwoExtended) {
+TEST(DisplayStructTraitsTest, DisplayLayoutTwoExtended) {
DisplayPlacement placement;
placement.display_id = kDisplayId1;
placement.parent_display_id = kDisplayId2;
@@ -232,12 +189,12 @@ TEST_F(DisplayStructTraitsTest, DisplayLayoutTwoExtended) {
input->default_unified = true;
std::unique_ptr<DisplayLayout> output;
- GetTraitsTestProxy()->EchoDisplayLayout(input->Copy(), &output);
+ SerializeAndDeserialize<mojom::DisplayLayout>(input->Copy(), &output);
CheckDisplayLayoutsEqual(*input, *output);
}
-TEST_F(DisplayStructTraitsTest, DisplayLayoutThreeExtended) {
+TEST(DisplayStructTraitsTest, DisplayLayoutThreeExtended) {
DisplayPlacement placement1;
placement1.display_id = kDisplayId2;
placement1.parent_display_id = kDisplayId1;
@@ -260,12 +217,12 @@ TEST_F(DisplayStructTraitsTest, DisplayLayoutThreeExtended) {
input->default_unified = false;
std::unique_ptr<DisplayLayout> output;
- GetTraitsTestProxy()->EchoDisplayLayout(input->Copy(), &output);
+ SerializeAndDeserialize<mojom::DisplayLayout>(input->Copy(), &output);
CheckDisplayLayoutsEqual(*input, *output);
}
-TEST_F(DisplayStructTraitsTest, DisplayLayoutTwoMirrored) {
+TEST(DisplayStructTraitsTest, DisplayLayoutTwoMirrored) {
DisplayPlacement placement;
placement.display_id = kDisplayId1;
placement.parent_display_id = kDisplayId2;
@@ -280,16 +237,16 @@ TEST_F(DisplayStructTraitsTest, DisplayLayoutTwoMirrored) {
input->default_unified = true;
std::unique_ptr<DisplayLayout> output;
- GetTraitsTestProxy()->EchoDisplayLayout(input->Copy(), &output);
+ SerializeAndDeserialize<mojom::DisplayLayout>(input->Copy(), &output);
CheckDisplayLayoutsEqual(*input, *output);
}
-TEST_F(DisplayStructTraitsTest, BasicGammaRampRGBEntry) {
+TEST(DisplayStructTraitsTest, BasicGammaRampRGBEntry) {
const GammaRampRGBEntry input{259, 81, 16};
GammaRampRGBEntry output;
- GetTraitsTestProxy()->EchoGammaRampRGBEntry(input, &output);
+ SerializeAndDeserialize<mojom::GammaRampRGBEntry>(input, &output);
EXPECT_EQ(input.r, output.r);
EXPECT_EQ(input.g, output.g);
@@ -297,7 +254,7 @@ TEST_F(DisplayStructTraitsTest, BasicGammaRampRGBEntry) {
}
// One display mode, current and native mode nullptr.
-TEST_F(DisplayStructTraitsTest, DisplaySnapshotCurrentAndNativeModesNull) {
+TEST(DisplayStructTraitsTest, DisplaySnapshotCurrentAndNativeModesNull) {
// Prepare sample input with random values.
const int64_t display_id = 7;
const gfx::Point origin(1, 2);
@@ -329,14 +286,14 @@ TEST_F(DisplayStructTraitsTest, DisplaySnapshotCurrentAndNativeModesNull) {
maximum_cursor_size);
std::unique_ptr<DisplaySnapshotMojo> output;
- GetTraitsTestProxy()->EchoDisplaySnapshotMojo(
+ SerializeAndDeserialize<mojom::DisplaySnapshotMojo>(
DisplaySnapshotMojo::CreateFrom(*input), &output);
CheckDisplaySnapShotMojoEqual(*input, *output);
}
// One display mode that is the native mode and no current mode.
-TEST_F(DisplayStructTraitsTest, DisplaySnapshotCurrentModeNull) {
+TEST(DisplayStructTraitsTest, DisplaySnapshotCurrentModeNull) {
// Prepare sample input with random values.
const int64_t display_id = 6;
const gfx::Point origin(11, 32);
@@ -367,14 +324,14 @@ TEST_F(DisplayStructTraitsTest, DisplaySnapshotCurrentModeNull) {
maximum_cursor_size);
std::unique_ptr<DisplaySnapshotMojo> output;
- GetTraitsTestProxy()->EchoDisplaySnapshotMojo(
+ SerializeAndDeserialize<mojom::DisplaySnapshotMojo>(
DisplaySnapshotMojo::CreateFrom(*input), &output);
CheckDisplaySnapShotMojoEqual(*input, *output);
}
// Multiple display modes, both native and current mode set.
-TEST_F(DisplayStructTraitsTest, DisplaySnapshotExternal) {
+TEST(DisplayStructTraitsTest, DisplaySnapshotExternal) {
// Prepare sample input from external display.
const int64_t display_id = 9834293210466051;
const gfx::Point origin(0, 1760);
@@ -409,13 +366,13 @@ TEST_F(DisplayStructTraitsTest, DisplaySnapshotExternal) {
maximum_cursor_size);
std::unique_ptr<DisplaySnapshotMojo> output;
- GetTraitsTestProxy()->EchoDisplaySnapshotMojo(
+ SerializeAndDeserialize<mojom::DisplaySnapshotMojo>(
DisplaySnapshotMojo::CreateFrom(*input), &output);
CheckDisplaySnapShotMojoEqual(*input, *output);
}
-TEST_F(DisplayStructTraitsTest, DisplaySnapshotInternal) {
+TEST(DisplayStructTraitsTest, DisplaySnapshotInternal) {
// Prepare sample input from Pixel's internal display.
const int64_t display_id = 13761487533244416;
const gfx::Point origin(0, 0);
@@ -446,17 +403,10 @@ TEST_F(DisplayStructTraitsTest, DisplaySnapshotInternal) {
maximum_cursor_size);
std::unique_ptr<DisplaySnapshotMojo> output;
- GetTraitsTestProxy()->EchoDisplaySnapshotMojo(
+ SerializeAndDeserialize<mojom::DisplaySnapshotMojo>(
DisplaySnapshotMojo::CreateFrom(*input), &output);
CheckDisplaySnapShotMojoEqual(*input, *output);
}
-TEST_F(DisplayStructTraitsTest, HDCPStateBasic) {
- const display::HDCPState input(HDCP_STATE_ENABLED);
- display::HDCPState output;
- GetTraitsTestProxy()->EchoHDCPState(input, &output);
- EXPECT_EQ(input, output);
-}
-
} // namespace display
« no previous file with comments | « ui/display/mojo/display_struct_traits_test.mojom ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698