Chromium Code Reviews| Index: ui/ozone/common/mojo/display_mode_proxy_struct_traits_unittest.cc |
| diff --git a/ui/ozone/common/mojo/display_mode_proxy_struct_traits_unittest.cc b/ui/ozone/common/mojo/display_mode_proxy_struct_traits_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..41a5c1f8915ce5895dac166ab1e12f09c297a56b |
| --- /dev/null |
| +++ b/ui/ozone/common/mojo/display_mode_proxy_struct_traits_unittest.cc |
| @@ -0,0 +1,62 @@ |
| +// Copyright 2016 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 "base/logging.h" |
| +#include "base/message_loop/message_loop.h" |
| +#include "mojo/public/cpp/bindings/binding.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| +#include "ui/ozone/common/mojo/display_mode_proxy_test.mojom.h" |
|
kylechar
2017/01/17 17:19:27
Missing #include for ui::DisplayMode_Params.
thanhph1
2017/01/17 20:19:06
Done.
|
| + |
| +namespace ui { |
| + |
| +class DisplayModeProxyTestImpl : public mojom::DisplayModeProxyTest { |
|
kylechar
2017/01/17 17:19:27
You'll want to put the DisplaySnapshotParams test
thanhph1
2017/01/17 20:19:06
Done.
|
| + public: |
| + explicit DisplayModeProxyTestImpl( |
| + mojo::InterfaceRequest<mojom::DisplayModeProxyTest> request) |
| + : binding_(this, std::move(request)) {} |
| + |
| + // DisplayModeProxyTest: |
| + void BounceDisplayModeProxy( |
| + const DisplayMode_Params& input, |
| + const BounceDisplayModeProxyCallback& callback) override { |
| + callback.Run(input); |
| + } |
| + |
| + private: |
| + mojo::Binding<DisplayModeProxyTest> binding_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(DisplayModeProxyTestImpl); |
| +}; |
| + |
| +TEST(MojoDisplayModeStructTraitsTest, Basic) { |
| + // A MessageLoop is needed for Mojo IPC to work. |
| + base::MessageLoop message_loop; |
| + |
| + mojom::DisplayModeProxyTestPtr proxy; |
| + DisplayModeProxyTestImpl impl(MakeRequest(&proxy)); |
| + |
| + // sample random data |
| + gfx::Size size(15, 29); |
|
kylechar
2017/01/17 17:19:27
If you aren't going to use these again, there is n
thanhph1
2017/01/17 20:19:06
Done.
|
| + bool is_interlaced = true; |
| + float refresh_rate = 61; |
| + |
| + // prepare input values |
| + DisplayMode_Params input; |
| + input.size = size; |
| + input.is_interlaced = is_interlaced; |
| + input.refresh_rate = refresh_rate; |
| + ui::DisplayMode_Params output; |
| + |
| + EXPECT_TRUE(proxy->BounceDisplayModeProxy(input, &output)); |
| + |
| + // We want to test each component individually to make sure each data member |
| + // was correctly serialized and deserialized. |
| + EXPECT_NE(&input, &output); // Make sure they aren't the same object. |
|
kylechar
2017/01/17 17:19:27
You know what input and output aren't the same obj
thanhph1
2017/01/17 20:19:06
Done, thanks!
|
| + EXPECT_EQ(input.size.width(), output.size.width()); |
|
kylechar
2017/01/17 17:19:27
gfx::Size has == defined, so you can compare them
thanhph1
2017/01/17 20:19:06
Done.
|
| + EXPECT_EQ(input.size.height(), output.size.height()); |
| + EXPECT_EQ(input.is_interlaced, output.is_interlaced); |
| + EXPECT_EQ(input.refresh_rate, output.refresh_rate); |
| +} |
| + |
| +} // namespace ui |