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

Side by Side Diff: content/common/gpu/gpu_channel_manager_unittest.cc

Issue 1365563002: Make channel preemption not require view contexts for hookup (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@wakeup_gpu
Patch Set: rebase Created 5 years, 2 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
« no previous file with comments | « content/common/gpu/gpu_channel_manager.cc ('k') | content/common/gpu/gpu_channel_test_common.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2014 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2014 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 "content/common/gpu/gpu_channel.h" 5 #include "content/common/gpu/gpu_channel.h"
6 #include "content/common/gpu/gpu_channel_manager.h" 6 #include "content/common/gpu/gpu_channel_manager.h"
7 #include "content/common/gpu/gpu_channel_test_common.h" 7 #include "content/common/gpu/gpu_channel_test_common.h"
8 #include "content/common/gpu/gpu_messages.h" 8 #include "content/common/gpu/gpu_messages.h"
9 #include "gpu/command_buffer/common/value_state.h" 9 #include "gpu/command_buffer/common/value_state.h"
10 #include "gpu/command_buffer/service/gl_utils.h" 10 #include "gpu/command_buffer/service/gl_utils.h"
(...skipping 10 matching lines...) Expand all
21 GpuChannelManagerTest() : GpuChannelTestCommon() {} 21 GpuChannelManagerTest() : GpuChannelTestCommon() {}
22 ~GpuChannelManagerTest() override {} 22 ~GpuChannelManagerTest() override {}
23 }; 23 };
24 24
25 TEST_F(GpuChannelManagerTest, EstablishChannel) { 25 TEST_F(GpuChannelManagerTest, EstablishChannel) {
26 int32 kClientId = 1; 26 int32 kClientId = 1;
27 uint64 kClientTracingId = 1; 27 uint64 kClientTracingId = 1;
28 28
29 ASSERT_TRUE(channel_manager()); 29 ASSERT_TRUE(channel_manager());
30 30
31 EXPECT_TRUE(channel_manager()->OnMessageReceived(GpuMsg_EstablishChannel( 31 GpuMsg_EstablishChannel_Params params;
32 kClientId, kClientTracingId, false, false, false))); 32 params.client_id = kClientId;
33 params.client_tracing_id = kClientTracingId;
34 params.preempts = false;
35 params.preempted = false;
36 params.allow_future_sync_points = false;
37 params.allow_real_time_streams = false;
38 EXPECT_TRUE(
39 channel_manager()->OnMessageReceived(GpuMsg_EstablishChannel(params)));
33 EXPECT_EQ((size_t)1, sink()->message_count()); 40 EXPECT_EQ((size_t)1, sink()->message_count());
34 const IPC::Message* msg = 41 const IPC::Message* msg =
35 sink()->GetUniqueMessageMatching(GpuHostMsg_ChannelEstablished::ID); 42 sink()->GetUniqueMessageMatching(GpuHostMsg_ChannelEstablished::ID);
36 ASSERT_TRUE(msg); 43 ASSERT_TRUE(msg);
37 base::Tuple<IPC::ChannelHandle> handle; 44 base::Tuple<IPC::ChannelHandle> handle;
38 ASSERT_TRUE(GpuHostMsg_ChannelEstablished::Read(msg, &handle)); 45 ASSERT_TRUE(GpuHostMsg_ChannelEstablished::Read(msg, &handle));
39 EXPECT_NE("", base::get<0>(handle).name); 46 EXPECT_NE("", base::get<0>(handle).name);
40 sink()->ClearMessages(); 47 sink()->ClearMessages();
41 48
42 GpuChannel* channel = channel_manager()->LookupChannel(kClientId); 49 GpuChannel* channel = channel_manager()->LookupChannel(kClientId);
(...skipping 13 matching lines...) Expand all
56 value_state1.int_value[3] = 0; 63 value_state1.int_value[3] = 0;
57 ValueState value_state2; 64 ValueState value_state2;
58 value_state2.int_value[0] = 3333; 65 value_state2.int_value[0] = 3333;
59 value_state2.int_value[1] = 0; 66 value_state2.int_value[1] = 0;
60 value_state2.int_value[2] = 0; 67 value_state2.int_value[2] = 0;
61 value_state2.int_value[3] = 0; 68 value_state2.int_value[3] = 0;
62 69
63 ASSERT_TRUE(channel_manager()); 70 ASSERT_TRUE(channel_manager());
64 71
65 // Initialize gpu channels 72 // Initialize gpu channels
66 EXPECT_TRUE(channel_manager()->OnMessageReceived(GpuMsg_EstablishChannel( 73 GpuMsg_EstablishChannel_Params params;
67 kClientId1, kClientTracingId1, false, false, false))); 74 params.client_id = kClientId1;
75 params.client_tracing_id = kClientTracingId1;
76 params.preempts = false;
77 params.preempted = false;
78 params.allow_future_sync_points = false;
79 params.allow_real_time_streams = false;
80 EXPECT_TRUE(
81 channel_manager()->OnMessageReceived(GpuMsg_EstablishChannel(params)));
68 GpuChannel* channel1 = channel_manager()->LookupChannel(kClientId1); 82 GpuChannel* channel1 = channel_manager()->LookupChannel(kClientId1);
69 ASSERT_TRUE(channel1); 83 ASSERT_TRUE(channel1);
70 84
71 EXPECT_TRUE(channel_manager()->OnMessageReceived(GpuMsg_EstablishChannel( 85 params.client_id = kClientId2;
72 kClientId2, kClientTracingId2, false, false, false))); 86 params.client_tracing_id = kClientTracingId2;
87 EXPECT_TRUE(
88 channel_manager()->OnMessageReceived(GpuMsg_EstablishChannel(params)));
73 GpuChannel* channel2 = channel_manager()->LookupChannel(kClientId2); 89 GpuChannel* channel2 = channel_manager()->LookupChannel(kClientId2);
74 ASSERT_TRUE(channel2); 90 ASSERT_TRUE(channel2);
75 91
76 EXPECT_NE(channel1, channel2); 92 EXPECT_NE(channel1, channel2);
77 93
78 // Make sure value states are only accessible by proper channels 94 // Make sure value states are only accessible by proper channels
79 channel_manager()->OnMessageReceived(GpuMsg_UpdateValueState( 95 channel_manager()->OnMessageReceived(GpuMsg_UpdateValueState(
80 kClientId1, GL_MOUSE_POSITION_CHROMIUM, value_state1)); 96 kClientId1, GL_MOUSE_POSITION_CHROMIUM, value_state1));
81 channel_manager()->OnMessageReceived(GpuMsg_UpdateValueState( 97 channel_manager()->OnMessageReceived(GpuMsg_UpdateValueState(
82 kClientId2, GL_MOUSE_POSITION_CHROMIUM, value_state2)); 98 kClientId2, GL_MOUSE_POSITION_CHROMIUM, value_state2));
83 99
84 const gpu::ValueStateMap* pending_value_buffer_state1 = 100 const gpu::ValueStateMap* pending_value_buffer_state1 =
85 channel1->pending_valuebuffer_state(); 101 channel1->pending_valuebuffer_state();
86 const gpu::ValueStateMap* pending_value_buffer_state2 = 102 const gpu::ValueStateMap* pending_value_buffer_state2 =
87 channel2->pending_valuebuffer_state(); 103 channel2->pending_valuebuffer_state();
88 EXPECT_NE(pending_value_buffer_state1, pending_value_buffer_state2); 104 EXPECT_NE(pending_value_buffer_state1, pending_value_buffer_state2);
89 105
90 const ValueState* state1 = 106 const ValueState* state1 =
91 pending_value_buffer_state1->GetState(GL_MOUSE_POSITION_CHROMIUM); 107 pending_value_buffer_state1->GetState(GL_MOUSE_POSITION_CHROMIUM);
92 const ValueState* state2 = 108 const ValueState* state2 =
93 pending_value_buffer_state2->GetState(GL_MOUSE_POSITION_CHROMIUM); 109 pending_value_buffer_state2->GetState(GL_MOUSE_POSITION_CHROMIUM);
94 EXPECT_NE(state1, state2); 110 EXPECT_NE(state1, state2);
95 111
96 EXPECT_EQ(state1->int_value[0], value_state1.int_value[0]); 112 EXPECT_EQ(state1->int_value[0], value_state1.int_value[0]);
97 EXPECT_EQ(state2->int_value[0], value_state2.int_value[0]); 113 EXPECT_EQ(state2->int_value[0], value_state2.int_value[0]);
98 EXPECT_NE(state1->int_value[0], state2->int_value[0]); 114 EXPECT_NE(state1->int_value[0], state2->int_value[0]);
99 } 115 }
100 116
101 } // namespace content 117 } // namespace content
OLDNEW
« no previous file with comments | « content/common/gpu/gpu_channel_manager.cc ('k') | content/common/gpu/gpu_channel_test_common.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698