| Index: blimp/engine/feature/geolocation/blimp_location_provider_unittest.cc
|
| diff --git a/blimp/engine/feature/geolocation/blimp_location_provider_unittest.cc b/blimp/engine/feature/geolocation/blimp_location_provider_unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..68f1a57d4e372c75ba4e4d8f4c89d70a24932908
|
| --- /dev/null
|
| +++ b/blimp/engine/feature/geolocation/blimp_location_provider_unittest.cc
|
| @@ -0,0 +1,156 @@
|
| +// Copyright 2016 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 "blimp/engine/feature/geolocation/blimp_location_provider.h"
|
| +
|
| +#include <memory>
|
| +#include <utility>
|
| +
|
| +#include "base/bind.h"
|
| +#include "base/memory/ptr_util.h"
|
| +#include "blimp/engine/feature/geolocation/mock_blimp_location_provider_delegate.h"
|
| +#include "testing/gmock/include/gmock/gmock.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +
|
| +using testing::_;
|
| +using testing::SaveArg;
|
| +
|
| +namespace blimp {
|
| +namespace engine {
|
| +
|
| +class BlimpLocationProviderTest : public testing::Test {
|
| + public:
|
| + BlimpLocationProviderTest()
|
| + : mock_callback_(base::Bind(&BlimpLocationProviderTest::OnLocationUpdate,
|
| + base::Unretained(this))),
|
| + delegate_(base::WrapUnique(new MockBlimpLocationProviderDelegate)),
|
| + location_provider_(new BlimpLocationProvider(delegate_->GetWeakPtr())) {
|
| + }
|
| +
|
| + void SetUp() override {}
|
| +
|
| + MOCK_METHOD2(OnLocationUpdate,
|
| + void(const content::LocationProvider* provider,
|
| + const content::Geoposition& geoposition));
|
| +
|
| + protected:
|
| + content::LocationProvider::LocationProviderUpdateCallback mock_callback_;
|
| + std::unique_ptr<MockBlimpLocationProviderDelegate> delegate_;
|
| + std::unique_ptr<BlimpLocationProvider> location_provider_;
|
| +
|
| + private:
|
| + DISALLOW_COPY_AND_ASSIGN(BlimpLocationProviderTest);
|
| +};
|
| +
|
| +TEST_F(BlimpLocationProviderTest, StartProviderRunsCorrectly) {
|
| + EXPECT_CALL(
|
| + *delegate_,
|
| + RequestAccuracy(GeolocationSetInterestLevelMessage::HIGH_ACCURACY))
|
| + .Times(1);
|
| + EXPECT_CALL(*delegate_,
|
| + RequestAccuracy(GeolocationSetInterestLevelMessage::LOW_ACCURACY))
|
| + .Times(1);
|
| +
|
| + // BlimpLocationProvider implicitly stops on teardown, if it was started.
|
| + EXPECT_CALL(*delegate_,
|
| + RequestAccuracy(GeolocationSetInterestLevelMessage::NO_INTEREST))
|
| + .Times(1);
|
| +
|
| + EXPECT_TRUE(location_provider_->StartProvider(true));
|
| + EXPECT_TRUE(location_provider_->StartProvider(false));
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, StartProviderHandlesNullDelegate) {
|
| + EXPECT_CALL(*delegate_, RequestAccuracy(_)).Times(0);
|
| +
|
| + delegate_.reset();
|
| + EXPECT_FALSE(location_provider_->StartProvider(true));
|
| + EXPECT_FALSE(location_provider_->StartProvider(false));
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, StopProviderRunsCorrectly) {
|
| + EXPECT_CALL(
|
| + *delegate_,
|
| + RequestAccuracy(GeolocationSetInterestLevelMessage::HIGH_ACCURACY))
|
| + .Times(1);
|
| + EXPECT_CALL(*delegate_,
|
| + RequestAccuracy(GeolocationSetInterestLevelMessage::NO_INTEREST))
|
| + .Times(1);
|
| +
|
| + location_provider_->StartProvider(true);
|
| + location_provider_->StopProvider();
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, StopProviderHandlesNullDelegate) {
|
| + EXPECT_CALL(
|
| + *delegate_,
|
| + RequestAccuracy(GeolocationSetInterestLevelMessage::HIGH_ACCURACY))
|
| + .Times(1);
|
| +
|
| + location_provider_->StartProvider(true);
|
| + delegate_.reset();
|
| + location_provider_->StopProvider();
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, LocationProviderDeleted) {
|
| + EXPECT_CALL(
|
| + *delegate_,
|
| + RequestAccuracy(GeolocationSetInterestLevelMessage::HIGH_ACCURACY))
|
| + .Times(1);
|
| + EXPECT_CALL(*delegate_,
|
| + RequestAccuracy(GeolocationSetInterestLevelMessage::NO_INTEREST))
|
| + .Times(1);
|
| +
|
| + location_provider_->StartProvider(true);
|
| + location_provider_.reset();
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, RequestRefreshRunsCorrectly) {
|
| + EXPECT_CALL(*delegate_, RequestRefresh()).Times(1);
|
| +
|
| + location_provider_->StartProvider(true);
|
| + location_provider_->RequestRefresh();
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, RequestRefreshHandlesNullDelegate) {
|
| + EXPECT_CALL(*delegate_, RequestRefresh()).Times(0);
|
| +
|
| + location_provider_->StartProvider(true);
|
| + delegate_.reset();
|
| + location_provider_->RequestRefresh();
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, OnPermissionGrantedCallsRefresh) {
|
| + EXPECT_CALL(*delegate_, RequestRefresh()).Times(1);
|
| +
|
| + location_provider_->StartProvider(true);
|
| + location_provider_->OnPermissionGranted();
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, OnPermissionGrantedHandlesNullDelegate) {
|
| + EXPECT_CALL(*delegate_, RequestRefresh()).Times(0);
|
| +
|
| + location_provider_->StartProvider(true);
|
| + delegate_.reset();
|
| + location_provider_->OnPermissionGranted();
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, SetUpdateCallbackPropagatesCallback) {
|
| + base::Callback<void(const content::Geoposition&)> callback;
|
| + EXPECT_CALL(*delegate_, SetUpdateCallback(_)).WillOnce(SaveArg<0>(&callback));
|
| + EXPECT_CALL(*this, OnLocationUpdate(location_provider_.get(), _)).Times(1);
|
| +
|
| + location_provider_->SetUpdateCallback(mock_callback_);
|
| + callback.Run(content::Geoposition());
|
| +}
|
| +
|
| +TEST_F(BlimpLocationProviderTest, SetUpdateCallbackHandlesNullDelegate) {
|
| + EXPECT_CALL(*delegate_, SetUpdateCallback(_)).Times(0);
|
| +
|
| + delegate_.reset();
|
| + location_provider_->SetUpdateCallback(mock_callback_);
|
| +}
|
| +
|
| +} // namespace engine
|
| +} // namespace blimp
|
|
|