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

Side by Side Diff: chrome/browser/sync/glue/bridged_sync_notifier_unittest.cc

Issue 10824161: [Sync] Avoid unregistering object IDs on shutdown (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Address comments Created 8 years, 4 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) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "chrome/browser/sync/glue/bridged_sync_notifier.h" 5 #include "chrome/browser/sync/glue/bridged_sync_notifier.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
10 #include "base/message_loop.h" 10 #include "base/message_loop.h"
11 #include "base/threading/thread.h" 11 #include "base/threading/thread.h"
12 #include "chrome/browser/sync/glue/chrome_sync_notification_bridge.h" 12 #include "chrome/browser/sync/glue/chrome_sync_notification_bridge.h"
13 #include "chrome/test/base/profile_mock.h" 13 #include "chrome/test/base/profile_mock.h"
14 #include "content/public/test/test_browser_thread.h" 14 #include "content/public/test/test_browser_thread.h"
15 #include "sync/internal_api/public/base/model_type.h" 15 #include "sync/internal_api/public/base/model_type.h"
16 #include "sync/internal_api/public/base/model_type_test_util.h" 16 #include "sync/internal_api/public/base/model_type_test_util.h"
17 #include "sync/notifier/mock_sync_notifier_observer.h" 17 #include "sync/notifier/mock_sync_notifier_observer.h"
18 #include "sync/notifier/sync_notifier.h" 18 #include "sync/notifier/sync_notifier.h"
19 #include "testing/gmock/include/gmock/gmock.h" 19 #include "testing/gmock/include/gmock/gmock.h"
20 #include "testing/gtest/include/gtest/gtest.h" 20 #include "testing/gtest/include/gtest/gtest.h"
21 21
22 namespace browser_sync { 22 namespace browser_sync {
23 namespace { 23 namespace {
24 24
25 using ::testing::NiceMock; 25 using ::testing::NiceMock;
26 using ::testing::StrictMock; 26 using ::testing::StrictMock;
27 using content::BrowserThread; 27 using content::BrowserThread;
28 using syncer::HasModelTypes; 28 using syncer::HasModelTypes;
29 29
30 const char kHandlerName[] = "MockObserver";
31
30 class MockChromeSyncNotificationBridge : public ChromeSyncNotificationBridge { 32 class MockChromeSyncNotificationBridge : public ChromeSyncNotificationBridge {
31 public: 33 public:
32 MockChromeSyncNotificationBridge( 34 MockChromeSyncNotificationBridge(
33 const Profile* profile, 35 const Profile* profile,
34 const scoped_refptr<base::SequencedTaskRunner>& sync_task_runner) 36 const scoped_refptr<base::SequencedTaskRunner>& sync_task_runner)
35 : ChromeSyncNotificationBridge(profile, sync_task_runner) {} 37 : ChromeSyncNotificationBridge(profile, sync_task_runner) {}
36 virtual ~MockChromeSyncNotificationBridge() {} 38 virtual ~MockChromeSyncNotificationBridge() {}
37 39
38 MOCK_METHOD2(UpdateRegisteredIds, void(syncer::SyncNotifierObserver*, 40 MOCK_METHOD2(SetHandler,
39 const syncer::ObjectIdSet&)); 41 void(const std::string&, syncer::SyncNotifierObserver*));
42 MOCK_METHOD2(UpdateRegisteredIds,
43 void(const std::string&, const syncer::ObjectIdSet&));
40 }; 44 };
41 45
42 class MockSyncNotifier : public syncer::SyncNotifier { 46 class MockSyncNotifier : public syncer::SyncNotifier {
43 public: 47 public:
44 MockSyncNotifier() {} 48 MockSyncNotifier() {}
45 virtual ~MockSyncNotifier() {} 49 virtual ~MockSyncNotifier() {}
46 50
51 MOCK_METHOD2(SetHandler,
52 void(const std::string&, syncer::SyncNotifierObserver*));
47 MOCK_METHOD2(UpdateRegisteredIds, 53 MOCK_METHOD2(UpdateRegisteredIds,
48 void(syncer::SyncNotifierObserver*, const syncer::ObjectIdSet&)); 54 void(const std::string&, const syncer::ObjectIdSet&));
49 MOCK_METHOD1(SetUniqueId, void(const std::string&)); 55 MOCK_METHOD1(SetUniqueId, void(const std::string&));
50 MOCK_METHOD1(SetStateDeprecated, void(const std::string&)); 56 MOCK_METHOD1(SetStateDeprecated, void(const std::string&));
51 MOCK_METHOD2(UpdateCredentials, void(const std::string&, const std::string&)); 57 MOCK_METHOD2(UpdateCredentials, void(const std::string&, const std::string&));
52 MOCK_METHOD1(SendNotification, void(syncer::ModelTypeSet)); 58 MOCK_METHOD1(SendNotification, void(syncer::ModelTypeSet));
53 }; 59 };
54 60
55 // All tests just verify that each call is passed through to the delegate, with 61 // All tests just verify that each call is passed through to the
msw 2012/08/03 23:30:46 nit: why line break earlier? Embrace the precious
akalin 2012/08/07 07:25:19 Done.
56 // the exception of UpdateRegisteredIds, which also verifies the call is 62 // delegate, with the exception of SetHandler and UpdateRegisteredIds,
57 // forwarded to the bridge. 63 // which also verifies the call is forwarded to the bridge.
58 class BridgedSyncNotifierTest : public testing::Test { 64 class BridgedSyncNotifierTest : public testing::Test {
59 public: 65 public:
60 BridgedSyncNotifierTest() 66 BridgedSyncNotifierTest()
61 : ui_thread_(BrowserThread::UI, &ui_loop_), 67 : ui_thread_(BrowserThread::UI, &ui_loop_),
62 mock_bridge_(&mock_profile_, ui_loop_.message_loop_proxy()), 68 mock_bridge_(&mock_profile_, ui_loop_.message_loop_proxy()),
63 mock_delegate_(new MockSyncNotifier), // Owned by bridged_notifier_. 69 mock_delegate_(new MockSyncNotifier), // Owned by bridged_notifier_.
64 bridged_notifier_(&mock_bridge_, mock_delegate_) {} 70 bridged_notifier_(&mock_bridge_, mock_delegate_) {}
65 virtual ~BridgedSyncNotifierTest() {} 71 virtual ~BridgedSyncNotifierTest() {}
66 72
67 protected: 73 protected:
68 MessageLoop ui_loop_; 74 MessageLoop ui_loop_;
69 content::TestBrowserThread ui_thread_; 75 content::TestBrowserThread ui_thread_;
70 NiceMock<ProfileMock> mock_profile_; 76 NiceMock<ProfileMock> mock_profile_;
71 StrictMock<MockChromeSyncNotificationBridge> mock_bridge_; 77 StrictMock<MockChromeSyncNotificationBridge> mock_bridge_;
72 MockSyncNotifier* mock_delegate_; 78 MockSyncNotifier* mock_delegate_;
73 BridgedSyncNotifier bridged_notifier_; 79 BridgedSyncNotifier bridged_notifier_;
74 }; 80 };
75 81
82 TEST_F(BridgedSyncNotifierTest, SetHandler) {
83 syncer::MockSyncNotifierObserver observer;
84 EXPECT_CALL(mock_bridge_, SetHandler(kHandlerName, &observer));
85 EXPECT_CALL(*mock_delegate_, SetHandler(kHandlerName, &observer));
86 bridged_notifier_.SetHandler(kHandlerName, &observer);
87 }
88
76 TEST_F(BridgedSyncNotifierTest, UpdateRegisteredIds) { 89 TEST_F(BridgedSyncNotifierTest, UpdateRegisteredIds) {
77 syncer::MockSyncNotifierObserver observer;
78 EXPECT_CALL(mock_bridge_, UpdateRegisteredIds( 90 EXPECT_CALL(mock_bridge_, UpdateRegisteredIds(
79 &observer, syncer::ObjectIdSet())); 91 kHandlerName, syncer::ObjectIdSet()));
80 EXPECT_CALL(*mock_delegate_, UpdateRegisteredIds( 92 EXPECT_CALL(*mock_delegate_, UpdateRegisteredIds(
81 &observer, syncer::ObjectIdSet())); 93 kHandlerName, syncer::ObjectIdSet()));
82 bridged_notifier_.UpdateRegisteredIds(&observer, syncer::ObjectIdSet()); 94 bridged_notifier_.UpdateRegisteredIds(kHandlerName, syncer::ObjectIdSet());
83 } 95 }
84 96
85 TEST_F(BridgedSyncNotifierTest, SetUniqueId) { 97 TEST_F(BridgedSyncNotifierTest, SetUniqueId) {
86 std::string unique_id = "unique id"; 98 std::string unique_id = "unique id";
87 EXPECT_CALL(*mock_delegate_, SetUniqueId(unique_id)); 99 EXPECT_CALL(*mock_delegate_, SetUniqueId(unique_id));
88 bridged_notifier_.SetUniqueId(unique_id); 100 bridged_notifier_.SetUniqueId(unique_id);
89 } 101 }
90 102
91 TEST_F(BridgedSyncNotifierTest, SetStateDeprecated) { 103 TEST_F(BridgedSyncNotifierTest, SetStateDeprecated) {
92 std::string state = "state"; 104 std::string state = "state";
93 EXPECT_CALL(*mock_delegate_, SetStateDeprecated(state)); 105 EXPECT_CALL(*mock_delegate_, SetStateDeprecated(state));
94 bridged_notifier_.SetStateDeprecated(state); 106 bridged_notifier_.SetStateDeprecated(state);
95 } 107 }
96 108
97 TEST_F(BridgedSyncNotifierTest, UpdateCredentials) { 109 TEST_F(BridgedSyncNotifierTest, UpdateCredentials) {
98 std::string email = "email"; 110 std::string email = "email";
99 std::string token = "token"; 111 std::string token = "token";
100 EXPECT_CALL(*mock_delegate_, UpdateCredentials(email, token)); 112 EXPECT_CALL(*mock_delegate_, UpdateCredentials(email, token));
101 bridged_notifier_.UpdateCredentials(email, token); 113 bridged_notifier_.UpdateCredentials(email, token);
102 } 114 }
103 115
104 TEST_F(BridgedSyncNotifierTest, SendNotification) { 116 TEST_F(BridgedSyncNotifierTest, SendNotification) {
105 syncer::ModelTypeSet changed_types(syncer::SESSIONS, syncer::EXTENSIONS); 117 syncer::ModelTypeSet changed_types(syncer::SESSIONS, syncer::EXTENSIONS);
106 EXPECT_CALL(*mock_delegate_, SendNotification(HasModelTypes(changed_types))); 118 EXPECT_CALL(*mock_delegate_, SendNotification(HasModelTypes(changed_types)));
107 bridged_notifier_.SendNotification(changed_types); 119 bridged_notifier_.SendNotification(changed_types);
108 } 120 }
109 121
110 } // namespace 122 } // namespace
111 } // namespace browser_sync 123 } // namespace browser_sync
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698