OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
| 5 #include <utility> |
| 6 |
5 #include "mojo/public/cpp/bindings/binding.h" | 7 #include "mojo/public/cpp/bindings/binding.h" |
6 #include "mojo/public/cpp/test_support/test_support.h" | 8 #include "mojo/public/cpp/test_support/test_support.h" |
7 #include "mojo/public/cpp/test_support/test_utils.h" | 9 #include "mojo/public/cpp/test_support/test_utils.h" |
8 #include "mojo/public/cpp/utility/run_loop.h" | 10 #include "mojo/public/cpp/utility/run_loop.h" |
9 #include "mojo/public/interfaces/bindings/tests/ping_service.mojom.h" | 11 #include "mojo/public/interfaces/bindings/tests/ping_service.mojom.h" |
10 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
11 | 13 |
12 namespace mojo { | 14 namespace mojo { |
13 namespace { | 15 namespace { |
14 | 16 |
(...skipping 29 matching lines...) Expand all Loading... |
44 void OnPingDone(); | 46 void OnPingDone(); |
45 | 47 |
46 test::PingServicePtr service_; | 48 test::PingServicePtr service_; |
47 unsigned int iterations_to_run_; | 49 unsigned int iterations_to_run_; |
48 unsigned int current_iterations_; | 50 unsigned int current_iterations_; |
49 | 51 |
50 MOJO_DISALLOW_COPY_AND_ASSIGN(PingPongTest); | 52 MOJO_DISALLOW_COPY_AND_ASSIGN(PingPongTest); |
51 }; | 53 }; |
52 | 54 |
53 PingPongTest::PingPongTest(test::PingServicePtr service) | 55 PingPongTest::PingPongTest(test::PingServicePtr service) |
54 : service_(service.Pass()) { | 56 : service_(std::move(service)) {} |
55 } | |
56 | 57 |
57 void PingPongTest::Run(unsigned int iterations) { | 58 void PingPongTest::Run(unsigned int iterations) { |
58 iterations_to_run_ = iterations; | 59 iterations_to_run_ = iterations; |
59 current_iterations_ = 0; | 60 current_iterations_ = 0; |
60 | 61 |
61 service_->Ping([this]() { OnPingDone(); }); | 62 service_->Ping([this]() { OnPingDone(); }); |
62 RunLoop::current()->Run(); | 63 RunLoop::current()->Run(); |
63 } | 64 } |
64 | 65 |
65 void PingPongTest::OnPingDone() { | 66 void PingPongTest::OnPingDone() { |
(...skipping 19 matching lines...) Expand all Loading... |
85 class MojoBindingsPerftest : public testing::Test { | 86 class MojoBindingsPerftest : public testing::Test { |
86 protected: | 87 protected: |
87 Environment env_; | 88 Environment env_; |
88 RunLoop run_loop_; | 89 RunLoop run_loop_; |
89 }; | 90 }; |
90 | 91 |
91 TEST_F(MojoBindingsPerftest, InProcessPingPong) { | 92 TEST_F(MojoBindingsPerftest, InProcessPingPong) { |
92 test::PingServicePtr service; | 93 test::PingServicePtr service; |
93 PingServiceImpl impl; | 94 PingServiceImpl impl; |
94 Binding<test::PingService> binding(&impl, GetProxy(&service)); | 95 Binding<test::PingService> binding(&impl, GetProxy(&service)); |
95 PingPongTest test(service.Pass()); | 96 PingPongTest test(std::move(service)); |
96 | 97 |
97 { | 98 { |
98 const unsigned int kIterations = 100000; | 99 const unsigned int kIterations = 100000; |
99 const MojoTimeTicks start_time = MojoGetTimeTicksNow(); | 100 const MojoTimeTicks start_time = MojoGetTimeTicksNow(); |
100 test.Run(kIterations); | 101 test.Run(kIterations); |
101 const MojoTimeTicks end_time = MojoGetTimeTicksNow(); | 102 const MojoTimeTicks end_time = MojoGetTimeTicksNow(); |
102 test::LogPerfResult( | 103 test::LogPerfResult( |
103 "InProcessPingPong", "0_Inactive", | 104 "InProcessPingPong", "0_Inactive", |
104 kIterations / MojoTicksToSeconds(end_time - start_time), | 105 kIterations / MojoTicksToSeconds(end_time - start_time), |
105 "pings/second"); | 106 "pings/second"); |
(...skipping 12 matching lines...) Expand all Loading... |
118 "InProcessPingPong", "1000_Inactive", | 119 "InProcessPingPong", "1000_Inactive", |
119 kIterations / MojoTicksToSeconds(end_time - start_time), | 120 kIterations / MojoTicksToSeconds(end_time - start_time), |
120 "pings/second"); | 121 "pings/second"); |
121 | 122 |
122 delete[] inactive_services; | 123 delete[] inactive_services; |
123 } | 124 } |
124 } | 125 } |
125 | 126 |
126 } // namespace | 127 } // namespace |
127 } // namespace mojo | 128 } // namespace mojo |
OLD | NEW |