| OLD | NEW |
| (Empty) |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include <utility> | |
| 6 | |
| 7 #include "base/test/launcher/unit_test_launcher.h" | |
| 8 #include "base/test/test_suite.h" | |
| 9 #include "cc/ipc/cc_param_traits.h" | |
| 10 #include "cc/output/compositor_frame.h" | |
| 11 #include "cc/quads/picture_draw_quad.h" | |
| 12 #include "ipc/ipc_message.h" | |
| 13 #include "testing/gtest/include/gtest/gtest.h" | |
| 14 #include "testing/perf/perf_test.h" | |
| 15 | |
| 16 using cc::CompositorFrame; | |
| 17 using cc::DelegatedFrameData; | |
| 18 using cc::DrawQuad; | |
| 19 using cc::PictureDrawQuad; | |
| 20 using cc::RenderPass; | |
| 21 using cc::SharedQuadState; | |
| 22 | |
| 23 namespace content { | |
| 24 namespace { | |
| 25 | |
| 26 static const int kTimeLimitMillis = 2000; | |
| 27 static const int kNumWarmupRuns = 20; | |
| 28 static const int kTimeCheckInterval = 10; | |
| 29 | |
| 30 class CCMessagesPerfTest : public testing::Test { | |
| 31 protected: | |
| 32 static void RunTest(const std::string& test_name, | |
| 33 const CompositorFrame& frame) { | |
| 34 for (int i = 0; i < kNumWarmupRuns; ++i) { | |
| 35 IPC::Message msg(1, 2, IPC::Message::PRIORITY_NORMAL); | |
| 36 IPC::ParamTraits<CompositorFrame>::Write(&msg, frame); | |
| 37 } | |
| 38 | |
| 39 base::TimeTicks start = base::TimeTicks::Now(); | |
| 40 base::TimeTicks end = | |
| 41 start + base::TimeDelta::FromMilliseconds(kTimeLimitMillis); | |
| 42 base::TimeDelta min_time; | |
| 43 int count = 0; | |
| 44 while (start < end) { | |
| 45 for (int i = 0; i < kTimeCheckInterval; ++i) { | |
| 46 IPC::Message msg(1, 2, IPC::Message::PRIORITY_NORMAL); | |
| 47 IPC::ParamTraits<CompositorFrame>::Write(&msg, frame); | |
| 48 ++count; | |
| 49 } | |
| 50 | |
| 51 base::TimeTicks now = base::TimeTicks::Now(); | |
| 52 if (now - start < min_time || min_time.is_zero()) | |
| 53 min_time = now - start; | |
| 54 start = base::TimeTicks::Now(); | |
| 55 } | |
| 56 | |
| 57 perf_test::PrintResult( | |
| 58 "min_frame_serialization_time", | |
| 59 "", | |
| 60 test_name, | |
| 61 min_time.InMillisecondsF() / kTimeCheckInterval * 1000, | |
| 62 "us", | |
| 63 true); | |
| 64 } | |
| 65 }; | |
| 66 | |
| 67 TEST_F(CCMessagesPerfTest, DelegatedFrame_ManyQuads_1_4000) { | |
| 68 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 69 | |
| 70 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 71 render_pass->CreateAndAppendSharedQuadState(); | |
| 72 for (int i = 0; i < 4000; ++i) { | |
| 73 PictureDrawQuad* quad = | |
| 74 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 75 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 76 } | |
| 77 | |
| 78 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 79 frame->delegated_frame_data->render_pass_list.push_back( | |
| 80 std::move(render_pass)); | |
| 81 | |
| 82 RunTest("DelegatedFrame_ManyQuads_1_4000", *frame); | |
| 83 } | |
| 84 | |
| 85 TEST_F(CCMessagesPerfTest, DelegatedFrame_ManyQuads_1_100000) { | |
| 86 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 87 | |
| 88 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 89 render_pass->CreateAndAppendSharedQuadState(); | |
| 90 for (int i = 0; i < 100000; ++i) { | |
| 91 PictureDrawQuad* quad = | |
| 92 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 93 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 94 } | |
| 95 | |
| 96 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 97 frame->delegated_frame_data->render_pass_list.push_back( | |
| 98 std::move(render_pass)); | |
| 99 | |
| 100 RunTest("DelegatedFrame_ManyQuads_1_100000", *frame); | |
| 101 } | |
| 102 | |
| 103 TEST_F(CCMessagesPerfTest, DelegatedFrame_ManyQuads_4000_4000) { | |
| 104 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 105 | |
| 106 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 107 for (int i = 0; i < 4000; ++i) { | |
| 108 render_pass->CreateAndAppendSharedQuadState(); | |
| 109 PictureDrawQuad* quad = | |
| 110 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 111 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 112 } | |
| 113 | |
| 114 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 115 frame->delegated_frame_data->render_pass_list.push_back( | |
| 116 std::move(render_pass)); | |
| 117 | |
| 118 RunTest("DelegatedFrame_ManyQuads_4000_4000", *frame); | |
| 119 } | |
| 120 | |
| 121 TEST_F(CCMessagesPerfTest, DelegatedFrame_ManyQuads_100000_100000) { | |
| 122 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 123 | |
| 124 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 125 for (int i = 0; i < 100000; ++i) { | |
| 126 render_pass->CreateAndAppendSharedQuadState(); | |
| 127 PictureDrawQuad* quad = | |
| 128 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 129 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 130 } | |
| 131 | |
| 132 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 133 frame->delegated_frame_data->render_pass_list.push_back( | |
| 134 std::move(render_pass)); | |
| 135 | |
| 136 RunTest("DelegatedFrame_ManyQuads_100000_100000", *frame); | |
| 137 } | |
| 138 | |
| 139 TEST_F(CCMessagesPerfTest, | |
| 140 DelegatedFrame_ManyRenderPasses_10000_100) { | |
| 141 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 142 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 143 | |
| 144 for (int i = 0; i < 1000; ++i) { | |
| 145 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 146 for (int j = 0; j < 100; ++j) { | |
| 147 render_pass->CreateAndAppendSharedQuadState(); | |
| 148 PictureDrawQuad* quad = | |
| 149 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 150 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 151 } | |
| 152 frame->delegated_frame_data->render_pass_list.push_back( | |
| 153 std::move(render_pass)); | |
| 154 } | |
| 155 | |
| 156 RunTest("DelegatedFrame_ManyRenderPasses_10000_100", *frame); | |
| 157 } | |
| 158 | |
| 159 } // namespace | |
| 160 } // namespace content | |
| OLD | NEW |