OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 // Tests for the Command Buffer Helper. | 5 // Tests for the Command Buffer Helper. |
6 | 6 |
7 #include "base/callback.h" | 7 #include "base/callback.h" |
8 #include "base/message_loop.h" | 8 #include "base/message_loop.h" |
9 #include "gpu/command_buffer/client/cmd_buffer_helper.h" | 9 #include "gpu/command_buffer/client/cmd_buffer_helper.h" |
10 #include "gpu/command_buffer/service/mocks.h" | 10 #include "gpu/command_buffer/service/mocks.h" |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
58 }; | 58 }; |
59 | 59 |
60 virtual void SetUp() { | 60 virtual void SetUp() { |
61 api_mock_.reset(new AsyncAPIMock); | 61 api_mock_.reset(new AsyncAPIMock); |
62 // ignore noops in the mock - we don't want to inspect the internals of the | 62 // ignore noops in the mock - we don't want to inspect the internals of the |
63 // helper. | 63 // helper. |
64 EXPECT_CALL(*api_mock_, DoCommand(cmd::kNoop, _, _)) | 64 EXPECT_CALL(*api_mock_, DoCommand(cmd::kNoop, _, _)) |
65 .WillRepeatedly(Return(error::kNoError)); | 65 .WillRepeatedly(Return(error::kNoError)); |
66 | 66 |
67 command_buffer_.reset(new CommandBufferService); | 67 command_buffer_.reset(new CommandBufferService); |
68 command_buffer_->Initialize(kCommandBufferSizeBytes); | 68 command_buffer_->Initialize(); |
69 Buffer ring_buffer = command_buffer_->GetRingBuffer(); | |
70 | 69 |
71 parser_ = new CommandParser(ring_buffer.ptr, | 70 parser_ = new CommandParser(api_mock_.get()); |
72 ring_buffer.size, | |
73 0, | |
74 ring_buffer.size, | |
75 0, | |
76 api_mock_.get()); | |
77 | 71 |
78 do_jump_command_.reset(new DoJumpCommand(parser_)); | 72 do_jump_command_.reset(new DoJumpCommand(parser_)); |
79 EXPECT_CALL(*api_mock_, DoCommand(cmd::kJump, _, _)) | 73 EXPECT_CALL(*api_mock_, DoCommand(cmd::kJump, _, _)) |
80 .WillRepeatedly( | 74 .WillRepeatedly( |
81 Invoke(do_jump_command_.get(), &DoJumpCommand::DoCommand)); | 75 Invoke(do_jump_command_.get(), &DoJumpCommand::DoCommand)); |
82 | 76 |
83 gpu_scheduler_.reset(new GpuScheduler( | 77 gpu_scheduler_.reset(new GpuScheduler( |
84 command_buffer_.get(), NULL, parser_)); | 78 command_buffer_.get(), NULL, parser_)); |
85 command_buffer_->SetPutOffsetChangeCallback(NewCallback( | 79 command_buffer_->SetPutOffsetChangeCallback(NewCallback( |
86 gpu_scheduler_.get(), &GpuScheduler::PutChanged)); | 80 gpu_scheduler_.get(), &GpuScheduler::PutChanged)); |
87 | 81 |
88 api_mock_->set_engine(gpu_scheduler_.get()); | 82 api_mock_->set_engine(gpu_scheduler_.get()); |
89 | 83 |
90 helper_.reset(new CommandBufferHelper(command_buffer_.get())); | 84 helper_.reset(new CommandBufferHelper(command_buffer_.get())); |
91 helper_->Initialize(kCommandBufferSizeBytes); | 85 helper_->Initialize(kCommandBufferSizeBytes); |
| 86 |
| 87 // Note: parser->SetBuffer would normally be called through |
| 88 // helper_->Initialize but currently it needs a GpuCommandBufferStub as the |
| 89 // CommandBuffer instead of the CommandBufferService for that to happen. |
| 90 Buffer ring_buffer = helper_->get_ring_buffer(); |
| 91 parser_->SetBuffer(ring_buffer.ptr, ring_buffer.size, 0, ring_buffer.size); |
92 } | 92 } |
93 | 93 |
94 virtual void TearDown() { | 94 virtual void TearDown() { |
95 // If the GpuScheduler posts any tasks, this forces them to run. | 95 // If the GpuScheduler posts any tasks, this forces them to run. |
96 MessageLoop::current()->RunAllPending(); | 96 MessageLoop::current()->RunAllPending(); |
97 } | 97 } |
98 | 98 |
99 // Adds a command to the buffer through the helper, while adding it as an | 99 // Adds a command to the buffer through the helper, while adding it as an |
100 // expected call on the API mock. | 100 // expected call on the API mock. |
101 void AddCommandWithExpect(error::Error _return, | 101 void AddCommandWithExpect(error::Error _return, |
(...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
302 helper_->Finish(); | 302 helper_->Finish(); |
303 | 303 |
304 // Check that the commands did happen. | 304 // Check that the commands did happen. |
305 Mock::VerifyAndClearExpectations(api_mock_.get()); | 305 Mock::VerifyAndClearExpectations(api_mock_.get()); |
306 | 306 |
307 // Check the error status. | 307 // Check the error status. |
308 EXPECT_EQ(error::kNoError, GetError()); | 308 EXPECT_EQ(error::kNoError, GetError()); |
309 } | 309 } |
310 | 310 |
311 } // namespace gpu | 311 } // namespace gpu |
OLD | NEW |