Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(206)

Side by Side Diff: device/geolocation/mock_location_provider.h

Issue 2226143002: Gets rid of the LocationArbitrator interface, in preference for LocationProvider. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Merge branch 'master' into lai Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 #ifndef DEVICE_GEOLOCATION_MOCK_LOCATION_PROVIDER_H_ 5 #ifndef DEVICE_GEOLOCATION_MOCK_LOCATION_PROVIDER_H_
6 #define DEVICE_GEOLOCATION_MOCK_LOCATION_PROVIDER_H_ 6 #define DEVICE_GEOLOCATION_MOCK_LOCATION_PROVIDER_H_
7 7
8 #include "base/compiler_specific.h" 8 #include "base/compiler_specific.h"
9 #include "base/macros.h" 9 #include "base/macros.h"
10 #include "base/memory/ref_counted.h" 10 #include "base/memory/ref_counted.h"
11 #include "base/single_thread_task_runner.h" 11 #include "base/single_thread_task_runner.h"
12 #include "base/threading/thread.h" 12 #include "base/threading/thread.h"
13 #include "device/geolocation/geoposition.h" 13 #include "device/geolocation/geoposition.h"
14 #include "device/geolocation/location_provider_base.h" 14 #include "device/geolocation/location_provider_base.h"
15 15
16 namespace device { 16 namespace device {
17 17
18 // Mock implementation of a location provider for testing. 18 // Mock implementation of a location provider for testing.
19 class MockLocationProvider : public LocationProviderBase { 19 class MockLocationProvider : public LocationProviderBase {
20 public: 20 public:
21 enum State { STOPPED, LOW_ACCURACY, HIGH_ACCURACY } state_; 21 enum State { STOPPED, LOW_ACCURACY, HIGH_ACCURACY } state_;
22 22
23 MockLocationProvider(); 23 MockLocationProvider();
24 ~MockLocationProvider() override; 24 ~MockLocationProvider() override;
25 25
26 bool IsProviderStarted() const;
Wez 2016/08/19 01:33:12 nit: This can be an in-line "trivial getter", i.e:
CJ 2016/08/22 17:41:31 Done.
27
26 // Updates listeners with the new position. 28 // Updates listeners with the new position.
27 void HandlePositionChanged(const Geoposition& position); 29 void HandlePositionChanged(const Geoposition& position);
28 30
29 // LocationProvider implementation. 31 // LocationProvider implementation.
30 bool StartProvider(bool high_accuracy) override; 32 bool StartProvider(bool high_accuracy) override;
31 void StopProvider() override; 33 void StopProvider() override;
32 void GetPosition(Geoposition* position) override; 34 const Geoposition& GetPosition() override;
33 void OnPermissionGranted() override; 35 void OnPermissionGranted() override;
34 36
35 bool is_permission_granted_; 37 bool is_permission_granted_;
36 Geoposition position_; 38 Geoposition position_;
37 scoped_refptr<base::SingleThreadTaskRunner> provider_task_runner_; 39 scoped_refptr<base::SingleThreadTaskRunner> provider_task_runner_;
Wez 2016/08/19 01:33:12 These three members should be private, with trivia
CJ 2016/08/22 17:41:31 Done.
38 40
39 private: 41 private:
40 DISALLOW_COPY_AND_ASSIGN(MockLocationProvider); 42 DISALLOW_COPY_AND_ASSIGN(MockLocationProvider);
41 }; 43 };
42 44
43 // Factory functions for the various sorts of mock location providers, 45 // Factory functions for the various sorts of mock location providers,
44 // for use with LocationArbitrator::SetProviderFactoryForTest (i.e. 46 // for use with LocationArbitrator::SetProviderFactoryForTest (i.e.
45 // not intended for test code to use to get access to the mock, you can use 47 // not intended for test code to use to get access to the mock, you can use
46 // MockLocationProvider::instance_ for this, or make a custom factory method). 48 // MockLocationProvider::instance_ for this, or make a custom factory method).
47 49
48 // Creates a mock location provider with no default behavior. 50 // Creates a mock location provider with no default behavior.
49 LocationProvider* NewMockLocationProvider(); 51 LocationProvider* NewMockLocationProvider();
50 // Creates a mock location provider that automatically notifies its 52 // Creates a mock location provider that automatically notifies its
51 // listeners with a valid location when StartProvider is called. 53 // listeners with a valid location when StartProvider is called.
52 LocationProvider* NewAutoSuccessMockLocationProvider(); 54 LocationProvider* NewAutoSuccessMockLocationProvider();
53 // Creates a mock location provider that automatically notifies its 55 // Creates a mock location provider that automatically notifies its
54 // listeners with an error when StartProvider is called. 56 // listeners with an error when StartProvider is called.
55 LocationProvider* NewAutoFailMockLocationProvider(); 57 LocationProvider* NewAutoFailMockLocationProvider();
56 // Similar to NewAutoSuccessMockLocationProvider but mimicks the behavior of 58 // Similar to NewAutoSuccessMockLocationProvider but mimicks the behavior of
57 // the Network Location provider, in deferring making location updates until 59 // the Network Location provider, in deferring making location updates until
58 // a permission request has been confirmed. 60 // a permission request has been confirmed.
59 LocationProvider* NewAutoSuccessMockNetworkLocationProvider(); 61 LocationProvider* NewAutoSuccessMockNetworkLocationProvider();
60 62
61 } // namespace device 63 } // namespace device
62 64
63 #endif // DEVICE_GEOLOCATION_MOCK_LOCATION_PROVIDER_H_ 65 #endif // DEVICE_GEOLOCATION_MOCK_LOCATION_PROVIDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698