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

Side by Side Diff: ui/aura/test/mus/test_context_factory.cc

Issue 2752303002: views/mus: Install a mus-friend ContextFactory for tests. (Closed)
Patch Set: . Created 3 years, 9 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2017 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 "ui/aura/test/mus/test_context_factory.h"
6
7 #include "base/threading/thread_task_runner_handle.h"
8 #include "cc/output/compositor_frame.h"
9 #include "cc/output/compositor_frame_sink_client.h"
10 #include "cc/scheduler/begin_frame_source.h"
11 #include "cc/scheduler/delay_based_time_source.h"
12 #include "cc/test/fake_compositor_frame_sink.h"
13
14 namespace aura {
15 namespace test {
16
17 namespace {
18
19 class FakeCompositorFrameSink : public cc::FakeCompositorFrameSink {
danakj 2017/03/17 14:10:57 Can this be cc/test/'s FakeCompositorFrameSink?
sadrul 2017/03/17 15:31:11 cc/test's FakeCompositorFrameSink does not install
danakj 2017/03/17 15:33:14 Ya sure! My high level theology here is that one f
sadrul 2017/03/17 16:50:29 Done.
20 public:
21 FakeCompositorFrameSink()
22 : cc::FakeCompositorFrameSink(cc::TestContextProvider::Create(),
23 cc::TestContextProvider::CreateWorker()) {}
24 ~FakeCompositorFrameSink() override = default;
25
26 private:
27 // cc::FakeCompositorFrameSink:
28 bool BindToClient(cc::CompositorFrameSinkClient* client) override {
29 if (!cc::FakeCompositorFrameSink::BindToClient(client))
30 return false;
31 begin_frame_source_ = base::MakeUnique<cc::BackToBackBeginFrameSource>(
32 base::MakeUnique<cc::DelayBasedTimeSource>(
33 base::ThreadTaskRunnerHandle::Get().get()));
34 client_->SetBeginFrameSource(begin_frame_source_.get());
35 return true;
36 }
37
38 std::unique_ptr<cc::BeginFrameSource> begin_frame_source_;
39
40 DISALLOW_COPY_AND_ASSIGN(FakeCompositorFrameSink);
41 };
42
43 } // namespace
44
45 const cc::CompositorFrame& TestContextFactory::GetLastCompositorFrame() const {
46 return *frame_sink_->last_sent_frame();
47 }
48
49 void TestContextFactory::CreateCompositorFrameSink(
danakj 2017/03/17 14:10:57 Can you put this in ui/compositor/test/ so we don'
sadrul 2017/03/17 16:50:29 Done.
50 base::WeakPtr<ui::Compositor> compositor) {
51 auto frame_sink = base::MakeUnique<FakeCompositorFrameSink>();
52 frame_sink_ = frame_sink.get();
53 compositor->SetCompositorFrameSink(std::move(frame_sink));
54 }
55
56 scoped_refptr<cc::ContextProvider>
57 TestContextFactory::SharedMainThreadContextProvider() {
58 return nullptr;
59 }
60
61 void TestContextFactory::RemoveCompositor(ui::Compositor* compositor) {
62 frame_sink_ = nullptr;
63 }
64
65 bool TestContextFactory::DoesCreateTestContexts() {
66 return true;
67 }
68
69 uint32_t TestContextFactory::GetImageTextureTarget(gfx::BufferFormat format,
70 gfx::BufferUsage usage) {
71 return GL_TEXTURE_2D;
72 }
73
74 gpu::GpuMemoryBufferManager* TestContextFactory::GetGpuMemoryBufferManager() {
75 return &gpu_memory_buffer_manager_;
76 }
77
78 cc::TaskGraphRunner* TestContextFactory::GetTaskGraphRunner() {
79 return &task_graph_runner_;
80 }
81
82 void TestContextFactory::AddObserver(ui::ContextFactoryObserver* observer) {}
83 void TestContextFactory::RemoveObserver(ui::ContextFactoryObserver* observer) {}
84
85 } // namespace test
86 } // namespace aura
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698