diff options
Diffstat (limited to 'chrome/browser/invalidation/ticl_invalidation_service_unittest.cc')
-rw-r--r-- | chrome/browser/invalidation/ticl_invalidation_service_unittest.cc | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/chrome/browser/invalidation/ticl_invalidation_service_unittest.cc b/chrome/browser/invalidation/ticl_invalidation_service_unittest.cc new file mode 100644 index 0000000..225dc0a --- /dev/null +++ b/chrome/browser/invalidation/ticl_invalidation_service_unittest.cc @@ -0,0 +1,59 @@ +// Copyright (c) 2013 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/invalidation/ticl_invalidation_service.h" + +#include "chrome/browser/invalidation/invalidation_frontend_test_template.h" +#include "chrome/browser/invalidation/invalidation_service_factory.h" +#include "chrome/test/base/testing_profile.h" +#include "sync/notifier/fake_invalidation_handler.h" +#include "sync/notifier/fake_invalidator.h" +#include "sync/notifier/invalidation_util.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace invalidation { + +class TiclInvalidationServiceTestDelegate { + public: + TiclInvalidationServiceTestDelegate() { } + + ~TiclInvalidationServiceTestDelegate() { + DestroyInvalidationFrontend(); + } + + void CreateInvalidationFrontend() { + fake_invalidator_ = new syncer::FakeInvalidator(); + profile_.reset(new TestingProfile()); + invalidation_service_.reset( + new TiclInvalidationService(NULL, NULL, profile_.get())); + invalidation_service_->InitForTest(fake_invalidator_); + } + + InvalidationFrontend* GetInvalidationFrontend() { + return invalidation_service_.get(); + } + + void DestroyInvalidationFrontend() { + invalidation_service_->Shutdown(); + } + + void TriggerOnInvalidatorStateChange(syncer::InvalidatorState state) { + fake_invalidator_->EmitOnInvalidatorStateChange(state); + } + + void TriggerOnIncomingInvalidation( + const syncer::ObjectIdInvalidationMap& invalidation_map) { + fake_invalidator_->EmitOnIncomingInvalidation(invalidation_map); + } + + syncer::FakeInvalidator* fake_invalidator_; // owned by the service. + scoped_ptr<TiclInvalidationService> invalidation_service_; + scoped_ptr<TestingProfile> profile_; +}; + +INSTANTIATE_TYPED_TEST_CASE_P( + TiclInvalidationServiceTest, InvalidationFrontendTest, + TiclInvalidationServiceTestDelegate); + +} // namespace invalidation |