| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "base/command_line.h" | 5 #include "base/command_line.h" |
| 6 #include "base/file_util.h" | 6 #include "base/file_util.h" |
| 7 #include "base/memory/scoped_ptr.h" | 7 #include "base/memory/scoped_ptr.h" |
| 8 #include "base/path_service.h" | 8 #include "base/path_service.h" |
| 9 #include "base/stringprintf.h" | 9 #include "base/stringprintf.h" |
| 10 #include "base/test/trace_event_analyzer.h" | 10 #include "base/test/trace_event_analyzer.h" |
| (...skipping 30 matching lines...) Expand all Loading... |
| 41 using trace_analyzer::TraceEventVector; | 41 using trace_analyzer::TraceEventVector; |
| 42 | 42 |
| 43 namespace { | 43 namespace { |
| 44 | 44 |
| 45 const char kSwapBuffersEvent[] = "SwapBuffers"; | 45 const char kSwapBuffersEvent[] = "SwapBuffers"; |
| 46 const char kAcceleratedCanvasCreationEvent[] = "Canvas2DLayerBridgeCreation"; | 46 const char kAcceleratedCanvasCreationEvent[] = "Canvas2DLayerBridgeCreation"; |
| 47 const char kWebGLCreationEvent[] = "DrawingBufferCreation"; | 47 const char kWebGLCreationEvent[] = "DrawingBufferCreation"; |
| 48 | 48 |
| 49 class GpuFeatureTest : public InProcessBrowserTest { | 49 class GpuFeatureTest : public InProcessBrowserTest { |
| 50 public: | 50 public: |
| 51 GpuFeatureTest() : trace_categories_("test_gpu"), gpu_enabled_(false) {} | 51 GpuFeatureTest() : category_patterns_("test_gpu"), gpu_enabled_(false) {} |
| 52 | 52 |
| 53 virtual void SetUpInProcessBrowserTestFixture() OVERRIDE { | 53 virtual void SetUpInProcessBrowserTestFixture() OVERRIDE { |
| 54 base::FilePath test_dir; | 54 base::FilePath test_dir; |
| 55 ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &test_dir)); | 55 ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &test_dir)); |
| 56 gpu_test_dir_ = test_dir.AppendASCII("gpu"); | 56 gpu_test_dir_ = test_dir.AppendASCII("gpu"); |
| 57 } | 57 } |
| 58 | 58 |
| 59 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 59 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
| 60 // Do not use mesa if real GPU is required. | 60 // Do not use mesa if real GPU is required. |
| 61 if (!command_line->HasSwitch(switches::kUseGpuInTests)) { | 61 if (!command_line->HasSwitch(switches::kUseGpuInTests)) { |
| (...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 118 // Bypass tests on GPU Linux Debug bots. | 118 // Bypass tests on GPU Linux Debug bots. |
| 119 if (gpu_enabled_) | 119 if (gpu_enabled_) |
| 120 return; | 120 return; |
| 121 #endif | 121 #endif |
| 122 #if defined(OS_MACOSX) | 122 #if defined(OS_MACOSX) |
| 123 // Bypass tests on Mac OSX 10.5 bots (IOSurfaceSupport is now required). | 123 // Bypass tests on Mac OSX 10.5 bots (IOSurfaceSupport is now required). |
| 124 if (!IOSurfaceSupport::Initialize()) | 124 if (!IOSurfaceSupport::Initialize()) |
| 125 return; | 125 return; |
| 126 #endif | 126 #endif |
| 127 | 127 |
| 128 ASSERT_TRUE(tracing::BeginTracing(trace_categories_)); | 128 ASSERT_TRUE(tracing::BeginTracing(category_patterns_)); |
| 129 | 129 |
| 130 // Have to use a new tab for the blacklist to work. | 130 // Have to use a new tab for the blacklist to work. |
| 131 RunTest(url, NULL, true); | 131 RunTest(url, NULL, true); |
| 132 | 132 |
| 133 ASSERT_TRUE(tracing::EndTracing(&trace_events_json_)); | 133 ASSERT_TRUE(tracing::EndTracing(&trace_events_json_)); |
| 134 | 134 |
| 135 analyzer_.reset(TraceAnalyzer::Create(trace_events_json_)); | 135 analyzer_.reset(TraceAnalyzer::Create(trace_events_json_)); |
| 136 analyzer_->AssociateBeginEndEvents(); | 136 analyzer_->AssociateBeginEndEvents(); |
| 137 TraceEventVector events; | 137 TraceEventVector events; |
| 138 | 138 |
| 139 if (!event_name) | 139 if (!event_name) |
| 140 return; | 140 return; |
| 141 | 141 |
| 142 size_t event_count = | 142 size_t event_count = |
| 143 analyzer_->FindEvents(Query::EventNameIs(event_name), &events); | 143 analyzer_->FindEvents(Query::EventNameIs(event_name), &events); |
| 144 | 144 |
| 145 if (event_expected) | 145 if (event_expected) |
| 146 EXPECT_GT(event_count, 0U); | 146 EXPECT_GT(event_count, 0U); |
| 147 else | 147 else |
| 148 EXPECT_EQ(event_count, 0U); | 148 EXPECT_EQ(event_count, 0U); |
| 149 } | 149 } |
| 150 | 150 |
| 151 // Trigger a resize of the chrome window, and use tracing to wait for the | 151 // Trigger a resize of the chrome window, and use tracing to wait for the |
| 152 // given |wait_event|. | 152 // given |wait_event|. |
| 153 bool ResizeAndWait(const gfx::Rect& new_bounds, | 153 bool ResizeAndWait(const gfx::Rect& new_bounds, |
| 154 const char* trace_categories, | 154 const char* category_patterns, |
| 155 const char* wait_category, | 155 const char* wait_category, |
| 156 const char* wait_event) { | 156 const char* wait_event) { |
| 157 if (!tracing::BeginTracingWithWatch(trace_categories, wait_category, | 157 if (!tracing::BeginTracingWithWatch(category_patterns, wait_category, |
| 158 wait_event, 1)) | 158 wait_event, 1)) |
| 159 return false; | 159 return false; |
| 160 browser()->window()->SetBounds(new_bounds); | 160 browser()->window()->SetBounds(new_bounds); |
| 161 if (!tracing::WaitForWatchEvent(base::TimeDelta())) | 161 if (!tracing::WaitForWatchEvent(base::TimeDelta())) |
| 162 return false; | 162 return false; |
| 163 if (!tracing::EndTracing(&trace_events_json_)) | 163 if (!tracing::EndTracing(&trace_events_json_)) |
| 164 return false; | 164 return false; |
| 165 analyzer_.reset(TraceAnalyzer::Create(trace_events_json_)); | 165 analyzer_.reset(TraceAnalyzer::Create(trace_events_json_)); |
| 166 analyzer_->AssociateBeginEndEvents(); | 166 analyzer_->AssociateBeginEndEvents(); |
| 167 return true; | 167 return true; |
| 168 } | 168 } |
| 169 | 169 |
| 170 protected: | 170 protected: |
| 171 base::FilePath gpu_test_dir_; | 171 base::FilePath gpu_test_dir_; |
| 172 scoped_ptr<TraceAnalyzer> analyzer_; | 172 scoped_ptr<TraceAnalyzer> analyzer_; |
| 173 std::string trace_categories_; | 173 std::string category_patterns_; |
| 174 std::string trace_events_json_; | 174 std::string trace_events_json_; |
| 175 bool gpu_enabled_; | 175 bool gpu_enabled_; |
| 176 }; | 176 }; |
| 177 | 177 |
| 178 #if defined(OS_WIN) | 178 #if defined(OS_WIN) |
| 179 // This test is flaky on Windows. http://crbug.com/177113 | 179 // This test is flaky on Windows. http://crbug.com/177113 |
| 180 #define MAYBE_AcceleratedCompositingAllowed DISABLED_AcceleratedCompositingAllow
ed | 180 #define MAYBE_AcceleratedCompositingAllowed DISABLED_AcceleratedCompositingAllow
ed |
| 181 #else | 181 #else |
| 182 #define MAYBE_AcceleratedCompositingAllowed AcceleratedCompositingAllowed | 182 #define MAYBE_AcceleratedCompositingAllowed AcceleratedCompositingAllowed |
| 183 #endif | 183 #endif |
| (...skipping 257 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 441 } | 441 } |
| 442 | 442 |
| 443 | 443 |
| 444 #if defined(OS_WIN) || defined(OS_CHROMEOS) || defined(OS_MACOSX) | 444 #if defined(OS_WIN) || defined(OS_CHROMEOS) || defined(OS_MACOSX) |
| 445 // http://crbug.com/162343: flaky on Windows and Mac, failing on ChromiumOS. | 445 // http://crbug.com/162343: flaky on Windows and Mac, failing on ChromiumOS. |
| 446 #define MAYBE_RafNoDamage DISABLED_RafNoDamage | 446 #define MAYBE_RafNoDamage DISABLED_RafNoDamage |
| 447 #else | 447 #else |
| 448 #define MAYBE_RafNoDamage RafNoDamage | 448 #define MAYBE_RafNoDamage RafNoDamage |
| 449 #endif | 449 #endif |
| 450 IN_PROC_BROWSER_TEST_F(GpuFeatureTest, MAYBE_RafNoDamage) { | 450 IN_PROC_BROWSER_TEST_F(GpuFeatureTest, MAYBE_RafNoDamage) { |
| 451 trace_categories_ = "-test_*"; | 451 category_patterns_ = "-test_*"; |
| 452 const base::FilePath url(FILE_PATH_LITERAL("feature_raf_no_damage.html")); | 452 const base::FilePath url(FILE_PATH_LITERAL("feature_raf_no_damage.html")); |
| 453 RunEventTest(url); | 453 RunEventTest(url); |
| 454 | 454 |
| 455 if (!analyzer_.get()) | 455 if (!analyzer_.get()) |
| 456 return; | 456 return; |
| 457 | 457 |
| 458 // Search for matching name on begin event or async_begin event (any begin). | 458 // Search for matching name on begin event or async_begin event (any begin). |
| 459 Query query_raf = | 459 Query query_raf = |
| 460 (Query::EventPhaseIs(TRACE_EVENT_PHASE_BEGIN) || | 460 (Query::EventPhaseIs(TRACE_EVENT_PHASE_BEGIN) || |
| 461 Query::EventPhaseIs(TRACE_EVENT_PHASE_ASYNC_BEGIN)) && | 461 Query::EventPhaseIs(TRACE_EVENT_PHASE_ASYNC_BEGIN)) && |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 550 base::StringPrintf( | 550 base::StringPrintf( |
| 551 "%d (resize offset %d): IOSurface width %d -> %d; Creates %d " | 551 "%d (resize offset %d): IOSurface width %d -> %d; Creates %d " |
| 552 "Expected %d", offset_i, offsets[offset_i], | 552 "Expected %d", offset_i, offsets[offset_i], |
| 553 old_width, new_width, num_creates, expected_creates); | 553 old_width, new_width, num_creates, expected_creates); |
| 554 } | 554 } |
| 555 } | 555 } |
| 556 } | 556 } |
| 557 #endif | 557 #endif |
| 558 | 558 |
| 559 } // namespace anonymous | 559 } // namespace anonymous |
| OLD | NEW |