Index: cc/output/bsp_tree_perftest.cc |
diff --git a/cc/trees/layer_tree_host_common_perftest.cc b/cc/output/bsp_tree_perftest.cc |
similarity index 72% |
copy from cc/trees/layer_tree_host_common_perftest.cc |
copy to cc/output/bsp_tree_perftest.cc |
index 768b4a155e40f29ed68492336c87ca04d9196962..7d2e4b6fafc621895479383d88da318efff0385e 100644 |
--- a/cc/trees/layer_tree_host_common_perftest.cc |
+++ b/cc/output/bsp_tree_perftest.cc |
@@ -1,4 +1,4 @@ |
-// Copyright 2013 The Chromium Authors. All rights reserved. |
+// 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. |
@@ -35,20 +35,13 @@ static const int kTimeLimitMillis = 2000; |
static const int kWarmupRuns = 5; |
static const int kTimeCheckInterval = 10; |
-class LayerTreeHostCommonPerfTest : public LayerTreeTest { |
+class BspTreePerfTest : public LayerTreeTest { |
public: |
- LayerTreeHostCommonPerfTest() |
+ BspTreePerfTest() |
: timer_(kWarmupRuns, |
base::TimeDelta::FromMilliseconds(kTimeLimitMillis), |
kTimeCheckInterval) {} |
- void ReadTestFile(const std::string& name) { |
- base::FilePath test_data_dir; |
- ASSERT_TRUE(PathService::Get(CCPaths::DIR_TEST_DATA, &test_data_dir)); |
- base::FilePath json_file = test_data_dir.AppendASCII(name + ".json"); |
- ASSERT_TRUE(base::ReadFileToString(json_file, &json_)); |
- } |
- |
void SetupTree() override { |
gfx::Size viewport = gfx::Size(720, 1038); |
layer_tree()->SetViewportSize(viewport); |
@@ -61,79 +54,17 @@ class LayerTreeHostCommonPerfTest : public LayerTreeTest { |
void SetTestName(const std::string& name) { test_name_ = name; } |
- void AfterTest() override { |
- CHECK(!test_name_.empty()) << "Must SetTestName() before TearDown()."; |
- perf_test::PrintResult("calc_draw_props_time", |
- "", |
- test_name_, |
- 1000 * timer_.MsPerLap(), |
- "us", |
- true); |
- } |
- |
- protected: |
- FakeContentLayerClient content_layer_client_; |
- LapTimer timer_; |
- std::string test_name_; |
- std::string json_; |
-}; |
- |
-class CalcDrawPropsTest : public LayerTreeHostCommonPerfTest { |
- public: |
- void RunCalcDrawProps() { RunTest(CompositorMode::SINGLE_THREADED); } |
- |
- void BeginTest() override { PostSetNeedsCommitToMainThread(); } |
- |
- void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override { |
- timer_.Reset(); |
- LayerTreeImpl* active_tree = host_impl->active_tree(); |
- |
- do { |
- bool can_render_to_separate_surface = true; |
- int max_texture_size = 8096; |
- DoCalcDrawPropertiesImpl(can_render_to_separate_surface, |
- max_texture_size, |
- active_tree, |
- host_impl); |
- |
- timer_.NextLap(); |
- } while (!timer_.HasTimeLimitExpired()); |
- |
- EndTest(); |
- } |
- |
- void DoCalcDrawPropertiesImpl(bool can_render_to_separate_surface, |
- int max_texture_size, |
- LayerTreeImpl* active_tree, |
- LayerTreeHostImpl* host_impl) { |
- LayerImplList update_list; |
- LayerTreeHostCommon::CalcDrawPropsImplInputs inputs( |
- active_tree->root_layer_for_testing(), active_tree->DrawViewportSize(), |
- host_impl->DrawTransform(), active_tree->device_scale_factor(), |
- active_tree->current_page_scale_factor(), |
- active_tree->InnerViewportContainerLayer(), |
- active_tree->InnerViewportScrollLayer(), |
- active_tree->OuterViewportScrollLayer(), |
- active_tree->elastic_overscroll()->Current(active_tree->IsActiveTree()), |
- active_tree->OverscrollElasticityLayer(), max_texture_size, |
- can_render_to_separate_surface, |
- host_impl->settings().layer_transforms_should_scale_layer_contents, |
- false, // do not verify_clip_tree_calculation for perf tests |
- false, // do not verify_transform_tree_calculation for perf tests |
- &update_list, active_tree->property_trees()); |
- LayerTreeHostCommon::CalculateDrawProperties(&inputs); |
- } |
-}; |
- |
-class BspTreePerfTest : public CalcDrawPropsTest { |
- public: |
- BspTreePerfTest() : num_duplicates_(1) {} |
- void RunSortLayers() { RunTest(CompositorMode::SINGLE_THREADED); } |
- |
void SetNumberOfDuplicates(int num_duplicates) { |
num_duplicates_ = num_duplicates; |
} |
+ void ReadTestFile(const std::string& name) { |
+ base::FilePath test_data_dir; |
+ ASSERT_TRUE(PathService::Get(CCPaths::DIR_TEST_DATA, &test_data_dir)); |
+ base::FilePath json_file = test_data_dir.AppendASCII(name + ".json"); |
+ ASSERT_TRUE(base::ReadFileToString(json_file, &json_)); |
+ } |
+ |
void BeginTest() override { PostSetNeedsCommitToMainThread(); } |
void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override { |
@@ -142,10 +73,8 @@ class BspTreePerfTest : public CalcDrawPropsTest { |
// itself |
bool can_render_to_separate_surface = true; |
int max_texture_size = 8096; |
- DoCalcDrawPropertiesImpl(can_render_to_separate_surface, |
- max_texture_size, |
- active_tree, |
- host_impl); |
+ DoCalcDrawPropertiesImpl(can_render_to_separate_surface, max_texture_size, |
+ active_tree, host_impl); |
LayerImplList base_list; |
BuildLayerImplList(active_tree->root_layer_for_testing(), &base_list); |
@@ -175,6 +104,28 @@ class BspTreePerfTest : public CalcDrawPropsTest { |
EndTest(); |
} |
+ void DoCalcDrawPropertiesImpl(bool can_render_to_separate_surface, |
+ int max_texture_size, |
+ LayerTreeImpl* active_tree, |
+ LayerTreeHostImpl* host_impl) { |
+ LayerImplList update_list; |
+ LayerTreeHostCommon::CalcDrawPropsImplInputs inputs( |
+ active_tree->root_layer_for_testing(), active_tree->DrawViewportSize(), |
+ host_impl->DrawTransform(), active_tree->device_scale_factor(), |
+ active_tree->current_page_scale_factor(), |
+ active_tree->InnerViewportContainerLayer(), |
+ active_tree->InnerViewportScrollLayer(), |
+ active_tree->OuterViewportScrollLayer(), |
+ active_tree->elastic_overscroll()->Current(active_tree->IsActiveTree()), |
+ active_tree->OverscrollElasticityLayer(), max_texture_size, |
+ can_render_to_separate_surface, |
+ host_impl->settings().layer_transforms_should_scale_layer_contents, |
+ false, // do not verify_clip_tree_calculation for perf tests |
+ false, // do not verify_transform_tree_calculation for perf tests |
+ &update_list, active_tree->property_trees()); |
+ LayerTreeHostCommon::CalculateDrawProperties(&inputs); |
+ } |
+ |
void BuildLayerImplList(LayerImpl* layer, LayerImplList* list) { |
for (auto* layer_impl : *layer->layer_tree_impl()) { |
if (layer_impl->Is3dSorted() && !layer_impl->bounds().IsEmpty()) { |
@@ -183,73 +134,59 @@ class BspTreePerfTest : public CalcDrawPropsTest { |
} |
} |
+ void AfterTest() override { |
+ CHECK(!test_name_.empty()) << "Must SetTestName() before TearDown()."; |
+ perf_test::PrintResult("calc_draw_props_time", "", test_name_, |
+ 1000 * timer_.MsPerLap(), "us", true); |
+ } |
+ |
private: |
+ FakeContentLayerClient content_layer_client_; |
+ LapTimer timer_; |
+ std::string test_name_; |
+ std::string json_; |
LayerImplList base_list_; |
- int num_duplicates_; |
+ int num_duplicates_ = 1; |
}; |
-TEST_F(CalcDrawPropsTest, TenTen) { |
- SetTestName("10_10"); |
- ReadTestFile("10_10_layer_tree"); |
- RunCalcDrawProps(); |
-} |
- |
-TEST_F(CalcDrawPropsTest, HeavyPage) { |
- SetTestName("heavy_page"); |
- ReadTestFile("heavy_layer_tree"); |
- RunCalcDrawProps(); |
-} |
- |
-TEST_F(CalcDrawPropsTest, TouchRegionLight) { |
- SetTestName("touch_region_light"); |
- ReadTestFile("touch_region_light"); |
- RunCalcDrawProps(); |
-} |
- |
-TEST_F(CalcDrawPropsTest, TouchRegionHeavy) { |
- SetTestName("touch_region_heavy"); |
- ReadTestFile("touch_region_heavy"); |
- RunCalcDrawProps(); |
-} |
- |
TEST_F(BspTreePerfTest, LayerSorterCubes) { |
SetTestName("layer_sort_cubes"); |
ReadTestFile("layer_sort_cubes"); |
- RunSortLayers(); |
+ RunTest(CompositorMode::SINGLE_THREADED); |
} |
TEST_F(BspTreePerfTest, LayerSorterRubik) { |
SetTestName("layer_sort_rubik"); |
ReadTestFile("layer_sort_rubik"); |
- RunSortLayers(); |
+ RunTest(CompositorMode::SINGLE_THREADED); |
} |
TEST_F(BspTreePerfTest, BspTreeCubes) { |
SetTestName("bsp_tree_cubes"); |
SetNumberOfDuplicates(1); |
ReadTestFile("layer_sort_cubes"); |
- RunSortLayers(); |
+ RunTest(CompositorMode::SINGLE_THREADED); |
} |
TEST_F(BspTreePerfTest, BspTreeRubik) { |
SetTestName("bsp_tree_rubik"); |
SetNumberOfDuplicates(1); |
ReadTestFile("layer_sort_rubik"); |
- RunSortLayers(); |
+ RunTest(CompositorMode::SINGLE_THREADED); |
} |
TEST_F(BspTreePerfTest, BspTreeCubes_2) { |
SetTestName("bsp_tree_cubes_2"); |
SetNumberOfDuplicates(2); |
ReadTestFile("layer_sort_cubes"); |
- RunSortLayers(); |
+ RunTest(CompositorMode::SINGLE_THREADED); |
} |
TEST_F(BspTreePerfTest, BspTreeCubes_4) { |
SetTestName("bsp_tree_cubes_4"); |
SetNumberOfDuplicates(4); |
ReadTestFile("layer_sort_cubes"); |
- RunSortLayers(); |
+ RunTest(CompositorMode::SINGLE_THREADED); |
} |
} // namespace |