| OLD | NEW |
| 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/extensions/api/push_messaging/push_messaging_invalidati
on_handler.h" | 5 #include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidati
on_handler.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
| 9 #include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidati
on_handler_delegate.h" | 9 #include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidati
on_handler_delegate.h" |
| 10 #include "chrome/browser/invalidation/invalidation_service.h" | 10 #include "chrome/browser/invalidation/invalidation_service.h" |
| 11 #include "google/cacheinvalidation/types.pb.h" | 11 #include "google/cacheinvalidation/types.pb.h" |
| 12 #include "sync/internal_api/public/base/invalidation_test_util.h" | 12 #include "sync/notifier/object_id_invalidation_map.h" |
| 13 #include "testing/gmock/include/gmock/gmock.h" | 13 #include "testing/gmock/include/gmock/gmock.h" |
| 14 #include "testing/gtest/include/gtest/gtest.h" | 14 #include "testing/gtest/include/gtest/gtest.h" |
| 15 | 15 |
| 16 using ::testing::_; | 16 using ::testing::_; |
| 17 using ::testing::NotNull; | 17 using ::testing::NotNull; |
| 18 using ::testing::SaveArg; | 18 using ::testing::SaveArg; |
| 19 using ::testing::StrictMock; | 19 using ::testing::StrictMock; |
| 20 | 20 |
| 21 namespace extensions { | 21 namespace extensions { |
| 22 | 22 |
| 23 namespace { | 23 namespace { |
| 24 | 24 |
| 25 class MockInvalidationService : public invalidation::InvalidationService { | 25 class MockInvalidationService : public invalidation::InvalidationService { |
| 26 public: | 26 public: |
| 27 MockInvalidationService(); | 27 MockInvalidationService(); |
| 28 ~MockInvalidationService(); | 28 ~MockInvalidationService(); |
| 29 MOCK_METHOD1(RegisterInvalidationHandler, | 29 MOCK_METHOD1(RegisterInvalidationHandler, |
| 30 void(syncer::InvalidationHandler*)); | 30 void(syncer::InvalidationHandler*)); |
| 31 MOCK_METHOD2(UpdateRegisteredInvalidationIds, | 31 MOCK_METHOD2(UpdateRegisteredInvalidationIds, |
| 32 void(syncer::InvalidationHandler*, const syncer::ObjectIdSet&)); | 32 void(syncer::InvalidationHandler*, const syncer::ObjectIdSet&)); |
| 33 MOCK_METHOD1(UnregisterInvalidationHandler, | 33 MOCK_METHOD1(UnregisterInvalidationHandler, |
| 34 void(syncer::InvalidationHandler*)); | 34 void(syncer::InvalidationHandler*)); |
| 35 MOCK_METHOD2(AcknowledgeInvalidation, void(const invalidation::ObjectId&, | |
| 36 const syncer::AckHandle&)); | |
| 37 MOCK_CONST_METHOD0(GetInvalidatorState, syncer::InvalidatorState()); | 35 MOCK_CONST_METHOD0(GetInvalidatorState, syncer::InvalidatorState()); |
| 38 MOCK_CONST_METHOD0(GetInvalidatorClientId, std::string()); | 36 MOCK_CONST_METHOD0(GetInvalidatorClientId, std::string()); |
| 39 | 37 |
| 40 private: | 38 private: |
| 41 DISALLOW_COPY_AND_ASSIGN(MockInvalidationService); | 39 DISALLOW_COPY_AND_ASSIGN(MockInvalidationService); |
| 42 }; | 40 }; |
| 43 | 41 |
| 44 MockInvalidationService::MockInvalidationService() {} | 42 MockInvalidationService::MockInvalidationService() {} |
| 45 MockInvalidationService::~MockInvalidationService() {} | 43 MockInvalidationService::~MockInvalidationService() {} |
| 46 | 44 |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 97 EXPECT_CALL(service_, | 95 EXPECT_CALL(service_, |
| 98 UpdateRegisteredInvalidationIds(handler_.get(), expected_ids)); | 96 UpdateRegisteredInvalidationIds(handler_.get(), expected_ids)); |
| 99 handler_->RegisterExtension("cccccccccccccccccccccccccccccccc"); | 97 handler_->RegisterExtension("cccccccccccccccccccccccccccccccc"); |
| 100 EXPECT_CALL(service_, | 98 EXPECT_CALL(service_, |
| 101 UpdateRegisteredInvalidationIds(handler_.get(), | 99 UpdateRegisteredInvalidationIds(handler_.get(), |
| 102 syncer::ObjectIdSet())); | 100 syncer::ObjectIdSet())); |
| 103 handler_->UnregisterExtension("cccccccccccccccccccccccccccccccc"); | 101 handler_->UnregisterExtension("cccccccccccccccccccccccccccccccc"); |
| 104 } | 102 } |
| 105 | 103 |
| 106 TEST_F(PushMessagingInvalidationHandlerTest, Dispatch) { | 104 TEST_F(PushMessagingInvalidationHandlerTest, Dispatch) { |
| 107 syncer::ObjectIdSet ids; | 105 syncer::ObjectIdInvalidationMap invalidation_map; |
| 108 ids.insert(invalidation::ObjectId( | 106 // A normal invalidation. |
| 109 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, | 107 invalidation_map.Insert( |
| 110 "U/dddddddddddddddddddddddddddddddd/0")); | 108 syncer::Invalidation::Init( |
| 111 ids.insert(invalidation::ObjectId( | 109 invalidation::ObjectId( |
| 112 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, | 110 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, |
| 113 "U/dddddddddddddddddddddddddddddddd/3")); | 111 "U/dddddddddddddddddddddddddddddddd/0"), |
| 112 10, |
| 113 "payload")); |
| 114 |
| 115 // An unknown version invalidation. |
| 116 invalidation_map.Insert(syncer::Invalidation::InitUnknownVersion( |
| 117 invalidation::ObjectId( |
| 118 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, |
| 119 "U/dddddddddddddddddddddddddddddddd/3"))); |
| 120 |
| 114 EXPECT_CALL(delegate_, | 121 EXPECT_CALL(delegate_, |
| 115 OnMessage("dddddddddddddddddddddddddddddddd", 0, "payload")); | 122 OnMessage("dddddddddddddddddddddddddddddddd", 0, "payload")); |
| 116 EXPECT_CALL(delegate_, | 123 EXPECT_CALL(delegate_, |
| 117 OnMessage("dddddddddddddddddddddddddddddddd", 3, "payload")); | 124 OnMessage("dddddddddddddddddddddddddddddddd", 3, "")); |
| 118 for (syncer::ObjectIdSet::const_iterator it = ids.begin(); it != ids.end(); | 125 handler_->OnIncomingInvalidation(invalidation_map); |
| 119 ++it) { | |
| 120 EXPECT_CALL(service_, AcknowledgeInvalidation( | |
| 121 *it, syncer::AckHandle::InvalidAckHandle())); | |
| 122 } | |
| 123 handler_->OnIncomingInvalidation( | |
| 124 ObjectIdSetToInvalidationMap( | |
| 125 ids, | |
| 126 syncer::Invalidation::kUnknownVersion, | |
| 127 "payload")); | |
| 128 } | 126 } |
| 129 | 127 |
| 130 // Tests that malformed object IDs don't trigger spurious callbacks. | 128 // Tests that malformed object IDs don't trigger spurious callbacks. |
| 131 TEST_F(PushMessagingInvalidationHandlerTest, DispatchInvalidObjectIds) { | 129 TEST_F(PushMessagingInvalidationHandlerTest, DispatchInvalidObjectIds) { |
| 132 syncer::ObjectIdSet ids; | 130 syncer::ObjectIdInvalidationMap invalidation_map; |
| 133 // Completely incorrect format. | 131 // Completely incorrect format. |
| 134 ids.insert(invalidation::ObjectId( | 132 invalidation_map.Insert(syncer::Invalidation::InitUnknownVersion( |
| 135 ipc::invalidation::ObjectSource::TEST, | 133 invalidation::ObjectId( |
| 136 "Invalid")); | 134 ipc::invalidation::ObjectSource::TEST, |
| 135 "Invalid"))); |
| 137 // Incorrect source. | 136 // Incorrect source. |
| 138 ids.insert(invalidation::ObjectId( | 137 invalidation_map.Insert(syncer::Invalidation::InitUnknownVersion( |
| 139 ipc::invalidation::ObjectSource::TEST, | 138 invalidation::ObjectId( |
| 140 "U/dddddddddddddddddddddddddddddddd/3")); | 139 ipc::invalidation::ObjectSource::TEST, |
| 140 "U/dddddddddddddddddddddddddddddddd/3"))); |
| 141 // Incorrect format type. | 141 // Incorrect format type. |
| 142 ids.insert(invalidation::ObjectId( | 142 invalidation_map.Insert(syncer::Invalidation::InitUnknownVersion( |
| 143 invalidation::ObjectId( |
| 144 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, |
| 145 "V/dddddddddddddddddddddddddddddddd/3"))); |
| 146 // Invalid extension ID length. |
| 147 invalidation_map.Insert(syncer::Invalidation::InitUnknownVersion( |
| 148 invalidation::ObjectId( |
| 149 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, |
| 150 "U/ddddddddddddddddddddddddddddddddd/3"))); |
| 151 // Non-numeric subchannel. |
| 152 invalidation_map.Insert(syncer::Invalidation::InitUnknownVersion( |
| 153 invalidation::ObjectId( |
| 154 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, |
| 155 "U/dddddddddddddddddddddddddddddddd/z"))); |
| 156 // Subchannel out of range. |
| 157 invalidation_map.Insert(syncer::Invalidation::InitUnknownVersion( |
| 158 invalidation::ObjectId( |
| 159 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, |
| 160 "U/dddddddddddddddddddddddddddddddd/4"))); |
| 161 handler_->OnIncomingInvalidation(invalidation_map); |
| 162 } |
| 163 |
| 164 // Test version filtering of incoming invalidations. |
| 165 TEST_F(PushMessagingInvalidationHandlerTest, InvalidationVersionsOutOfOrder) { |
| 166 const invalidation::ObjectId id0( |
| 143 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, | 167 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, |
| 144 "V/dddddddddddddddddddddddddddddddd/3")); | 168 "U/dddddddddddddddddddddddddddddddd/0"); |
| 145 // Invalid extension ID length. | 169 const invalidation::ObjectId id3( |
| 146 ids.insert(invalidation::ObjectId( | |
| 147 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, | 170 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, |
| 148 "U/ddddddddddddddddddddddddddddddddd/3")); | 171 "U/dddddddddddddddddddddddddddddddd/3"); |
| 149 // Non-numeric subchannel. | 172 |
| 150 ids.insert(invalidation::ObjectId( | 173 // The first received invalidation should get through. |
| 151 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, | 174 syncer::ObjectIdInvalidationMap map1; |
| 152 "U/dddddddddddddddddddddddddddddddd/z")); | 175 map1.Insert(syncer::Invalidation::Init(id0, 5, "5")); |
| 153 // Subchannel out of range. | 176 EXPECT_CALL(delegate_, OnMessage("dddddddddddddddddddddddddddddddd", 0, "5")); |
| 154 ids.insert(invalidation::ObjectId( | 177 handler_->OnIncomingInvalidation(map1); |
| 155 ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING, | 178 testing::Mock::VerifyAndClearExpectations(&delegate_); |
| 156 "U/dddddddddddddddddddddddddddddddd/4")); | 179 |
| 157 // Invalid object IDs should still be acknowledged. | 180 // Invalid versions are always allowed through. |
| 158 for (syncer::ObjectIdSet::const_iterator it = ids.begin(); it != ids.end(); | 181 syncer::ObjectIdInvalidationMap map2; |
| 159 ++it) { | 182 map2.Insert(syncer::Invalidation::InitUnknownVersion(id0)); |
| 160 EXPECT_CALL(service_, AcknowledgeInvalidation( | 183 EXPECT_CALL(delegate_, OnMessage("dddddddddddddddddddddddddddddddd", 0, "")); |
| 161 *it, syncer::AckHandle::InvalidAckHandle())); | 184 handler_->OnIncomingInvalidation(map2); |
| 162 } | 185 testing::Mock::VerifyAndClearExpectations(&delegate_); |
| 163 handler_->OnIncomingInvalidation( | 186 |
| 164 ObjectIdSetToInvalidationMap( | 187 // An older version should not make it through. |
| 165 ids, | 188 syncer::ObjectIdInvalidationMap map3; |
| 166 syncer::Invalidation::kUnknownVersion, | 189 map3.Insert(syncer::Invalidation::Init(id0, 4, "4")); |
| 167 "payload")); | 190 handler_->OnIncomingInvalidation(map3); |
| 191 |
| 192 // A newer version will make it through. |
| 193 syncer::ObjectIdInvalidationMap map4; |
| 194 map4.Insert(syncer::Invalidation::Init(id0, 6, "6")); |
| 195 EXPECT_CALL(delegate_, OnMessage("dddddddddddddddddddddddddddddddd", 0, "6")); |
| 196 handler_->OnIncomingInvalidation(map4); |
| 197 testing::Mock::VerifyAndClearExpectations(&delegate_); |
| 198 |
| 199 // An unrelated object should be unaffected by all the above. |
| 200 syncer::ObjectIdInvalidationMap map5; |
| 201 map5.Insert(syncer::Invalidation::Init(id3, 1, "1")); |
| 202 EXPECT_CALL(delegate_, OnMessage("dddddddddddddddddddddddddddddddd", 3, "1")); |
| 203 handler_->OnIncomingInvalidation(map5); |
| 204 testing::Mock::VerifyAndClearExpectations(&delegate_); |
| 168 } | 205 } |
| 169 | 206 |
| 170 } // namespace extensions | 207 } // namespace extensions |
| OLD | NEW |