| 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 CCParamTraitsPerfTest : 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", "", test_name, | |
| 59 min_time.InMillisecondsF() / kTimeCheckInterval * 1000, "us", true); | |
| 60 } | |
| 61 }; | |
| 62 | |
| 63 TEST_F(CCParamTraitsPerfTest, DelegatedFrame_ManyQuads_1_4000) { | |
| 64 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 65 | |
| 66 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 67 render_pass->CreateAndAppendSharedQuadState(); | |
| 68 for (int i = 0; i < 4000; ++i) { | |
| 69 PictureDrawQuad* quad = | |
| 70 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 71 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 72 } | |
| 73 | |
| 74 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 75 frame->delegated_frame_data->render_pass_list.push_back( | |
| 76 std::move(render_pass)); | |
| 77 | |
| 78 RunTest("DelegatedFrame_ManyQuads_1_4000", *frame); | |
| 79 } | |
| 80 | |
| 81 TEST_F(CCParamTraitsPerfTest, DelegatedFrame_ManyQuads_1_100000) { | |
| 82 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 83 | |
| 84 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 85 render_pass->CreateAndAppendSharedQuadState(); | |
| 86 for (int i = 0; i < 100000; ++i) { | |
| 87 PictureDrawQuad* quad = | |
| 88 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 89 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 90 } | |
| 91 | |
| 92 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 93 frame->delegated_frame_data->render_pass_list.push_back( | |
| 94 std::move(render_pass)); | |
| 95 | |
| 96 RunTest("DelegatedFrame_ManyQuads_1_100000", *frame); | |
| 97 } | |
| 98 | |
| 99 TEST_F(CCParamTraitsPerfTest, DelegatedFrame_ManyQuads_4000_4000) { | |
| 100 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 101 | |
| 102 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 103 for (int i = 0; i < 4000; ++i) { | |
| 104 render_pass->CreateAndAppendSharedQuadState(); | |
| 105 PictureDrawQuad* quad = | |
| 106 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 107 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 108 } | |
| 109 | |
| 110 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 111 frame->delegated_frame_data->render_pass_list.push_back( | |
| 112 std::move(render_pass)); | |
| 113 | |
| 114 RunTest("DelegatedFrame_ManyQuads_4000_4000", *frame); | |
| 115 } | |
| 116 | |
| 117 TEST_F(CCParamTraitsPerfTest, DelegatedFrame_ManyQuads_100000_100000) { | |
| 118 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 119 | |
| 120 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 121 for (int i = 0; i < 100000; ++i) { | |
| 122 render_pass->CreateAndAppendSharedQuadState(); | |
| 123 PictureDrawQuad* quad = | |
| 124 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 125 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 126 } | |
| 127 | |
| 128 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 129 frame->delegated_frame_data->render_pass_list.push_back( | |
| 130 std::move(render_pass)); | |
| 131 | |
| 132 RunTest("DelegatedFrame_ManyQuads_100000_100000", *frame); | |
| 133 } | |
| 134 | |
| 135 TEST_F(CCParamTraitsPerfTest, DelegatedFrame_ManyRenderPasses_10000_100) { | |
| 136 std::unique_ptr<CompositorFrame> frame(new CompositorFrame); | |
| 137 frame->delegated_frame_data.reset(new DelegatedFrameData); | |
| 138 | |
| 139 for (int i = 0; i < 1000; ++i) { | |
| 140 std::unique_ptr<RenderPass> render_pass = RenderPass::Create(); | |
| 141 for (int j = 0; j < 100; ++j) { | |
| 142 render_pass->CreateAndAppendSharedQuadState(); | |
| 143 PictureDrawQuad* quad = | |
| 144 render_pass->CreateAndAppendDrawQuad<PictureDrawQuad>(); | |
| 145 quad->shared_quad_state = render_pass->shared_quad_state_list.back(); | |
| 146 } | |
| 147 frame->delegated_frame_data->render_pass_list.push_back( | |
| 148 std::move(render_pass)); | |
| 149 } | |
| 150 | |
| 151 RunTest("DelegatedFrame_ManyRenderPasses_10000_100", *frame); | |
| 152 } | |
| 153 | |
| 154 } // namespace | |
| 155 } // namespace content | |
| OLD | NEW |