Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 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 "blimp/engine/feature/geolocation/blimp_location_provider.h" | |
| 6 | |
| 7 #include <memory> | |
| 8 #include <utility> | |
| 9 | |
| 10 #include "base/bind.h" | |
| 11 #include "base/memory/ptr_util.h" | |
| 12 #include "blimp/engine/feature/geolocation/mock_blimp_location_provider_delegate .h" | |
| 13 #include "testing/gmock/include/gmock/gmock.h" | |
| 14 #include "testing/gtest/include/gtest/gtest.h" | |
| 15 | |
| 16 using testing::_; | |
| 17 using testing::SaveArg; | |
| 18 | |
| 19 namespace blimp { | |
| 20 namespace engine { | |
| 21 | |
| 22 class BlimpLocationProviderTest : public testing::Test { | |
| 23 public: | |
| 24 BlimpLocationProviderTest() | |
| 25 : mock_callback_(base::Bind(&BlimpLocationProviderTest::OnLocationUpdate, | |
| 26 base::Unretained(this))), | |
| 27 delegate_(base::WrapUnique(new MockBlimpLocationProviderDelegate)), | |
| 28 location_provider_(new BlimpLocationProvider(delegate_->GetWeakPtr())) { | |
| 29 } | |
| 30 | |
| 31 void SetUp() override {} | |
| 32 | |
| 33 MOCK_METHOD2(OnLocationUpdate, | |
| 34 void(const content::LocationProvider* provider, | |
| 35 const content::Geoposition& geoposition)); | |
| 36 | |
| 37 protected: | |
| 38 content::LocationProvider::LocationProviderUpdateCallback mock_callback_; | |
| 39 std::unique_ptr<MockBlimpLocationProviderDelegate> delegate_; | |
| 40 std::unique_ptr<BlimpLocationProvider> location_provider_; | |
| 41 | |
| 42 private: | |
| 43 DISALLOW_COPY_AND_ASSIGN(BlimpLocationProviderTest); | |
| 44 }; | |
| 45 | |
| 46 TEST_F(BlimpLocationProviderTest, StartProviderRunsCorrectly) { | |
| 47 EXPECT_CALL( | |
| 48 *delegate_, | |
| 49 RequestAccuracy(GeolocationSetInterestLevelMessage::HIGH_ACCURACY)) | |
| 50 .Times(1); | |
| 51 EXPECT_CALL(*delegate_, | |
| 52 RequestAccuracy(GeolocationSetInterestLevelMessage::LOW_ACCURACY)) | |
| 53 .Times(1); | |
| 54 | |
| 55 // Occurs during tear down. | |
|
Wez
2016/07/22 01:18:58
nit: Suggest a little more clarifying wording, e.g
CJ
2016/07/22 20:03:30
Done.
| |
| 56 EXPECT_CALL(*delegate_, | |
| 57 RequestAccuracy(GeolocationSetInterestLevelMessage::NO_INTEREST)) | |
| 58 .Times(1); | |
| 59 | |
| 60 EXPECT_TRUE(location_provider_->StartProvider(true)); | |
| 61 EXPECT_TRUE(location_provider_->StartProvider(false)); | |
| 62 } | |
| 63 | |
| 64 TEST_F(BlimpLocationProviderTest, StartProviderHandlesNullDelegate) { | |
| 65 EXPECT_CALL(*delegate_, RequestAccuracy(_)).Times(0); | |
| 66 delegate_.reset(); | |
|
Kevin M
2016/07/21 17:37:06
add newline to visually separate execution setup a
CJ
2016/07/21 22:04:46
Done.
| |
| 67 EXPECT_FALSE(location_provider_->StartProvider(true)); | |
| 68 EXPECT_FALSE(location_provider_->StartProvider(false)); | |
| 69 } | |
| 70 | |
| 71 TEST_F(BlimpLocationProviderTest, StopProviderRunsCorrectly) { | |
| 72 EXPECT_CALL( | |
| 73 *delegate_, | |
| 74 RequestAccuracy(GeolocationSetInterestLevelMessage::HIGH_ACCURACY)) | |
| 75 .Times(1); | |
| 76 EXPECT_CALL(*delegate_, | |
| 77 RequestAccuracy(GeolocationSetInterestLevelMessage::NO_INTEREST)) | |
| 78 .Times(1); | |
| 79 location_provider_->StartProvider(true); | |
| 80 | |
|
Kevin M
2016/07/21 17:37:06
remove newline
CJ
2016/07/21 22:04:46
Done.
| |
| 81 location_provider_->StopProvider(); | |
| 82 } | |
| 83 | |
| 84 TEST_F(BlimpLocationProviderTest, StopProviderHandlesNullDelegate) { | |
| 85 EXPECT_CALL( | |
| 86 *delegate_, | |
| 87 RequestAccuracy(GeolocationSetInterestLevelMessage::HIGH_ACCURACY)) | |
| 88 .Times(1); | |
| 89 location_provider_->StartProvider(true); | |
| 90 delegate_.reset(); | |
| 91 location_provider_->StopProvider(); | |
| 92 } | |
| 93 | |
| 94 TEST_F(BlimpLocationProviderTest, LocationProviderDeleted) { | |
| 95 EXPECT_CALL( | |
| 96 *delegate_, | |
| 97 RequestAccuracy(GeolocationSetInterestLevelMessage::HIGH_ACCURACY)) | |
| 98 .Times(1); | |
| 99 EXPECT_CALL(*delegate_, | |
| 100 RequestAccuracy(GeolocationSetInterestLevelMessage::NO_INTEREST)) | |
| 101 .Times(1); | |
| 102 location_provider_->StartProvider(true); | |
| 103 location_provider_.reset(); | |
| 104 } | |
| 105 | |
| 106 TEST_F(BlimpLocationProviderTest, RequestRefreshRunsCorrectly) { | |
| 107 EXPECT_CALL(*delegate_, RequestRefresh()).Times(1); | |
| 108 location_provider_->StartProvider(true); | |
| 109 location_provider_->RequestRefresh(); | |
| 110 } | |
| 111 | |
| 112 TEST_F(BlimpLocationProviderTest, RequestRefreshHandlesNullDelegate) { | |
| 113 EXPECT_CALL(*delegate_, RequestRefresh()).Times(0); | |
| 114 location_provider_->StartProvider(true); | |
| 115 delegate_.reset(); | |
| 116 location_provider_->RequestRefresh(); | |
| 117 } | |
| 118 | |
| 119 TEST_F(BlimpLocationProviderTest, OnPermissionGrantedCallsRefresh) { | |
| 120 EXPECT_CALL(*delegate_, RequestRefresh()).Times(1); | |
| 121 location_provider_->StartProvider(true); | |
| 122 location_provider_->OnPermissionGranted(); | |
| 123 } | |
| 124 | |
| 125 TEST_F(BlimpLocationProviderTest, OnPermissionGrantedHandlesNullDelegate) { | |
| 126 EXPECT_CALL(*delegate_, RequestRefresh()).Times(0); | |
| 127 location_provider_->StartProvider(true); | |
| 128 delegate_.reset(); | |
| 129 location_provider_->OnPermissionGranted(); | |
| 130 } | |
| 131 | |
| 132 TEST_F(BlimpLocationProviderTest, SetUpdateCallbackPropagatesCallback) { | |
| 133 base::Callback<void(const content::Geoposition&)> callback; | |
| 134 EXPECT_CALL(*delegate_, SetUpdateCallback(_)).WillOnce(SaveArg<0>(&callback)); | |
| 135 location_provider_->SetUpdateCallback(mock_callback_); | |
| 136 | |
| 137 EXPECT_CALL(*this, OnLocationUpdate(location_provider_.get(), _)).Times(1); | |
| 138 content::Geoposition position; | |
| 139 callback.Run(position); | |
| 140 } | |
| 141 | |
| 142 TEST_F(BlimpLocationProviderTest, SetUpdateCallbackHandlesNullDelegate) { | |
| 143 EXPECT_CALL(*delegate_, SetUpdateCallback(_)).Times(0); | |
| 144 delegate_.reset(); | |
| 145 location_provider_->SetUpdateCallback(mock_callback_); | |
| 146 } | |
| 147 | |
| 148 } // namespace engine | |
| 149 } // namespace blimp | |
| OLD | NEW |