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

Side by Side Diff: chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc

Issue 10826156: Plumb invalidations from Tango to the extensions code for the Push Messaging API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix Android build 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
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidati on_handler.h"
6
7 #include "base/basictypes.h"
8 #include "base/memory/scoped_ptr.h"
9 #include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidati on_handler_delegate.h"
10 #include "chrome/browser/sync/invalidation_frontend.h"
11 #include "google/cacheinvalidation/types.pb.h"
12 #include "testing/gmock/include/gmock/gmock.h"
13 #include "testing/gtest/include/gtest/gtest.h"
14
15 using ::testing::_;
16 using ::testing::InSequence;
17 using ::testing::NotNull;
18 using ::testing::SaveArg;
19 using ::testing::StrictMock;
20
21 namespace extensions {
22
23 namespace {
24
25 class MockInvalidationFrontend : public InvalidationFrontend {
26 public:
27 MockInvalidationFrontend();
28 ~MockInvalidationFrontend();
29 MOCK_METHOD1(RegisterInvalidationHandler,
30 void(syncer::SyncNotifierObserver*));
31 MOCK_METHOD2(UpdateRegisteredInvalidationIds,
32 void(syncer::SyncNotifierObserver*, const syncer::ObjectIdSet&));
33 MOCK_METHOD1(UnregisterInvalidationHandler,
34 void(syncer::SyncNotifierObserver*));
35
36 private:
37 DISALLOW_COPY_AND_ASSIGN(MockInvalidationFrontend);
38 };
39
40 MockInvalidationFrontend::MockInvalidationFrontend() {}
41 MockInvalidationFrontend::~MockInvalidationFrontend() {}
42
43 class MockInvalidationHandlerDelegate
44 : public PushMessagingInvalidationHandlerDelegate {
45 public:
46 MockInvalidationHandlerDelegate();
47 ~MockInvalidationHandlerDelegate();
48 MOCK_METHOD3(OnMessage,
49 void(const std::string&, int, const std::string&));
50
51 private:
52 DISALLOW_COPY_AND_ASSIGN(MockInvalidationHandlerDelegate);
53 };
54
55 MockInvalidationHandlerDelegate::MockInvalidationHandlerDelegate() {}
56 MockInvalidationHandlerDelegate::~MockInvalidationHandlerDelegate() {}
57
58 } // namespace
59
60 class PushMessagingInvalidationHandlerTest : public ::testing::Test {
61 protected:
62 virtual void SetUp() OVERRIDE {
63 SetUpWithArgs(std::set<std::string>(), syncer::ObjectIdSet());
64 }
65
66 virtual void SetUpWithArgs(const std::set<std::string>& extension_ids,
67 const syncer::ObjectIdSet& expected_ids) {
68 InSequence seq;
69 syncer::SyncNotifierObserver* handler[2] = {};
70 EXPECT_CALL(service_, RegisterInvalidationHandler(NotNull()))
71 .WillOnce(SaveArg<0>(&handler[0]));
72 EXPECT_CALL(service_,
73 UpdateRegisteredInvalidationIds(NotNull(), expected_ids))
74 .WillOnce(SaveArg<0>(&handler[1]));
75 handler_.reset(new PushMessagingInvalidationHandler(
76 &service_, &delegate_, extension_ids));
77 EXPECT_EQ(handler[0], handler[1]);
78 EXPECT_EQ(handler_.get(), handler[0]);
79
80 }
81 virtual void TearDown() OVERRIDE {
82 EXPECT_CALL(service_, UnregisterInvalidationHandler(handler_.get()));
83 handler_.reset();
84 }
85 StrictMock<MockInvalidationFrontend> service_;
86 StrictMock<MockInvalidationHandlerDelegate> delegate_;
87 scoped_ptr<PushMessagingInvalidationHandler> handler_;
88 };
89
90 // Tests that we correctly register any extensions passed in when constructed.
91 TEST_F(PushMessagingInvalidationHandlerTest, Construction) {
92 TearDown();
93
94 InSequence seq;
95 std::set<std::string> extension_ids;
96 extension_ids.insert("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa");
97 extension_ids.insert("bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb");
98 syncer::ObjectIdSet expected_ids;
99 expected_ids.insert(invalidation::ObjectId(
100 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
101 "U/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/0"));
102 expected_ids.insert(invalidation::ObjectId(
103 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
104 "U/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/1"));
105 expected_ids.insert(invalidation::ObjectId(
106 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
107 "U/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/2"));
108 expected_ids.insert(invalidation::ObjectId(
109 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
110 "U/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/3"));
111 expected_ids.insert(invalidation::ObjectId(
112 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
113 "U/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/0"));
114 expected_ids.insert(invalidation::ObjectId(
115 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
116 "U/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/1"));
117 expected_ids.insert(invalidation::ObjectId(
118 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
119 "U/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/2"));
120 expected_ids.insert(invalidation::ObjectId(
121 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
122 "U/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/3"));
123
124 SetUpWithArgs(extension_ids, expected_ids);
125 }
126
127 TEST_F(PushMessagingInvalidationHandlerTest, RegisterUnregisterExtension) {
128 syncer::ObjectIdSet expected_ids;
129 expected_ids.insert(invalidation::ObjectId(
130 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
131 "U/cccccccccccccccccccccccccccccccc/0"));
132 expected_ids.insert(invalidation::ObjectId(
133 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
134 "U/cccccccccccccccccccccccccccccccc/1"));
135 expected_ids.insert(invalidation::ObjectId(
136 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
137 "U/cccccccccccccccccccccccccccccccc/2"));
138 expected_ids.insert(invalidation::ObjectId(
139 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
140 "U/cccccccccccccccccccccccccccccccc/3"));
141 EXPECT_CALL(service_,
142 UpdateRegisteredInvalidationIds(handler_.get(), expected_ids));
143 handler_->RegisterExtension("cccccccccccccccccccccccccccccccc");
144 EXPECT_CALL(service_,
145 UpdateRegisteredInvalidationIds(handler_.get(),
146 syncer::ObjectIdSet()));
147 handler_->UnregisterExtension("cccccccccccccccccccccccccccccccc");
148 }
149
150 TEST_F(PushMessagingInvalidationHandlerTest, Dispatch) {
151 syncer::ObjectIdSet ids;
152 ids.insert(invalidation::ObjectId(
153 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
154 "U/dddddddddddddddddddddddddddddddd/0"));
155 ids.insert(invalidation::ObjectId(
156 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
157 "U/dddddddddddddddddddddddddddddddd/3"));
158 EXPECT_CALL(delegate_,
159 OnMessage("dddddddddddddddddddddddddddddddd", 0, "payload"));
160 EXPECT_CALL(delegate_,
161 OnMessage("dddddddddddddddddddddddddddddddd", 3, "payload"));
162 handler_->OnIncomingNotification(ObjectIdSetToPayloadMap(ids, "payload"),
163 syncer::REMOTE_NOTIFICATION);
164 }
165
166 // Tests that malformed object IDs don't trigger spurious callbacks.
167 TEST_F(PushMessagingInvalidationHandlerTest, DispatchInvalidObjectIds) {
168 syncer::ObjectIdSet ids;
169 // Completely incorrect format.
170 ids.insert(invalidation::ObjectId(
171 ipc::invalidation::ObjectSource::TEST,
172 "Invalid"));
173 // Incorrect source.
174 ids.insert(invalidation::ObjectId(
175 ipc::invalidation::ObjectSource::TEST,
176 "U/dddddddddddddddddddddddddddddddd/3"));
177 // Incorrect format type.
178 ids.insert(invalidation::ObjectId(
179 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
180 "V/dddddddddddddddddddddddddddddddd/3"));
181 // Invalid extension ID length.
182 ids.insert(invalidation::ObjectId(
183 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
184 "U/ddddddddddddddddddddddddddddddddd/3"));
185 // Non-numeric subchannel.
186 ids.insert(invalidation::ObjectId(
187 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
188 "U/dddddddddddddddddddddddddddddddd/z"));
189 // Subchannel out of range.
190 ids.insert(invalidation::ObjectId(
191 ipc::invalidation::ObjectSource::CHROME_COMPONENTS,
192 "U/dddddddddddddddddddddddddddddddd/4"));
193 handler_->OnIncomingNotification(ObjectIdSetToPayloadMap(ids, "payload"),
194 syncer::REMOTE_NOTIFICATION);
195 }
196
197 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698