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

Side by Side Diff: chrome/browser/sync/test/engine/syncer_command_test.h

Issue 8189003: Send important client side event information to the server. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: For review Created 9 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 | Annotate | Revision Log
OLDNEW
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 #ifndef CHROME_BROWSER_SYNC_TEST_ENGINE_SYNCER_COMMAND_TEST_H_ 5 #ifndef CHROME_BROWSER_SYNC_TEST_ENGINE_SYNCER_COMMAND_TEST_H_
6 #define CHROME_BROWSER_SYNC_TEST_ENGINE_SYNCER_COMMAND_TEST_H_ 6 #define CHROME_BROWSER_SYNC_TEST_ENGINE_SYNCER_COMMAND_TEST_H_
7 #pragma once 7 #pragma once
8 8
9 #include <algorithm> 9 #include <algorithm>
10 #include <string> 10 #include <string>
11 #include <vector> 11 #include <vector>
12 12
13 #include "base/compiler_specific.h" 13 #include "base/compiler_specific.h"
14 #include "chrome/browser/sync/engine/model_safe_worker.h" 14 #include "chrome/browser/sync/engine/model_safe_worker.h"
15 #include "chrome/browser/sync/sessions/debug_info_getter.h"
15 #include "chrome/browser/sync/sessions/sync_session.h" 16 #include "chrome/browser/sync/sessions/sync_session.h"
16 #include "chrome/browser/sync/sessions/sync_session_context.h" 17 #include "chrome/browser/sync/sessions/sync_session_context.h"
17 #include "chrome/browser/sync/test/engine/mock_connection_manager.h" 18 #include "chrome/browser/sync/test/engine/mock_connection_manager.h"
18 #include "chrome/browser/sync/test/engine/test_directory_setter_upper.h" 19 #include "chrome/browser/sync/test/engine/test_directory_setter_upper.h"
19 #include "testing/gtest/include/gtest/gtest.h" 20 #include "testing/gtest/include/gtest/gtest.h"
21 #include "testing/gmock/include/gmock/gmock.h"
22
23 using ::testing::NiceMock;
20 24
21 namespace browser_sync { 25 namespace browser_sync {
22 26
27 class MockDebugInfoGetter : public browser_sync::sessions::DebugInfoGetter {
28 public:
29 MOCK_METHOD1(GetAndClearDebugInfo, void(sync_pb::DebugInfo* debug_info));
30 };
31
23 // A test fixture that simplifies writing unit tests for individual 32 // A test fixture that simplifies writing unit tests for individual
24 // SyncerCommands, providing convenient access to a test directory 33 // SyncerCommands, providing convenient access to a test directory
25 // and a syncer session. 34 // and a syncer session.
26 template<typename T> 35 template<typename T>
27 class SyncerCommandTestWithParam : public testing::TestWithParam<T>, 36 class SyncerCommandTestWithParam : public testing::TestWithParam<T>,
28 public sessions::SyncSession::Delegate, 37 public sessions::SyncSession::Delegate,
29 public ModelSafeWorkerRegistrar { 38 public ModelSafeWorkerRegistrar {
30 public: 39 public:
31 enum UseMockDirectory { 40 enum UseMockDirectory {
32 USE_MOCK_DIRECTORY 41 USE_MOCK_DIRECTORY
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after
110 return session_.get(); 119 return session_.get();
111 } 120 }
112 121
113 void ClearSession() { 122 void ClearSession() {
114 session_.reset(); 123 session_.reset();
115 } 124 }
116 125
117 void ResetContext() { 126 void ResetContext() {
118 context_.reset(new sessions::SyncSessionContext( 127 context_.reset(new sessions::SyncSessionContext(
119 mock_server_.get(), syncdb_->manager(), registrar(), 128 mock_server_.get(), syncdb_->manager(), registrar(),
120 std::vector<SyncEngineEventListener*>())); 129 std::vector<SyncEngineEventListener*>(), &mock_debug_info_getter_));
121 context_->set_account_name(syncdb_->name()); 130 context_->set_account_name(syncdb_->name());
122 ClearSession(); 131 ClearSession();
123 } 132 }
124 133
125 // Install a MockServerConnection. Resets the context. By default, 134 // Install a MockServerConnection. Resets the context. By default,
126 // the context does not have a MockServerConnection attached. 135 // the context does not have a MockServerConnection attached.
127 void ConfigureMockServerConnection() { 136 void ConfigureMockServerConnection() {
128 mock_server_.reset( 137 mock_server_.reset(
129 new MockConnectionManager(syncdb_->manager(), syncdb_->name())); 138 new MockConnectionManager(syncdb_->manager(), syncdb_->name()));
130 ResetContext(); 139 ResetContext();
131 } 140 }
132 141
133 std::vector<scoped_refptr<ModelSafeWorker> >* workers() { 142 std::vector<scoped_refptr<ModelSafeWorker> >* workers() {
134 return &workers_; 143 return &workers_;
135 } 144 }
136 145
137 const ModelSafeRoutingInfo& routing_info() { return routing_info_; } 146 const ModelSafeRoutingInfo& routing_info() { return routing_info_; }
138 ModelSafeRoutingInfo* mutable_routing_info() { return &routing_info_; } 147 ModelSafeRoutingInfo* mutable_routing_info() { return &routing_info_; }
139 148
140 MockConnectionManager* mock_server() { 149 MockConnectionManager* mock_server() {
141 return mock_server_.get(); 150 return mock_server_.get();
142 } 151 }
143 152
153 MockDebugInfoGetter* mock_debug_info_getter() {
154 return &mock_debug_info_getter_;
155 }
156
144 private: 157 private:
145 scoped_ptr<TestDirectorySetterUpper> syncdb_; 158 scoped_ptr<TestDirectorySetterUpper> syncdb_;
146 scoped_ptr<sessions::SyncSessionContext> context_; 159 scoped_ptr<sessions::SyncSessionContext> context_;
147 scoped_ptr<MockConnectionManager> mock_server_; 160 scoped_ptr<MockConnectionManager> mock_server_;
148 scoped_ptr<sessions::SyncSession> session_; 161 scoped_ptr<sessions::SyncSession> session_;
149 std::vector<scoped_refptr<ModelSafeWorker> > workers_; 162 std::vector<scoped_refptr<ModelSafeWorker> > workers_;
150 ModelSafeRoutingInfo routing_info_; 163 ModelSafeRoutingInfo routing_info_;
164 NiceMock<MockDebugInfoGetter> mock_debug_info_getter_;
151 DISALLOW_COPY_AND_ASSIGN(SyncerCommandTestWithParam); 165 DISALLOW_COPY_AND_ASSIGN(SyncerCommandTestWithParam);
152 }; 166 };
153 167
154 class SyncerCommandTest : public SyncerCommandTestWithParam<void*> {}; 168 class SyncerCommandTest : public SyncerCommandTestWithParam<void*> {};
155 169
156 class MockDirectorySyncerCommandTest 170 class MockDirectorySyncerCommandTest
157 : public SyncerCommandTestWithParam<void*> { 171 : public SyncerCommandTestWithParam<void*> {
158 public: 172 public:
159 MockDirectorySyncerCommandTest() 173 MockDirectorySyncerCommandTest()
160 : SyncerCommandTestWithParam<void*>( 174 : SyncerCommandTestWithParam<void*>(
161 SyncerCommandTestWithParam<void*>::USE_MOCK_DIRECTORY) {} 175 SyncerCommandTestWithParam<void*>::USE_MOCK_DIRECTORY) {}
162 MockDirectorySetterUpper::MockDirectory* mock_directory() { 176 MockDirectorySetterUpper::MockDirectory* mock_directory() {
163 return static_cast<MockDirectorySetterUpper*>(syncdb())->directory(); 177 return static_cast<MockDirectorySetterUpper*>(syncdb())->directory();
164 } 178 }
165 }; 179 };
166 180
167 } // namespace browser_sync 181 } // namespace browser_sync
168 182
169 #endif // CHROME_BROWSER_SYNC_TEST_ENGINE_SYNCER_COMMAND_TEST_H_ 183 #endif // CHROME_BROWSER_SYNC_TEST_ENGINE_SYNCER_COMMAND_TEST_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698