Chromium Code Reviews| Index: chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc |
| diff --git a/chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc b/chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..37d31a4ebc2e9f4e544facc2ee03f33ebee51d28 |
| --- /dev/null |
| +++ b/chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc |
| @@ -0,0 +1,193 @@ |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler.h" |
| + |
| +#include "base/basictypes.h" |
| +#include "base/memory/scoped_ptr.h" |
| +#include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_observer.h" |
| +#include "chrome/browser/sync/invalidation_service.h" |
| +#include "google/cacheinvalidation/types.pb.h" |
| +#include "testing/gmock/include/gmock/gmock.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +using ::testing::_; |
| +using ::testing::InSequence; |
| +using ::testing::NotNull; |
| +using ::testing::SaveArg; |
| +using ::testing::StrictMock; |
| + |
| +namespace extensions { |
| + |
| +namespace { |
|
Munjal (Google)
2012/08/20 19:26:00
NIt: Put hte anonymous namesapce outside of extens
dcheng
2012/08/20 20:58:21
This is for convenience: that way, I don't need to
|
| + |
| +class MockInvalidationService : public InvalidationService { |
| + public: |
| + MockInvalidationService(); |
| + ~MockInvalidationService(); |
| + MOCK_METHOD1(RegisterInvalidationHandler, |
| + void(syncer::SyncNotifierObserver*)); |
| + MOCK_METHOD2(UpdateRegisteredInvalidationIds, |
| + void(syncer::SyncNotifierObserver*, const syncer::ObjectIdSet&)); |
| + MOCK_METHOD1(UnregisterInvalidationHandler, |
| + void(syncer::SyncNotifierObserver*)); |
| + |
| + private: |
| + DISALLOW_COPY_AND_ASSIGN(MockInvalidationService); |
| +}; |
| + |
| +MockInvalidationService::MockInvalidationService() {} |
| +MockInvalidationService::~MockInvalidationService() {} |
| + |
| +class MockInvalidationHandlerObserver |
| + : public PushMessagingInvalidationHandlerObserver { |
| + public: |
| + MockInvalidationHandlerObserver(); |
| + ~MockInvalidationHandlerObserver(); |
| + MOCK_METHOD3(OnMessage, |
| + void(const std::string&, int, const std::string&)); |
| + |
| + private: |
| + DISALLOW_COPY_AND_ASSIGN(MockInvalidationHandlerObserver); |
| +}; |
| + |
| +MockInvalidationHandlerObserver::MockInvalidationHandlerObserver() {} |
| +MockInvalidationHandlerObserver::~MockInvalidationHandlerObserver() {} |
| + |
| +class PushMessagingInvalidationHandlerTest : public ::testing::Test { |
| + protected: |
| + virtual void SetUp() OVERRIDE { |
| + SetUpWithArgs(std::set<std::string>(), syncer::ObjectIdSet()); |
| + } |
| + |
| + virtual void SetUpWithArgs(const std::set<std::string>& extension_ids, |
| + const syncer::ObjectIdSet& expected_ids) { |
| + InSequence seq; |
| + syncer::SyncNotifierObserver* handler[2] = {}; |
| + EXPECT_CALL(service_, RegisterInvalidationHandler(NotNull())) |
| + .WillOnce(SaveArg<0>(&handler[0])); |
| + EXPECT_CALL(service_, |
| + UpdateRegisteredInvalidationIds(NotNull(), expected_ids)) |
| + .WillOnce(SaveArg<0>(&handler[1])); |
| + handler_.reset(new PushMessagingInvalidationHandler( |
| + &service_, &observer_, extension_ids)); |
| + EXPECT_EQ(handler[0], handler[1]); |
| + EXPECT_EQ(handler_.get(), handler[0]); |
| + |
| + } |
| + virtual void TearDown() OVERRIDE { |
| + EXPECT_CALL(service_, UnregisterInvalidationHandler(handler_.get())); |
| + handler_.reset(); |
| + } |
| + StrictMock<MockInvalidationService> service_; |
| + StrictMock<MockInvalidationHandlerObserver> observer_; |
| + scoped_ptr<PushMessagingInvalidationHandler> handler_; |
| +}; |
| + |
| +// Tests that we correctly register any extensions passed in when constructed. |
| +TEST_F(PushMessagingInvalidationHandlerTest, Construction) { |
| + TearDown(); |
| + |
| + InSequence seq; |
| + std::set<std::string> extension_ids; |
| + extension_ids.insert("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"); |
| + extension_ids.insert("bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb"); |
| + syncer::ObjectIdSet expected_ids; |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/0")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/1")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/2")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/3")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/0")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/1")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/2")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/3")); |
| + |
| + SetUpWithArgs(extension_ids, expected_ids); |
| +} |
| + |
| +TEST_F(PushMessagingInvalidationHandlerTest, RegisterUnregisterExtension) { |
| + syncer::ObjectIdSet expected_ids; |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/cccccccccccccccccccccccccccccccc/0")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/cccccccccccccccccccccccccccccccc/1")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/cccccccccccccccccccccccccccccccc/2")); |
| + expected_ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/cccccccccccccccccccccccccccccccc/3")); |
| + EXPECT_CALL(service_, |
| + UpdateRegisteredInvalidationIds(handler_.get(), expected_ids)); |
| + handler_->RegisterExtension("cccccccccccccccccccccccccccccccc"); |
| + EXPECT_CALL(service_, |
| + UpdateRegisteredInvalidationIds(handler_.get(), |
| + syncer::ObjectIdSet())); |
| + handler_->UnregisterExtension("cccccccccccccccccccccccccccccccc"); |
| +} |
| + |
| +TEST_F(PushMessagingInvalidationHandlerTest, Dispatch) { |
| + syncer::ObjectIdSet ids; |
| + ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/dddddddddddddddddddddddddddddddd/0")); |
| + ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/dddddddddddddddddddddddddddddddd/3")); |
| + EXPECT_CALL(observer_, |
| + OnMessage("dddddddddddddddddddddddddddddddd", 0, "payload")); |
| + EXPECT_CALL(observer_, |
| + OnMessage("dddddddddddddddddddddddddddddddd", 3, "payload")); |
| + handler_->OnIncomingNotification(ObjectIdSetToPayloadMap(ids, "payload"), |
| + syncer::REMOTE_NOTIFICATION); |
| +} |
| + |
| +// Tests that malformed object IDs don't trigger spurious callbacks. |
| +TEST_F(PushMessagingInvalidationHandlerTest, DispatchInvalidObjectIds) { |
| + syncer::ObjectIdSet ids; |
| + // Incorrect source. |
| + ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::TEST, |
| + "U/dddddddddddddddddddddddddddddddd/3")); |
| + // Incorrect format type. |
| + ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "V/dddddddddddddddddddddddddddddddd/3")); |
| + // Invalid extension ID length. |
| + ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/ddddddddddddddddddddddddddddddddd/3")); |
| + // Non-numeric subchannel. |
| + ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/dddddddddddddddddddddddddddddddd/z")); |
| + // Subchannel out of range. |
| + ids.insert(invalidation::ObjectId( |
| + ipc::invalidation::ObjectSource::CHROME_COMPONENTS, |
| + "U/dddddddddddddddddddddddddddddddd/4")); |
| + handler_->OnIncomingNotification(ObjectIdSetToPayloadMap(ids, "payload"), |
| + syncer::REMOTE_NOTIFICATION); |
| +} |
| + |
| +} // namespace |
| + |
| +} // namespace extensions |