Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4760)

Unified Diff: cc/resources/tile_task_worker_pool_unittest.cc

Issue 1144693002: cc: Move files out of cc/resources/. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: resources: android Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « cc/resources/tile_task_worker_pool_perftest.cc ('k') | cc/resources/tiling_set_eviction_queue.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/resources/tile_task_worker_pool_unittest.cc
diff --git a/cc/resources/tile_task_worker_pool_unittest.cc b/cc/resources/tile_task_worker_pool_unittest.cc
deleted file mode 100644
index 34de309356a6556713b0ffc7c8be2d6514da75d6..0000000000000000000000000000000000000000
--- a/cc/resources/tile_task_worker_pool_unittest.cc
+++ /dev/null
@@ -1,442 +0,0 @@
-// Copyright 2013 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.
-
-#include "cc/resources/tile_task_worker_pool.h"
-
-#include <limits>
-#include <vector>
-
-#include "base/cancelable_callback.h"
-#include "base/location.h"
-#include "base/single_thread_task_runner.h"
-#include "base/thread_task_runner_handle.h"
-#include "cc/base/unique_notifier.h"
-#include "cc/resources/bitmap_tile_task_worker_pool.h"
-#include "cc/resources/gpu_rasterizer.h"
-#include "cc/resources/gpu_tile_task_worker_pool.h"
-#include "cc/resources/one_copy_tile_task_worker_pool.h"
-#include "cc/resources/picture_pile.h"
-#include "cc/resources/picture_pile_impl.h"
-#include "cc/resources/pixel_buffer_tile_task_worker_pool.h"
-#include "cc/resources/raster_buffer.h"
-#include "cc/resources/resource_pool.h"
-#include "cc/resources/resource_provider.h"
-#include "cc/resources/scoped_resource.h"
-#include "cc/resources/tile_task_runner.h"
-#include "cc/resources/zero_copy_tile_task_worker_pool.h"
-#include "cc/test/fake_output_surface.h"
-#include "cc/test/fake_output_surface_client.h"
-#include "cc/test/fake_picture_pile_impl.h"
-#include "cc/test/test_gpu_memory_buffer_manager.h"
-#include "cc/test/test_shared_bitmap_manager.h"
-#include "cc/test/test_task_graph_runner.h"
-#include "cc/test/test_web_graphics_context_3d.h"
-#include "gpu/GLES2/gl2extchromium.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-namespace cc {
-namespace {
-
-const size_t kMaxTransferBufferUsageBytes = 10000U;
-// A resource of this dimension^2 * 4 must be greater than the above transfer
-// buffer constant.
-const size_t kLargeResourceDimension = 1000U;
-
-enum TileTaskWorkerPoolType {
- TILE_TASK_WORKER_POOL_TYPE_PIXEL_BUFFER,
- TILE_TASK_WORKER_POOL_TYPE_ZERO_COPY,
- TILE_TASK_WORKER_POOL_TYPE_ONE_COPY,
- TILE_TASK_WORKER_POOL_TYPE_GPU,
- TILE_TASK_WORKER_POOL_TYPE_BITMAP
-};
-
-class TestRasterTaskImpl : public RasterTask {
- public:
- typedef base::Callback<void(const RasterSource::SolidColorAnalysis& analysis,
- bool was_canceled)> Reply;
-
- TestRasterTaskImpl(const Resource* resource,
- const Reply& reply,
- ImageDecodeTask::Vector* dependencies)
- : RasterTask(resource, dependencies),
- reply_(reply),
- picture_pile_(FakePicturePileImpl::CreateEmptyPile(gfx::Size(1, 1),
- gfx::Size(1, 1))) {}
-
- // Overridden from Task:
- void RunOnWorkerThread() override {
- raster_buffer_->Playback(picture_pile_.get(), gfx::Rect(0, 0, 1, 1), 1.0);
- }
-
- // Overridden from TileTask:
- void ScheduleOnOriginThread(TileTaskClient* client) override {
- raster_buffer_ = client->AcquireBufferForRaster(resource());
- }
- void CompleteOnOriginThread(TileTaskClient* client) override {
- client->ReleaseBufferForRaster(raster_buffer_.Pass());
- }
- void RunReplyOnOriginThread() override {
- reply_.Run(RasterSource::SolidColorAnalysis(), !HasFinishedRunning());
- }
-
- protected:
- ~TestRasterTaskImpl() override {}
-
- private:
- const Reply reply_;
- scoped_ptr<RasterBuffer> raster_buffer_;
- scoped_refptr<PicturePileImpl> picture_pile_;
-
- DISALLOW_COPY_AND_ASSIGN(TestRasterTaskImpl);
-};
-
-class BlockingTestRasterTaskImpl : public TestRasterTaskImpl {
- public:
- BlockingTestRasterTaskImpl(const Resource* resource,
- const Reply& reply,
- base::Lock* lock,
- ImageDecodeTask::Vector* dependencies)
- : TestRasterTaskImpl(resource, reply, dependencies), lock_(lock) {}
-
- // Overridden from Task:
- void RunOnWorkerThread() override {
- base::AutoLock lock(*lock_);
- TestRasterTaskImpl::RunOnWorkerThread();
- }
-
- // Overridden from TileTask:
- void RunReplyOnOriginThread() override {}
-
- protected:
- ~BlockingTestRasterTaskImpl() override {}
-
- private:
- base::Lock* lock_;
-
- DISALLOW_COPY_AND_ASSIGN(BlockingTestRasterTaskImpl);
-};
-
-class TileTaskWorkerPoolTest
- : public testing::TestWithParam<TileTaskWorkerPoolType>,
- public TileTaskRunnerClient {
- public:
- struct RasterTaskResult {
- unsigned id;
- bool canceled;
- };
-
- typedef std::vector<scoped_refptr<RasterTask>> RasterTaskVector;
-
- enum NamedTaskSet { REQUIRED_FOR_ACTIVATION, REQUIRED_FOR_DRAW, ALL };
-
- TileTaskWorkerPoolTest()
- : context_provider_(TestContextProvider::Create()),
- worker_context_provider_(TestContextProvider::Create()),
- all_tile_tasks_finished_(
- base::ThreadTaskRunnerHandle::Get().get(),
- base::Bind(&TileTaskWorkerPoolTest::AllTileTasksFinished,
- base::Unretained(this))),
- timeout_seconds_(5),
- timed_out_(false) {}
-
- // Overridden from testing::Test:
- void SetUp() override {
- switch (GetParam()) {
- case TILE_TASK_WORKER_POOL_TYPE_PIXEL_BUFFER:
- Create3dOutputSurfaceAndResourceProvider();
- tile_task_worker_pool_ = PixelBufferTileTaskWorkerPool::Create(
- base::ThreadTaskRunnerHandle::Get().get(), &task_graph_runner_,
- context_provider_.get(), resource_provider_.get(),
- kMaxTransferBufferUsageBytes);
- break;
- case TILE_TASK_WORKER_POOL_TYPE_ZERO_COPY:
- Create3dOutputSurfaceAndResourceProvider();
- tile_task_worker_pool_ = ZeroCopyTileTaskWorkerPool::Create(
- base::ThreadTaskRunnerHandle::Get().get(), &task_graph_runner_,
- resource_provider_.get());
- break;
- case TILE_TASK_WORKER_POOL_TYPE_ONE_COPY:
- Create3dOutputSurfaceAndResourceProvider();
- staging_resource_pool_ = ResourcePool::Create(resource_provider_.get(),
- GL_TEXTURE_2D);
- tile_task_worker_pool_ = OneCopyTileTaskWorkerPool::Create(
- base::ThreadTaskRunnerHandle::Get().get(), &task_graph_runner_,
- context_provider_.get(), resource_provider_.get(),
- staging_resource_pool_.get());
- break;
- case TILE_TASK_WORKER_POOL_TYPE_GPU:
- Create3dOutputSurfaceAndResourceProvider();
- tile_task_worker_pool_ = GpuTileTaskWorkerPool::Create(
- base::ThreadTaskRunnerHandle::Get().get(), &task_graph_runner_,
- context_provider_.get(), resource_provider_.get(), false, 0);
- break;
- case TILE_TASK_WORKER_POOL_TYPE_BITMAP:
- CreateSoftwareOutputSurfaceAndResourceProvider();
- tile_task_worker_pool_ = BitmapTileTaskWorkerPool::Create(
- base::ThreadTaskRunnerHandle::Get().get(), &task_graph_runner_,
- resource_provider_.get());
- break;
- }
-
- DCHECK(tile_task_worker_pool_);
- tile_task_worker_pool_->AsTileTaskRunner()->SetClient(this);
- }
-
- void TearDown() override {
- tile_task_worker_pool_->AsTileTaskRunner()->Shutdown();
- tile_task_worker_pool_->AsTileTaskRunner()->CheckForCompletedTasks();
- }
-
- void AllTileTasksFinished() {
- tile_task_worker_pool_->AsTileTaskRunner()->CheckForCompletedTasks();
- base::MessageLoop::current()->Quit();
- }
-
- // Overriden from TileTaskWorkerPoolClient:
- void DidFinishRunningTileTasks(TaskSet task_set) override {
- EXPECT_FALSE(completed_task_sets_[task_set]);
- completed_task_sets_[task_set] = true;
- if (task_set == ALL) {
- EXPECT_TRUE((~completed_task_sets_).none());
- all_tile_tasks_finished_.Schedule();
- }
- }
-
- TaskSetCollection TasksThatShouldBeForcedToComplete() const override {
- return TaskSetCollection();
- }
-
- void RunMessageLoopUntilAllTasksHaveCompleted() {
- if (timeout_seconds_) {
- timeout_.Reset(base::Bind(&TileTaskWorkerPoolTest::OnTimeout,
- base::Unretained(this)));
- base::ThreadTaskRunnerHandle::Get()->PostDelayedTask(
- FROM_HERE, timeout_.callback(),
- base::TimeDelta::FromSeconds(timeout_seconds_));
- }
-
- base::MessageLoop::current()->Run();
-
- timeout_.Cancel();
-
- ASSERT_FALSE(timed_out_) << "Test timed out";
- }
-
- void ScheduleTasks() {
- TileTaskQueue queue;
-
- for (RasterTaskVector::const_iterator it = tasks_.begin();
- it != tasks_.end(); ++it) {
- TaskSetCollection task_sets;
- task_sets[REQUIRED_FOR_ACTIVATION] = true;
- task_sets[REQUIRED_FOR_DRAW] = true;
- task_sets[ALL] = true;
- queue.items.push_back(TileTaskQueue::Item(it->get(), task_sets));
- }
-
- completed_task_sets_.reset();
- tile_task_worker_pool_->AsTileTaskRunner()->ScheduleTasks(&queue);
- }
-
- void AppendTask(unsigned id, const gfx::Size& size) {
- scoped_ptr<ScopedResource> resource(
- ScopedResource::Create(resource_provider_.get()));
- resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE,
- RGBA_8888);
- const Resource* const_resource = resource.get();
-
- ImageDecodeTask::Vector empty;
- tasks_.push_back(new TestRasterTaskImpl(
- const_resource,
- base::Bind(&TileTaskWorkerPoolTest::OnTaskCompleted,
- base::Unretained(this), base::Passed(&resource), id),
- &empty));
- }
-
- void AppendTask(unsigned id) { AppendTask(id, gfx::Size(1, 1)); }
-
- void AppendBlockingTask(unsigned id, base::Lock* lock) {
- const gfx::Size size(1, 1);
-
- scoped_ptr<ScopedResource> resource(
- ScopedResource::Create(resource_provider_.get()));
- resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE,
- RGBA_8888);
- const Resource* const_resource = resource.get();
-
- ImageDecodeTask::Vector empty;
- tasks_.push_back(new BlockingTestRasterTaskImpl(
- const_resource,
- base::Bind(&TileTaskWorkerPoolTest::OnTaskCompleted,
- base::Unretained(this), base::Passed(&resource), id),
- lock, &empty));
- }
-
- const std::vector<RasterTaskResult>& completed_tasks() const {
- return completed_tasks_;
- }
-
- void LoseContext(ContextProvider* context_provider) {
- if (!context_provider)
- return;
- context_provider->ContextGL()->LoseContextCHROMIUM(
- GL_GUILTY_CONTEXT_RESET_ARB, GL_INNOCENT_CONTEXT_RESET_ARB);
- context_provider->ContextGL()->Flush();
- }
-
- private:
- void Create3dOutputSurfaceAndResourceProvider() {
- output_surface_ = FakeOutputSurface::Create3d(
- context_provider_, worker_context_provider_).Pass();
- CHECK(output_surface_->BindToClient(&output_surface_client_));
- TestWebGraphicsContext3D* context3d = context_provider_->TestContext3d();
- context3d->set_support_sync_query(true);
- resource_provider_ = ResourceProvider::Create(output_surface_.get(), NULL,
- &gpu_memory_buffer_manager_,
- NULL, 0, false, 1).Pass();
- }
-
- void CreateSoftwareOutputSurfaceAndResourceProvider() {
- output_surface_ = FakeOutputSurface::CreateSoftware(
- make_scoped_ptr(new SoftwareOutputDevice));
- CHECK(output_surface_->BindToClient(&output_surface_client_));
- resource_provider_ =
- ResourceProvider::Create(output_surface_.get(), &shared_bitmap_manager_,
- NULL, NULL, 0, false, 1).Pass();
- }
-
- void OnTaskCompleted(scoped_ptr<ScopedResource> resource,
- unsigned id,
- const RasterSource::SolidColorAnalysis& analysis,
- bool was_canceled) {
- RasterTaskResult result;
- result.id = id;
- result.canceled = was_canceled;
- completed_tasks_.push_back(result);
- }
-
- void OnTimeout() {
- timed_out_ = true;
- base::MessageLoop::current()->Quit();
- }
-
- protected:
- scoped_refptr<TestContextProvider> context_provider_;
- scoped_refptr<TestContextProvider> worker_context_provider_;
- FakeOutputSurfaceClient output_surface_client_;
- scoped_ptr<FakeOutputSurface> output_surface_;
- scoped_ptr<ResourceProvider> resource_provider_;
- scoped_ptr<ResourcePool> staging_resource_pool_;
- scoped_ptr<TileTaskWorkerPool> tile_task_worker_pool_;
- TestGpuMemoryBufferManager gpu_memory_buffer_manager_;
- TestSharedBitmapManager shared_bitmap_manager_;
- TestTaskGraphRunner task_graph_runner_;
- base::CancelableClosure timeout_;
- UniqueNotifier all_tile_tasks_finished_;
- int timeout_seconds_;
- bool timed_out_;
- RasterTaskVector tasks_;
- std::vector<RasterTaskResult> completed_tasks_;
- TaskSetCollection completed_task_sets_;
-};
-
-TEST_P(TileTaskWorkerPoolTest, Basic) {
- AppendTask(0u);
- AppendTask(1u);
- ScheduleTasks();
-
- RunMessageLoopUntilAllTasksHaveCompleted();
-
- ASSERT_EQ(2u, completed_tasks().size());
- EXPECT_FALSE(completed_tasks()[0].canceled);
- EXPECT_FALSE(completed_tasks()[1].canceled);
-}
-
-TEST_P(TileTaskWorkerPoolTest, FailedMapResource) {
- if (GetParam() == TILE_TASK_WORKER_POOL_TYPE_BITMAP)
- return;
-
- TestWebGraphicsContext3D* context3d = context_provider_->TestContext3d();
- context3d->set_times_map_buffer_chromium_succeeds(0);
- AppendTask(0u);
- ScheduleTasks();
-
- RunMessageLoopUntilAllTasksHaveCompleted();
-
- ASSERT_EQ(1u, completed_tasks().size());
- EXPECT_FALSE(completed_tasks()[0].canceled);
-}
-
-// This test checks that replacing a pending raster task with another does
-// not prevent the DidFinishRunningTileTasks notification from being sent.
-TEST_P(TileTaskWorkerPoolTest, FalseThrottling) {
- base::Lock lock;
-
- // Schedule a task that is prevented from completing with a lock.
- lock.Acquire();
- AppendBlockingTask(0u, &lock);
- ScheduleTasks();
-
- // Schedule another task to replace the still-pending task. Because the old
- // task is not a throttled task in the new task set, it should not prevent
- // DidFinishRunningTileTasks from getting signaled.
- RasterTaskVector tasks;
- tasks.swap(tasks_);
- AppendTask(1u);
- ScheduleTasks();
-
- // Unblock the first task to allow the second task to complete.
- lock.Release();
-
- RunMessageLoopUntilAllTasksHaveCompleted();
-}
-
-TEST_P(TileTaskWorkerPoolTest, LargeResources) {
- gfx::Size size(kLargeResourceDimension, kLargeResourceDimension);
-
- {
- // Verify a resource of this size is larger than the transfer buffer.
- scoped_ptr<ScopedResource> resource(
- ScopedResource::Create(resource_provider_.get()));
- resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE,
- RGBA_8888);
- EXPECT_GE(resource->bytes(), kMaxTransferBufferUsageBytes);
- }
-
- AppendTask(0u, size);
- AppendTask(1u, size);
- AppendTask(2u, size);
- ScheduleTasks();
-
- // This will time out if a resource that is larger than the throttle limit
- // never gets scheduled.
- RunMessageLoopUntilAllTasksHaveCompleted();
-}
-
-TEST_P(TileTaskWorkerPoolTest, LostContext) {
- LoseContext(output_surface_->context_provider());
- LoseContext(output_surface_->worker_context_provider());
-
- AppendTask(0u);
- AppendTask(1u);
- ScheduleTasks();
-
- RunMessageLoopUntilAllTasksHaveCompleted();
-
- ASSERT_EQ(2u, completed_tasks().size());
- EXPECT_FALSE(completed_tasks()[0].canceled);
- EXPECT_FALSE(completed_tasks()[1].canceled);
-}
-
-INSTANTIATE_TEST_CASE_P(
- TileTaskWorkerPoolTests,
- TileTaskWorkerPoolTest,
- ::testing::Values(TILE_TASK_WORKER_POOL_TYPE_PIXEL_BUFFER,
- TILE_TASK_WORKER_POOL_TYPE_ZERO_COPY,
- TILE_TASK_WORKER_POOL_TYPE_ONE_COPY,
- TILE_TASK_WORKER_POOL_TYPE_GPU,
- TILE_TASK_WORKER_POOL_TYPE_BITMAP));
-
-} // namespace
-} // namespace cc
« no previous file with comments | « cc/resources/tile_task_worker_pool_perftest.cc ('k') | cc/resources/tiling_set_eviction_queue.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698