blob: 689245b271ade29a6f5ef1150221a468d41b8407 [file] [log] [blame]
Jason Glasgowef965562012-04-10 16:12:35 -04001// Copyright (c) 2012 The Chromium OS 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 "shill/cellular_capability_universal.h"
6
Nathan Williams4b7c2a82012-04-13 15:19:47 -04007#include <string>
8#include <vector>
9
Jason Glasgowef965562012-04-10 16:12:35 -040010#include <base/bind.h>
Darin Petkova4ca3c32012-08-17 16:05:24 +020011#include <base/stringprintf.h>
Jason Glasgowef965562012-04-10 16:12:35 -040012#include <chromeos/dbus/service_constants.h>
13#include <gtest/gtest.h>
14#include <mobile_provider.h>
Ben Chan5c853ef2012-10-05 00:05:37 -070015#include <ModemManager/ModemManager.h>
Jason Glasgowef965562012-04-10 16:12:35 -040016
17#include "shill/cellular.h"
18#include "shill/cellular_service.h"
Jason Glasgowaf583282012-04-18 15:18:22 -040019#include "shill/dbus_adaptor.h"
Jason Glasgowef965562012-04-10 16:12:35 -040020#include "shill/error.h"
21#include "shill/event_dispatcher.h"
22#include "shill/mock_adaptors.h"
Ben Chan15786032012-11-04 21:28:02 -080023#include "shill/mock_cellular_operator_info.h"
Jason Glasgow14521872012-05-07 19:12:15 -040024#include "shill/mock_cellular_service.h"
Jason Glasgowaf583282012-04-18 15:18:22 -040025#include "shill/mock_dbus_properties_proxy.h"
Jason Glasgowef965562012-04-10 16:12:35 -040026#include "shill/mock_glib.h"
27#include "shill/mock_manager.h"
28#include "shill/mock_metrics.h"
Arman Uguray6e5639f2012-11-15 20:30:19 -080029#include "shill/mock_mm1_bearer_proxy.h"
Jason Glasgowef965562012-04-10 16:12:35 -040030#include "shill/mock_mm1_modem_modem3gpp_proxy.h"
31#include "shill/mock_mm1_modem_modemcdma_proxy.h"
32#include "shill/mock_mm1_modem_proxy.h"
33#include "shill/mock_mm1_modem_simple_proxy.h"
34#include "shill/mock_mm1_sim_proxy.h"
35#include "shill/mock_profile.h"
36#include "shill/mock_rtnl_handler.h"
37#include "shill/nice_mock_control.h"
38#include "shill/proxy_factory.h"
39
40using base::Bind;
Darin Petkova4ca3c32012-08-17 16:05:24 +020041using base::StringPrintf;
Jason Glasgowef965562012-04-10 16:12:35 -040042using base::Unretained;
43using std::string;
Nathan Williams4b7c2a82012-04-13 15:19:47 -040044using std::vector;
Jason Glasgowef965562012-04-10 16:12:35 -040045using testing::InSequence;
Ben Chan6d0d1e72012-11-06 21:19:28 -080046using testing::Invoke;
Gary Moraine285a842012-08-15 08:23:57 -070047using testing::Mock;
Jason Glasgowef965562012-04-10 16:12:35 -040048using testing::NiceMock;
49using testing::Return;
Jason Glasgowcd0349c2012-05-03 23:32:15 -040050using testing::SaveArg;
Jason Glasgowef965562012-04-10 16:12:35 -040051using testing::_;
52
53namespace shill {
54
55MATCHER(IsSuccess, "") {
56 return arg.IsSuccess();
57}
58MATCHER(IsFailure, "") {
59 return arg.IsFailure();
60}
Jason Glasgow14521872012-05-07 19:12:15 -040061MATCHER_P(HasApn, expected_apn, "") {
62 string apn;
63 return (DBusProperties::GetString(arg,
64 CellularCapabilityUniversal::kConnectApn,
65 &apn) &&
66 apn == expected_apn);
67}
Jason Glasgowef965562012-04-10 16:12:35 -040068
Ben Chan6d0d1e72012-11-06 21:19:28 -080069class MockCellularOperatorInfoGetOLPHelper {
70 public:
71 MockCellularOperatorInfoGetOLPHelper(const CellularService::OLP &olp) {
72 olp_.CopyFrom(olp);
73 }
74
75 ~MockCellularOperatorInfoGetOLPHelper() {}
76
77 bool GetOLP(const std::string &operator_id, CellularService::OLP *olp) {
78 olp->CopyFrom(olp_);
79 return true;
80 }
81
82 private:
83 CellularService::OLP olp_;
84};
85
Jason Glasgowef965562012-04-10 16:12:35 -040086class CellularCapabilityUniversalTest : public testing::Test {
87 public:
88 CellularCapabilityUniversalTest()
89 : manager_(&control_, &dispatcher_, &metrics_, &glib_),
Arman Uguray6e5639f2012-11-15 20:30:19 -080090 bearer_proxy_(new mm1::MockBearerProxy()),
Ben Chan3ecdf822012-08-06 12:29:23 -070091 modem_3gpp_proxy_(new mm1::MockModemModem3gppProxy()),
92 modem_cdma_proxy_(new mm1::MockModemModemCdmaProxy()),
93 modem_proxy_(new mm1::MockModemProxy()),
94 modem_simple_proxy_(new mm1::MockModemSimpleProxy()),
95 sim_proxy_(new mm1::MockSimProxy()),
96 properties_proxy_(new MockDBusPropertiesProxy()),
97 proxy_factory_(this),
98 capability_(NULL),
99 device_adaptor_(NULL),
100 provider_db_(NULL),
Jason Glasgowef965562012-04-10 16:12:35 -0400101 cellular_(new Cellular(&control_,
102 &dispatcher_,
103 NULL,
104 &manager_,
105 "",
106 "",
107 0,
108 Cellular::kTypeUniversal,
109 "",
110 "",
Jason Glasgowa585fc32012-06-06 11:04:09 -0400111 "",
Ben Chan3ecdf822012-08-06 12:29:23 -0700112 NULL,
Ben Chan62028b22012-11-05 11:20:02 -0800113 NULL,
Ben Chan3ecdf822012-08-06 12:29:23 -0700114 &proxy_factory_)),
Jason Glasgow14521872012-05-07 19:12:15 -0400115 service_(new MockCellularService(&control_,
116 &dispatcher_,
117 &metrics_,
118 &manager_,
Ben Chan3ecdf822012-08-06 12:29:23 -0700119 cellular_)) {}
Jason Glasgowef965562012-04-10 16:12:35 -0400120
121 virtual ~CellularCapabilityUniversalTest() {
122 cellular_->service_ = NULL;
123 capability_ = NULL;
124 device_adaptor_ = NULL;
Darin Petkovb4fccd22012-08-10 11:59:26 +0200125 if (provider_db_) {
126 mobile_provider_close_db(provider_db_);
127 provider_db_ = NULL;
128 }
Jason Glasgowef965562012-04-10 16:12:35 -0400129 }
130
131 virtual void SetUp() {
132 capability_ = dynamic_cast<CellularCapabilityUniversal *>(
133 cellular_->capability_.get());
Jason Glasgowef965562012-04-10 16:12:35 -0400134 device_adaptor_ =
135 dynamic_cast<NiceMock<DeviceMockAdaptor> *>(cellular_->adaptor());
Jason Glasgow14521872012-05-07 19:12:15 -0400136 cellular_->service_ = service_;
Jason Glasgowef965562012-04-10 16:12:35 -0400137 }
138
139 virtual void TearDown() {
140 capability_->proxy_factory_ = NULL;
141 }
142
Darin Petkova4ca3c32012-08-17 16:05:24 +0200143 void SetService() {
144 cellular_->service_ = new CellularService(
145 &control_, &dispatcher_, &metrics_, NULL, cellular_);
146 }
147
Jason Glasgow4380f0d2012-05-03 18:05:04 -0400148 void InitProviderDB() {
149 const char kTestMobileProviderDBPath[] = "provider_db_unittest.bfd";
150
151 provider_db_ = mobile_provider_open_db(kTestMobileProviderDBPath);
152 ASSERT_TRUE(provider_db_);
153 cellular_->provider_db_ = provider_db_;
154 }
155
Jason Glasgowef965562012-04-10 16:12:35 -0400156 void InvokeEnable(bool enable, Error *error,
157 const ResultCallback &callback, int timeout) {
158 callback.Run(Error());
159 }
160 void InvokeEnableFail(bool enable, Error *error,
161 const ResultCallback &callback, int timeout) {
162 callback.Run(Error(Error::kOperationFailed));
163 }
Jason Glasgowaf583282012-04-18 15:18:22 -0400164 void InvokeRegister(const string &operator_id, Error *error,
165 const ResultCallback &callback, int timeout) {
166 callback.Run(Error());
167 }
168
Gary Morainceba6aa2012-05-03 10:28:26 -0700169 void InvokeScan(Error *error, const DBusPropertyMapsCallback &callback,
170 int timeout) {
171 callback.Run(CellularCapabilityUniversal::ScanResults(), Error());
172 }
Jason Glasgowcd0349c2012-05-03 23:32:15 -0400173 void ScanError(Error *error, const DBusPropertyMapsCallback &callback,
174 int timeout) {
175 error->Populate(Error::kOperationFailed);
176 }
Gary Morainceba6aa2012-05-03 10:28:26 -0700177
178 void Set3gppProxy() {
179 capability_->modem_3gpp_proxy_.reset(modem_3gpp_proxy_.release());
180 }
181
Jason Glasgow14521872012-05-07 19:12:15 -0400182 void SetSimpleProxy() {
183 capability_->modem_simple_proxy_.reset(modem_simple_proxy_.release());
184 }
185
Thieu Le3d275392012-07-20 15:32:58 -0700186 void ReleaseCapabilityProxies() {
187 capability_->ReleaseProxies();
188 }
189
Jason Glasgowef965562012-04-10 16:12:35 -0400190 MOCK_METHOD1(TestCallback, void(const Error &error));
191
192 protected:
Arman Uguray6e5639f2012-11-15 20:30:19 -0800193 static const char kActiveBearerPathPrefix[];
Jason Glasgowef965562012-04-10 16:12:35 -0400194 static const char kImei[];
Arman Uguray6e5639f2012-11-15 20:30:19 -0800195 static const char kInactiveBearerPathPrefix[];
Jason Glasgowaf583282012-04-18 15:18:22 -0400196 static const char kSimPath[];
197 static const uint32 kAccessTechnologies;
Jason Glasgowef965562012-04-10 16:12:35 -0400198
199 class TestProxyFactory : public ProxyFactory {
200 public:
201 explicit TestProxyFactory(CellularCapabilityUniversalTest *test) :
202 test_(test) {}
203
Arman Uguray6e5639f2012-11-15 20:30:19 -0800204 virtual mm1::BearerProxyInterface *CreateBearerProxy(
205 const std::string &path,
206 const std::string &/*service*/) {
207 mm1::MockBearerProxy *bearer_proxy = test_->bearer_proxy_.release();
208 if (path.find(kActiveBearerPathPrefix) != std::string::npos)
209 ON_CALL(*bearer_proxy, Connected()).WillByDefault(Return(true));
210 else
211 ON_CALL(*bearer_proxy, Connected()).WillByDefault(Return(false));
212 test_->bearer_proxy_.reset(new mm1::MockBearerProxy());
213 return bearer_proxy;
214 }
215
Jason Glasgowef965562012-04-10 16:12:35 -0400216 virtual mm1::ModemModem3gppProxyInterface *CreateMM1ModemModem3gppProxy(
Arman Uguray6e5639f2012-11-15 20:30:19 -0800217 const std::string &/*path*/,
218 const std::string &/*service*/) {
Jason Glasgowef965562012-04-10 16:12:35 -0400219 return test_->modem_3gpp_proxy_.release();
220 }
221
222 virtual mm1::ModemModemCdmaProxyInterface *CreateMM1ModemModemCdmaProxy(
Arman Uguray6e5639f2012-11-15 20:30:19 -0800223 const std::string &/*path*/,
224 const std::string &/*service*/) {
Jason Glasgowef965562012-04-10 16:12:35 -0400225 return test_->modem_cdma_proxy_.release();
226 }
227
228 virtual mm1::ModemProxyInterface *CreateMM1ModemProxy(
Arman Uguray6e5639f2012-11-15 20:30:19 -0800229 const std::string &/*path*/,
230 const std::string &/*service*/) {
Jason Glasgowef965562012-04-10 16:12:35 -0400231 return test_->modem_proxy_.release();
232 }
233
234 virtual mm1::ModemSimpleProxyInterface *CreateMM1ModemSimpleProxy(
Arman Uguray6e5639f2012-11-15 20:30:19 -0800235 const std::string &/*path*/,
236 const std::string &/*service*/) {
Jason Glasgowef965562012-04-10 16:12:35 -0400237 return test_->modem_simple_proxy_.release();
238 }
239
240 virtual mm1::SimProxyInterface *CreateSimProxy(
Arman Uguray6e5639f2012-11-15 20:30:19 -0800241 const std::string &/*path*/,
242 const std::string &/*service*/) {
Jason Glasgowef965562012-04-10 16:12:35 -0400243 return test_->sim_proxy_.release();
244 }
Jason Glasgowaf583282012-04-18 15:18:22 -0400245 virtual DBusPropertiesProxyInterface *CreateDBusPropertiesProxy(
Arman Uguray6e5639f2012-11-15 20:30:19 -0800246 const std::string &/*path*/,
247 const std::string &/*service*/) {
Jason Glasgowaf583282012-04-18 15:18:22 -0400248 return test_->properties_proxy_.release();
249 }
Jason Glasgowef965562012-04-10 16:12:35 -0400250
251 private:
252 CellularCapabilityUniversalTest *test_;
253 };
254
255 NiceMockControl control_;
256 EventDispatcher dispatcher_;
257 MockMetrics metrics_;
258 MockGLib glib_;
259 MockManager manager_;
Arman Uguray6e5639f2012-11-15 20:30:19 -0800260 scoped_ptr<mm1::MockBearerProxy> bearer_proxy_;
Jason Glasgowef965562012-04-10 16:12:35 -0400261 scoped_ptr<mm1::MockModemModem3gppProxy> modem_3gpp_proxy_;
262 scoped_ptr<mm1::MockModemModemCdmaProxy> modem_cdma_proxy_;
263 scoped_ptr<mm1::MockModemProxy> modem_proxy_;
264 scoped_ptr<mm1::MockModemSimpleProxy> modem_simple_proxy_;
265 scoped_ptr<mm1::MockSimProxy> sim_proxy_;
Jason Glasgowaf583282012-04-18 15:18:22 -0400266 scoped_ptr<MockDBusPropertiesProxy> properties_proxy_;
Jason Glasgowef965562012-04-10 16:12:35 -0400267 TestProxyFactory proxy_factory_;
268 CellularCapabilityUniversal *capability_; // Owned by |cellular_|.
269 NiceMock<DeviceMockAdaptor> *device_adaptor_; // Owned by |cellular_|.
Ben Chan15786032012-11-04 21:28:02 -0800270 MockCellularOperatorInfo cellular_operator_info_;
Jason Glasgow4380f0d2012-05-03 18:05:04 -0400271 mobile_provider_db *provider_db_;
Ben Chan3ecdf822012-08-06 12:29:23 -0700272 CellularRefPtr cellular_;
273 MockCellularService *service_; // owned by cellular_
Jason Glasgowcd0349c2012-05-03 23:32:15 -0400274 DBusPropertyMapsCallback scan_callback_; // saved for testing scan operations
Jason Glasgow14521872012-05-07 19:12:15 -0400275 DBusPathCallback connect_callback_; // saved for testing connect operations
Jason Glasgowef965562012-04-10 16:12:35 -0400276};
277
Arman Uguray6e5639f2012-11-15 20:30:19 -0800278const char CellularCapabilityUniversalTest::kActiveBearerPathPrefix[] =
279 "/bearer/active";
Jason Glasgowef965562012-04-10 16:12:35 -0400280const char CellularCapabilityUniversalTest::kImei[] = "999911110000";
Arman Uguray6e5639f2012-11-15 20:30:19 -0800281const char CellularCapabilityUniversalTest::kInactiveBearerPathPrefix[] =
282 "/bearer/inactive";
Jason Glasgowaf583282012-04-18 15:18:22 -0400283const char CellularCapabilityUniversalTest::kSimPath[] = "/foo/sim";
284const uint32 CellularCapabilityUniversalTest::kAccessTechnologies =
285 MM_MODEM_ACCESS_TECHNOLOGY_LTE |
286 MM_MODEM_ACCESS_TECHNOLOGY_HSPA_PLUS;
Jason Glasgowef965562012-04-10 16:12:35 -0400287
288TEST_F(CellularCapabilityUniversalTest, StartModem) {
Jason Glasgowaf583282012-04-18 15:18:22 -0400289 // Set up mock modem properties
290 DBusPropertiesMap modem_properties;
291 string operator_name = "TestOperator";
292 string operator_code = "001400";
293
294 modem_properties[MM_MODEM_PROPERTY_ACCESSTECHNOLOGIES].
295 writer().append_uint32(kAccessTechnologies);
296
297 ::DBus::Variant v;
298 ::DBus::MessageIter writer = v.writer();
Jason Glasgowef965562012-04-10 16:12:35 -0400299 ::DBus::Struct< uint32_t, bool > quality;
300 quality._1 = 90;
301 quality._2 = true;
Jason Glasgowaf583282012-04-18 15:18:22 -0400302 writer << quality;
303 modem_properties[MM_MODEM_PROPERTY_SIGNALQUALITY] = v;
304
305 // Set up mock modem 3gpp properties
306 DBusPropertiesMap modem3gpp_properties;
307 modem3gpp_properties[MM_MODEM_MODEM3GPP_PROPERTY_ENABLEDFACILITYLOCKS].
308 writer().append_uint32(0);
309 modem3gpp_properties[MM_MODEM_MODEM3GPP_PROPERTY_IMEI].
310 writer().append_string(kImei);
311
312 EXPECT_CALL(*modem_proxy_,
313 Enable(true, _, _, CellularCapability::kTimeoutEnable))
314 .WillOnce(Invoke(this, &CellularCapabilityUniversalTest::InvokeEnable));
315 EXPECT_CALL(*properties_proxy_,
316 GetAll(MM_DBUS_INTERFACE_MODEM))
317 .WillOnce(Return(modem_properties));
318 EXPECT_CALL(*properties_proxy_,
319 GetAll(MM_DBUS_INTERFACE_MODEM_MODEM3GPP))
320 .WillOnce(Return(modem3gpp_properties));
Jason Glasgowef965562012-04-10 16:12:35 -0400321
Gary Moraine285a842012-08-15 08:23:57 -0700322 // Let the modem report that it is initializing. StartModem() should defer
323 // enabling the modem until its state changes to disabled.
324 EXPECT_CALL(*modem_proxy_, State())
325 .WillOnce(Return(Cellular::kModemStateInitializing));
326
Jason Glasgowef965562012-04-10 16:12:35 -0400327 // After setup we lose pointers to the proxies, so it is hard to set
328 // expectations.
329 SetUp();
330
331 Error error;
Gary Moraine285a842012-08-15 08:23:57 -0700332 EXPECT_CALL(*this, TestCallback(_)).Times(0);
Jason Glasgowef965562012-04-10 16:12:35 -0400333 ResultCallback callback =
334 Bind(&CellularCapabilityUniversalTest::TestCallback, Unretained(this));
335 capability_->StartModem(&error, callback);
Gary Moraine285a842012-08-15 08:23:57 -0700336
Arman Uguray6e5639f2012-11-15 20:30:19 -0800337 // Verify that the modem has not been enabled.
Gary Moraine285a842012-08-15 08:23:57 -0700338 EXPECT_TRUE(capability_->imei_.empty());
339 EXPECT_EQ(0, capability_->access_technologies_);
340 Mock::VerifyAndClearExpectations(this);
341
342 // Change the state to kModemStateDisabling and verify that it still has not
Arman Uguray6e5639f2012-11-15 20:30:19 -0800343 // been enabled.
Gary Moraine285a842012-08-15 08:23:57 -0700344 EXPECT_CALL(*this, TestCallback(_)).Times(0);
345 capability_->OnModemStateChangedSignal(Cellular::kModemStateInitializing,
346 Cellular::kModemStateDisabling, 0);
347 EXPECT_TRUE(capability_->imei_.empty());
348 EXPECT_EQ(0, capability_->access_technologies_);
349 Mock::VerifyAndClearExpectations(this);
350
351 // Change the state of the modem to disabled and verify that it gets enabled.
352 EXPECT_CALL(*this, TestCallback(IsSuccess()));
353 capability_->OnModemStateChangedSignal(Cellular::kModemStateDisabling,
354 Cellular::kModemStateDisabled, 0);
Jason Glasgowef965562012-04-10 16:12:35 -0400355 EXPECT_TRUE(error.IsSuccess());
Jason Glasgowaf583282012-04-18 15:18:22 -0400356 EXPECT_EQ(kImei, capability_->imei_);
357 EXPECT_EQ(kAccessTechnologies, capability_->access_technologies_);
Jason Glasgowef965562012-04-10 16:12:35 -0400358}
359
360TEST_F(CellularCapabilityUniversalTest, StartModemFail) {
Gary Moraine285a842012-08-15 08:23:57 -0700361 EXPECT_CALL(*modem_proxy_, State())
362 .WillOnce(Return(Cellular::kModemStateDisabled));
Jason Glasgowef965562012-04-10 16:12:35 -0400363 EXPECT_CALL(*modem_proxy_,
364 Enable(true, _, _, CellularCapability::kTimeoutEnable))
365 .WillOnce(
366 Invoke(this, &CellularCapabilityUniversalTest::InvokeEnableFail));
367 EXPECT_CALL(*this, TestCallback(IsFailure()));
368 ResultCallback callback =
369 Bind(&CellularCapabilityUniversalTest::TestCallback, Unretained(this));
370 SetUp();
371
372 Error error;
373 capability_->StartModem(&error, callback);
Thieu Lee3b36592012-08-30 17:50:26 -0700374 EXPECT_TRUE(error.IsOngoing());
Jason Glasgowef965562012-04-10 16:12:35 -0400375}
376
Jason Glasgow02401cc2012-05-16 10:35:37 -0400377TEST_F(CellularCapabilityUniversalTest, StopModem) {
378 // Save pointers to proxies before they are lost by the call to InitProxies
379 mm1::MockModemProxy *modem_proxy = modem_proxy_.get();
380 SetUp();
381 EXPECT_CALL(*modem_proxy, set_state_changed_callback(_));
382 capability_->InitProxies();
383
384 Error error;
385 ResultCallback callback =
386 Bind(&CellularCapabilityUniversalTest::TestCallback, Unretained(this));
387 capability_->StopModem(&error, callback);
388 EXPECT_TRUE(error.IsSuccess());
389
390 ResultCallback disable_callback;
391 EXPECT_CALL(*modem_proxy,
392 Enable(false, _, _, CellularCapability::kTimeoutEnable))
393 .WillOnce(SaveArg<2>(&disable_callback));
394 dispatcher_.DispatchPendingEvents();
395
396 EXPECT_CALL(*this, TestCallback(IsSuccess()));
397 disable_callback.Run(Error(Error::kSuccess));
398}
399
400TEST_F(CellularCapabilityUniversalTest, StopModemConnected) {
401 // Save pointers to proxies before they are lost by the call to InitProxies
402 mm1::MockModemProxy *modem_proxy = modem_proxy_.get();
403 mm1::MockModemSimpleProxy *modem_simple_proxy = modem_simple_proxy_.get();
404 SetUp();
405 EXPECT_CALL(*modem_proxy, set_state_changed_callback(_));
406 capability_->InitProxies();
407
408 ResultCallback disconnect_callback;
409 Error error;
410 ResultCallback callback =
411 Bind(&CellularCapabilityUniversalTest::TestCallback, Unretained(this));
412 EXPECT_CALL(*modem_simple_proxy,
413 Disconnect(::DBus::Path("/"), _, _,
Thieu Le049adb52012-11-12 17:14:51 -0800414 CellularCapability::kTimeoutDisconnect))
Jason Glasgow02401cc2012-05-16 10:35:37 -0400415 .WillOnce(SaveArg<2>(&disconnect_callback));
Thieu Led0012052012-07-25 16:09:09 -0700416 capability_->cellular()->modem_state_ = Cellular::kModemStateConnected;
Jason Glasgow02401cc2012-05-16 10:35:37 -0400417 capability_->StopModem(&error, callback);
418 EXPECT_TRUE(error.IsSuccess());
419
420 ResultCallback disable_callback;
421 EXPECT_CALL(*modem_proxy,
422 Enable(false, _, _, CellularCapability::kTimeoutEnable))
423 .WillOnce(SaveArg<2>(&disable_callback));
424 disconnect_callback.Run(Error(Error::kSuccess));
425
426 EXPECT_CALL(*this, TestCallback(IsSuccess()));
427 disable_callback.Run(Error(Error::kSuccess));
428}
429
Thieu Le5d6864a2012-07-20 11:43:51 -0700430TEST_F(CellularCapabilityUniversalTest, DisconnectModemNoBearer) {
431 Error error;
432 ResultCallback disconnect_callback;
Thieu Le3d275392012-07-20 15:32:58 -0700433 EXPECT_CALL(*modem_simple_proxy_,
Thieu Le049adb52012-11-12 17:14:51 -0800434 Disconnect(_, _, _, CellularCapability::kTimeoutDisconnect))
Thieu Le5d6864a2012-07-20 11:43:51 -0700435 .Times(0);
436 capability_->Disconnect(&error, disconnect_callback);
437}
438
Thieu Le3d275392012-07-20 15:32:58 -0700439TEST_F(CellularCapabilityUniversalTest, DisconnectNoProxy) {
440 Error error;
441 ResultCallback disconnect_callback;
442 capability_->bearer_path_ = "/foo";
443 EXPECT_CALL(*modem_simple_proxy_,
Thieu Le049adb52012-11-12 17:14:51 -0800444 Disconnect(_, _, _, CellularCapability::kTimeoutDisconnect))
Thieu Le3d275392012-07-20 15:32:58 -0700445 .Times(0);
446 ReleaseCapabilityProxies();
447 capability_->Disconnect(&error, disconnect_callback);
448}
449
Jason Glasgowaf583282012-04-18 15:18:22 -0400450TEST_F(CellularCapabilityUniversalTest, PropertiesChanged) {
451 // Set up mock modem properties
452 DBusPropertiesMap modem_properties;
453 modem_properties[MM_MODEM_PROPERTY_ACCESSTECHNOLOGIES].
454 writer().append_uint32(kAccessTechnologies);
455 modem_properties[MM_MODEM_PROPERTY_SIM].
456 writer().append_path(kSimPath);
457
458 // Set up mock modem 3gpp properties
459 DBusPropertiesMap modem3gpp_properties;
460 modem3gpp_properties[MM_MODEM_MODEM3GPP_PROPERTY_ENABLEDFACILITYLOCKS].
461 writer().append_uint32(0);
462 modem3gpp_properties[MM_MODEM_MODEM3GPP_PROPERTY_IMEI].
463 writer().append_string(kImei);
464
465 // Set up mock modem sim properties
466 DBusPropertiesMap sim_properties;
467
468 // After setup we lose pointers to the proxies, so it is hard to set
469 // expectations.
470 EXPECT_CALL(*properties_proxy_,
471 GetAll(MM_DBUS_INTERFACE_SIM))
472 .WillOnce(Return(sim_properties));
473
474 SetUp();
475
476 EXPECT_EQ("", capability_->imei_);
477 EXPECT_EQ(MM_MODEM_ACCESS_TECHNOLOGY_UNKNOWN,
478 capability_->access_technologies_);
479 EXPECT_FALSE(capability_->sim_proxy_.get());
Jason Glasgowbad114b2012-05-21 15:24:16 -0400480 EXPECT_CALL(*device_adaptor_, EmitStringChanged(
481 flimflam::kTechnologyFamilyProperty, flimflam::kTechnologyFamilyGsm));
Jason Glasgowaf583282012-04-18 15:18:22 -0400482 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_MODEM,
483 modem_properties, vector<string>());
484 EXPECT_EQ(kAccessTechnologies, capability_->access_technologies_);
485 EXPECT_EQ(kSimPath, capability_->sim_path_);
486 EXPECT_TRUE(capability_->sim_proxy_.get());
487
488 // Changing properties on wrong interface will not have an effect
489 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_MODEM,
490 modem3gpp_properties,
491 vector<string>());
492 EXPECT_EQ("", capability_->imei_);
493
494 // Changing properties on the right interface gets reflected in the
495 // capabilities object
496 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_MODEM_MODEM3GPP,
497 modem3gpp_properties,
498 vector<string>());
499 EXPECT_EQ(kImei, capability_->imei_);
Jason Glasgowbad114b2012-05-21 15:24:16 -0400500
501 // Expect to see changes when the family changes
502 modem_properties.clear();
503 modem_properties[MM_MODEM_PROPERTY_ACCESSTECHNOLOGIES].
504 writer().append_uint32(MM_MODEM_ACCESS_TECHNOLOGY_1XRTT);
505 EXPECT_CALL(*device_adaptor_, EmitStringChanged(
506 flimflam::kTechnologyFamilyProperty, flimflam::kTechnologyFamilyCdma)).
507 Times(1);
508 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_MODEM,
509 modem_properties,
510 vector<string>());
511 // Back to LTE
512 modem_properties.clear();
513 modem_properties[MM_MODEM_PROPERTY_ACCESSTECHNOLOGIES].
514 writer().append_uint32(MM_MODEM_ACCESS_TECHNOLOGY_LTE);
515 EXPECT_CALL(*device_adaptor_, EmitStringChanged(
516 flimflam::kTechnologyFamilyProperty, flimflam::kTechnologyFamilyGsm)).
517 Times(1);
518 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_MODEM,
519 modem_properties,
520 vector<string>());
521
522 // LTE & CDMA - the device adaptor should not be called!
523 modem_properties.clear();
524 modem_properties[MM_MODEM_PROPERTY_ACCESSTECHNOLOGIES].
525 writer().append_uint32(MM_MODEM_ACCESS_TECHNOLOGY_LTE |
526 MM_MODEM_ACCESS_TECHNOLOGY_1XRTT);
527 EXPECT_CALL(*device_adaptor_, EmitStringChanged(_, _)).Times(0);
528 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_MODEM,
529 modem_properties,
530 vector<string>());
Jason Glasgowaf583282012-04-18 15:18:22 -0400531}
532
Ben Chanbd3aee82012-10-16 23:52:04 -0700533TEST_F(CellularCapabilityUniversalTest, SimPathChanged) {
534 // Set up mock modem SIM properties
535 const char kImsi[] = "310100000001";
536 const char kSimIdentifier[] = "9999888";
537 const char kOperatorIdentifier[] = "310240";
538 const char kOperatorName[] = "Custom SPN";
539 DBusPropertiesMap sim_properties;
540 sim_properties[MM_SIM_PROPERTY_IMSI].writer().append_string(kImsi);
541 sim_properties[MM_SIM_PROPERTY_SIMIDENTIFIER].writer()
542 .append_string(kSimIdentifier);
543 sim_properties[MM_SIM_PROPERTY_OPERATORIDENTIFIER].writer()
544 .append_string(kOperatorIdentifier);
545 sim_properties[MM_SIM_PROPERTY_OPERATORNAME].writer()
546 .append_string(kOperatorName);
547
548 EXPECT_CALL(*properties_proxy_, GetAll(MM_DBUS_INTERFACE_SIM))
549 .Times(1).WillOnce(Return(sim_properties));
550
551 EXPECT_FALSE(capability_->sim_present_);
552 EXPECT_TRUE(capability_->sim_proxy_ == NULL);
553 EXPECT_EQ("", capability_->sim_path_);
554 EXPECT_EQ("", capability_->imsi_);
555 EXPECT_EQ("", capability_->sim_identifier_);
556 EXPECT_EQ("", capability_->operator_id_);
557 EXPECT_EQ("", capability_->spn_);
558
559 capability_->OnSimPathChanged(kSimPath);
560 EXPECT_TRUE(capability_->sim_present_);
561 EXPECT_TRUE(capability_->sim_proxy_ != NULL);
562 EXPECT_EQ(kSimPath, capability_->sim_path_);
563 EXPECT_EQ(kImsi, capability_->imsi_);
564 EXPECT_EQ(kSimIdentifier, capability_->sim_identifier_);
565 EXPECT_EQ(kOperatorIdentifier, capability_->operator_id_);
566 EXPECT_EQ(kOperatorName, capability_->spn_);
567
568 // Changing to the same SIM path should be a no-op.
569 capability_->OnSimPathChanged(kSimPath);
570 EXPECT_TRUE(capability_->sim_present_);
571 EXPECT_TRUE(capability_->sim_proxy_ != NULL);
572 EXPECT_EQ(kSimPath, capability_->sim_path_);
573 EXPECT_EQ(kImsi, capability_->imsi_);
574 EXPECT_EQ(kSimIdentifier, capability_->sim_identifier_);
575 EXPECT_EQ(kOperatorIdentifier, capability_->operator_id_);
576 EXPECT_EQ(kOperatorName, capability_->spn_);
577
578 capability_->OnSimPathChanged("");
579 EXPECT_FALSE(capability_->sim_present_);
580 EXPECT_TRUE(capability_->sim_proxy_ == NULL);
581 EXPECT_EQ("", capability_->sim_path_);
582 EXPECT_EQ("", capability_->imsi_);
583 EXPECT_EQ("", capability_->sim_identifier_);
584 EXPECT_EQ("", capability_->operator_id_);
585 EXPECT_EQ("", capability_->spn_);
586}
587
Jason Glasgowaf583282012-04-18 15:18:22 -0400588TEST_F(CellularCapabilityUniversalTest, SimPropertiesChanged) {
589 // Set up mock modem properties
590 DBusPropertiesMap modem_properties;
591 modem_properties[MM_MODEM_PROPERTY_SIM].writer().append_path(kSimPath);
592
593 // Set up mock modem sim properties
594 const char kImsi[] = "310100000001";
595 DBusPropertiesMap sim_properties;
596 sim_properties[MM_SIM_PROPERTY_IMSI].writer().append_string(kImsi);
597
598 EXPECT_CALL(*properties_proxy_, GetAll(MM_DBUS_INTERFACE_SIM))
599 .WillOnce(Return(sim_properties));
600
601 // After setup we lose pointers to the proxies, so it is hard to set
602 // expectations.
603 SetUp();
Jason Glasgow4380f0d2012-05-03 18:05:04 -0400604 InitProviderDB();
Jason Glasgowaf583282012-04-18 15:18:22 -0400605
Jason Glasgow4380f0d2012-05-03 18:05:04 -0400606 EXPECT_TRUE(cellular_->home_provider().GetName().empty());
607 EXPECT_TRUE(cellular_->home_provider().GetCountry().empty());
608 EXPECT_TRUE(cellular_->home_provider().GetCode().empty());
Jason Glasgowaf583282012-04-18 15:18:22 -0400609 EXPECT_FALSE(capability_->sim_proxy_.get());
610 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_MODEM,
611 modem_properties, vector<string>());
612 EXPECT_EQ(kSimPath, capability_->sim_path_);
613 EXPECT_TRUE(capability_->sim_proxy_.get());
614 EXPECT_EQ(kImsi, capability_->imsi_);
615
616 // Updating the SIM
617 DBusPropertiesMap new_properties;
Jason Glasgow4380f0d2012-05-03 18:05:04 -0400618 const char kCountry[] = "us";
619 const char kCode[] = "310160";
620 const char kNewImsi[] = "310240123456789";
Jason Glasgowaf583282012-04-18 15:18:22 -0400621 const char kSimIdentifier[] = "9999888";
Jason Glasgow4380f0d2012-05-03 18:05:04 -0400622 const char kOperatorIdentifier[] = "310240";
623 const char kOperatorName[] = "Custom SPN";
Jason Glasgowaf583282012-04-18 15:18:22 -0400624 new_properties[MM_SIM_PROPERTY_IMSI].writer().append_string(kNewImsi);
625 new_properties[MM_SIM_PROPERTY_SIMIDENTIFIER].writer().
626 append_string(kSimIdentifier);
627 new_properties[MM_SIM_PROPERTY_OPERATORIDENTIFIER].writer().
628 append_string(kOperatorIdentifier);
Jason Glasgowaf583282012-04-18 15:18:22 -0400629 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_SIM,
630 new_properties,
631 vector<string>());
632 EXPECT_EQ(kNewImsi, capability_->imsi_);
633 EXPECT_EQ(kSimIdentifier, capability_->sim_identifier_);
634 EXPECT_EQ(kOperatorIdentifier, capability_->operator_id_);
Jason Glasgow4380f0d2012-05-03 18:05:04 -0400635 EXPECT_EQ("", capability_->spn_);
636 EXPECT_EQ("T-Mobile", cellular_->home_provider().GetName());
637 EXPECT_EQ(kCountry, cellular_->home_provider().GetCountry());
638 EXPECT_EQ(kCode, cellular_->home_provider().GetCode());
639 EXPECT_EQ(4, capability_->apn_list_.size());
640
641 new_properties[MM_SIM_PROPERTY_OPERATORNAME].writer().
642 append_string(kOperatorName);
643 capability_->OnDBusPropertiesChanged(MM_DBUS_INTERFACE_SIM,
644 new_properties,
645 vector<string>());
646 EXPECT_EQ(kOperatorName, cellular_->home_provider().GetName());
Jason Glasgowaf583282012-04-18 15:18:22 -0400647 EXPECT_EQ(kOperatorName, capability_->spn_);
648}
649
Gary Morainceba6aa2012-05-03 10:28:26 -0700650MATCHER_P(SizeIs, value, "") {
651 return static_cast<size_t>(value) == arg.size();
652}
653
654// Validates that OnScanReply does not crash with a null callback.
655TEST_F(CellularCapabilityUniversalTest, ScanWithNullCallback) {
656 Error error;
657 EXPECT_CALL(*modem_3gpp_proxy_, Scan(_, _, CellularCapability::kTimeoutScan))
658 .WillOnce(Invoke(this, &CellularCapabilityUniversalTest::InvokeScan));
659 EXPECT_CALL(*device_adaptor_,
660 EmitStringmapsChanged(flimflam::kFoundNetworksProperty,
661 SizeIs(0)));
662 Set3gppProxy();
663 capability_->Scan(&error, ResultCallback());
664 EXPECT_TRUE(error.IsSuccess());
665}
666
Jason Glasgowcd0349c2012-05-03 23:32:15 -0400667// Validates that the scanning property is updated
668TEST_F(CellularCapabilityUniversalTest, Scan) {
669 Error error;
670
671 EXPECT_CALL(*modem_3gpp_proxy_, Scan(_, _, CellularCapability::kTimeoutScan))
672 .WillRepeatedly(SaveArg<1>(&scan_callback_));
673 EXPECT_CALL(*device_adaptor_,
674 EmitBoolChanged(flimflam::kScanningProperty, true));
675 Set3gppProxy();
676 capability_->Scan(&error, ResultCallback());
677 EXPECT_TRUE(capability_->scanning_);
678
679 // Simulate the completion of the scan with 2 networks in the results.
680 EXPECT_CALL(*device_adaptor_,
681 EmitBoolChanged(flimflam::kScanningProperty, false));
682 EXPECT_CALL(*device_adaptor_,
683 EmitStringmapsChanged(flimflam::kFoundNetworksProperty,
684 SizeIs(2)));
685 vector<DBusPropertiesMap> results;
686 const char kScanID0[] = "testID0";
687 const char kScanID1[] = "testID1";
688 results.push_back(DBusPropertiesMap());
689 results[0][CellularCapabilityUniversal::kOperatorLongProperty].
690 writer().append_string(kScanID0);
691 results.push_back(DBusPropertiesMap());
692 results[1][CellularCapabilityUniversal::kOperatorLongProperty].
693 writer().append_string(kScanID1);
694 scan_callback_.Run(results, error);
695 EXPECT_FALSE(capability_->scanning_);
696
697 // Simulate the completion of the scan with no networks in the results.
698 EXPECT_CALL(*device_adaptor_,
699 EmitBoolChanged(flimflam::kScanningProperty, true));
700 capability_->Scan(&error, ResultCallback());
701 EXPECT_TRUE(capability_->scanning_);
702 EXPECT_CALL(*device_adaptor_,
703 EmitBoolChanged(flimflam::kScanningProperty, false));
704 EXPECT_CALL(*device_adaptor_,
705 EmitStringmapsChanged(flimflam::kFoundNetworksProperty,
706 SizeIs(0)));
707 scan_callback_.Run(vector<DBusPropertiesMap>(), Error());
708 EXPECT_FALSE(capability_->scanning_);
709}
710
711// Validates expected property updates when scan fails
712TEST_F(CellularCapabilityUniversalTest, ScanFailure) {
713 Error error;
714
715 // Test immediate error
716 {
717 InSequence seq;
718 EXPECT_CALL(*modem_3gpp_proxy_,
719 Scan(_, _, CellularCapability::kTimeoutScan))
720 .WillOnce(Invoke(this, &CellularCapabilityUniversalTest::ScanError));
721 EXPECT_CALL(*modem_3gpp_proxy_,
722 Scan(_, _, CellularCapability::kTimeoutScan))
723 .WillOnce(SaveArg<1>(&scan_callback_));
724 }
725 Set3gppProxy();
726 capability_->Scan(&error, ResultCallback());
727 EXPECT_FALSE(capability_->scanning_);
728 EXPECT_TRUE(error.IsFailure());
729
730 // Initiate a scan
731 error.Populate(Error::kSuccess);
732 EXPECT_CALL(*device_adaptor_,
733 EmitBoolChanged(flimflam::kScanningProperty, true));
734 capability_->Scan(&error, ResultCallback());
735 EXPECT_TRUE(capability_->scanning_);
736 EXPECT_TRUE(error.IsSuccess());
737
738 // Validate that error is returned if Scan is called while already scanning.
739 capability_->Scan(&error, ResultCallback());
740 EXPECT_TRUE(capability_->scanning_);
741 EXPECT_TRUE(error.IsFailure());
742
743 // Validate that signals are emitted even if an error is reported.
744 capability_->found_networks_.clear();
745 capability_->found_networks_.push_back(Stringmap());
746 EXPECT_CALL(*device_adaptor_,
747 EmitBoolChanged(flimflam::kScanningProperty, false));
748 EXPECT_CALL(*device_adaptor_,
749 EmitStringmapsChanged(flimflam::kFoundNetworksProperty,
750 SizeIs(0)));
751 vector<DBusPropertiesMap> results;
752 scan_callback_.Run(results, Error(Error::kOperationFailed));
753 EXPECT_FALSE(capability_->scanning_);
754}
755
Arman Uguray6e5639f2012-11-15 20:30:19 -0800756// Validates expected behavior of OnListBearersReply function
757TEST_F(CellularCapabilityUniversalTest, OnListBearersReply) {
758 // Check that bearer_path_ is set correctly when an active bearer
759 // is returned.
760 const size_t kPathCount = 3;
761 DBus::Path active_paths[kPathCount], inactive_paths[kPathCount];
762 for (size_t i = 0; i < kPathCount; ++i) {
763 active_paths[i] =
764 DBus::Path(base::StringPrintf("%s/%zu", kActiveBearerPathPrefix, i));
765 inactive_paths[i] =
766 DBus::Path(base::StringPrintf("%s/%zu", kInactiveBearerPathPrefix, i));
767 }
768
769 std::vector<DBus::Path> paths;
770 paths.push_back(inactive_paths[0]);
771 paths.push_back(inactive_paths[1]);
772 paths.push_back(active_paths[2]);
773 paths.push_back(inactive_paths[1]);
774 paths.push_back(inactive_paths[2]);
775
776 Error error;
777 capability_->OnListBearersReply(paths, error);
778 EXPECT_STREQ(capability_->bearer_path_.c_str(), active_paths[2].c_str());
779
780 paths.clear();
781
782 // Check that bearer_path_ is empty if no active bearers are returned.
783 paths.push_back(inactive_paths[0]);
784 paths.push_back(inactive_paths[1]);
785 paths.push_back(inactive_paths[2]);
786 paths.push_back(inactive_paths[1]);
787
788 capability_->OnListBearersReply(paths, error);
789 EXPECT_TRUE(capability_->bearer_path_.empty());
790
791 // Check that returning multiple bearers causes death.
792 paths.push_back(active_paths[0]);
793 paths.push_back(inactive_paths[1]);
794 paths.push_back(inactive_paths[2]);
795 paths.push_back(active_paths[1]);
796 paths.push_back(inactive_paths[1]);
797
798 EXPECT_DEATH(capability_->OnListBearersReply(paths, error),
799 "Found more than one active bearer.");
800}
801
Jason Glasgow14521872012-05-07 19:12:15 -0400802// Validates expected behavior of Connect function
803TEST_F(CellularCapabilityUniversalTest, Connect) {
804 mm1::MockModemSimpleProxy *modem_simple_proxy = modem_simple_proxy_.get();
805 SetSimpleProxy();
806 Error error;
807 DBusPropertiesMap properties;
808 capability_->apn_try_list_.clear();
809 ResultCallback callback =
810 Bind(&CellularCapabilityUniversalTest::TestCallback, Unretained(this));
811 DBus::Path bearer("/foo");
812
813 // Test connect failures
814 EXPECT_CALL(*modem_simple_proxy, Connect(_, _, _, _))
815 .WillOnce(SaveArg<2>(&connect_callback_));
816 capability_->Connect(properties, &error, callback);
817 EXPECT_TRUE(error.IsSuccess());
818 EXPECT_CALL(*this, TestCallback(IsFailure()));
819 EXPECT_CALL(*service_, ClearLastGoodApn());
820 connect_callback_.Run(bearer, Error(Error::kOperationFailed));
821
822 // Test connect success
823 EXPECT_CALL(*modem_simple_proxy, Connect(_, _, _, _))
824 .WillOnce(SaveArg<2>(&connect_callback_));
825 capability_->Connect(properties, &error, callback);
826 EXPECT_TRUE(error.IsSuccess());
827 EXPECT_CALL(*this, TestCallback(IsSuccess()));
828 connect_callback_.Run(bearer, Error(Error::kSuccess));
Jason Glasgow7234ec32012-05-23 16:01:21 -0400829
830 // Test connect failures without a service. Make sure that shill
831 // does not crash if the connect failed and there is no
832 // CellularService object. This can happen if the modem is enabled
833 // and then quickly disabled.
834 cellular_->service_ = NULL;
835 EXPECT_FALSE(capability_->cellular()->service());
836 EXPECT_CALL(*modem_simple_proxy, Connect(_, _, _, _))
837 .WillOnce(SaveArg<2>(&connect_callback_));
838 capability_->Connect(properties, &error, callback);
839 EXPECT_TRUE(error.IsSuccess());
840 EXPECT_CALL(*this, TestCallback(IsFailure()));
841 connect_callback_.Run(bearer, Error(Error::kOperationFailed));
Jason Glasgow14521872012-05-07 19:12:15 -0400842}
843
844// Validates Connect iterates over APNs
845TEST_F(CellularCapabilityUniversalTest, ConnectApns) {
846 mm1::MockModemSimpleProxy *modem_simple_proxy = modem_simple_proxy_.get();
847 SetSimpleProxy();
848 Error error;
849 DBusPropertiesMap properties;
850 capability_->apn_try_list_.clear();
851 ResultCallback callback =
852 Bind(&CellularCapabilityUniversalTest::TestCallback, Unretained(this));
853 DBus::Path bearer("/bearer0");
854
855 const char apn_name_foo[] = "foo";
856 const char apn_name_bar[] = "bar";
857 EXPECT_CALL(*modem_simple_proxy, Connect(HasApn(apn_name_foo), _, _, _))
858 .WillOnce(SaveArg<2>(&connect_callback_));
859 Stringmap apn1;
860 apn1[flimflam::kApnProperty] = apn_name_foo;
861 capability_->apn_try_list_.push_back(apn1);
862 Stringmap apn2;
863 apn2[flimflam::kApnProperty] = apn_name_bar;
864 capability_->apn_try_list_.push_back(apn2);
865 capability_->FillConnectPropertyMap(&properties);
866 capability_->Connect(properties, &error, callback);
867 EXPECT_TRUE(error.IsSuccess());
868
869 EXPECT_CALL(*modem_simple_proxy, Connect(HasApn(apn_name_bar), _, _, _))
870 .WillOnce(SaveArg<2>(&connect_callback_));
871 EXPECT_CALL(*service_, ClearLastGoodApn());
872 connect_callback_.Run(bearer, Error(Error::kInvalidApn));
873
874 EXPECT_CALL(*service_, SetLastGoodApn(apn2));
875 EXPECT_CALL(*this, TestCallback(IsSuccess()));
876 connect_callback_.Run(bearer, Error(Error::kSuccess));
877}
878
Jason Glasgow9f09aef2012-05-08 16:26:55 -0400879// Validates GetTypeString and AccessTechnologyToTechnologyFamily
880TEST_F(CellularCapabilityUniversalTest, GetTypeString) {
881 const int gsm_technologies[] = {
882 MM_MODEM_ACCESS_TECHNOLOGY_LTE,
883 MM_MODEM_ACCESS_TECHNOLOGY_HSPA_PLUS,
884 MM_MODEM_ACCESS_TECHNOLOGY_HSPA,
885 MM_MODEM_ACCESS_TECHNOLOGY_HSUPA,
886 MM_MODEM_ACCESS_TECHNOLOGY_HSDPA,
887 MM_MODEM_ACCESS_TECHNOLOGY_UMTS,
888 MM_MODEM_ACCESS_TECHNOLOGY_EDGE,
889 MM_MODEM_ACCESS_TECHNOLOGY_GPRS,
890 MM_MODEM_ACCESS_TECHNOLOGY_GSM_COMPACT,
891 MM_MODEM_ACCESS_TECHNOLOGY_GSM,
892 MM_MODEM_ACCESS_TECHNOLOGY_LTE | MM_MODEM_ACCESS_TECHNOLOGY_EVDO0,
893 MM_MODEM_ACCESS_TECHNOLOGY_GSM | MM_MODEM_ACCESS_TECHNOLOGY_EVDO0,
894 MM_MODEM_ACCESS_TECHNOLOGY_LTE | MM_MODEM_ACCESS_TECHNOLOGY_EVDOA,
895 MM_MODEM_ACCESS_TECHNOLOGY_GSM | MM_MODEM_ACCESS_TECHNOLOGY_EVDOA,
896 MM_MODEM_ACCESS_TECHNOLOGY_LTE | MM_MODEM_ACCESS_TECHNOLOGY_EVDOB,
897 MM_MODEM_ACCESS_TECHNOLOGY_GSM | MM_MODEM_ACCESS_TECHNOLOGY_EVDOB,
898 MM_MODEM_ACCESS_TECHNOLOGY_GSM | MM_MODEM_ACCESS_TECHNOLOGY_1XRTT,
899 };
Ben Chan62028b22012-11-05 11:20:02 -0800900 for (size_t i = 0; i < arraysize(gsm_technologies); ++i) {
Jason Glasgow9f09aef2012-05-08 16:26:55 -0400901 capability_->access_technologies_ = gsm_technologies[i];
902 ASSERT_EQ(capability_->GetTypeString(), flimflam::kTechnologyFamilyGsm);
903 }
904 const int cdma_technologies[] = {
905 MM_MODEM_ACCESS_TECHNOLOGY_EVDO0,
906 MM_MODEM_ACCESS_TECHNOLOGY_EVDOA,
907 MM_MODEM_ACCESS_TECHNOLOGY_EVDOA | MM_MODEM_ACCESS_TECHNOLOGY_EVDO0,
908 MM_MODEM_ACCESS_TECHNOLOGY_EVDOB,
909 MM_MODEM_ACCESS_TECHNOLOGY_EVDOB | MM_MODEM_ACCESS_TECHNOLOGY_EVDO0,
910 MM_MODEM_ACCESS_TECHNOLOGY_1XRTT,
911 };
Ben Chan62028b22012-11-05 11:20:02 -0800912 for (size_t i = 0; i < arraysize(cdma_technologies); ++i) {
Jason Glasgow9f09aef2012-05-08 16:26:55 -0400913 capability_->access_technologies_ = cdma_technologies[i];
914 ASSERT_EQ(capability_->GetTypeString(), flimflam::kTechnologyFamilyCdma);
915 }
916 capability_->access_technologies_ = MM_MODEM_ACCESS_TECHNOLOGY_UNKNOWN;
917 ASSERT_EQ(capability_->GetTypeString(), "");
918}
919
Darin Petkovf508c822012-09-21 13:43:17 +0200920TEST_F(CellularCapabilityUniversalTest, AllowRoaming) {
921 EXPECT_FALSE(cellular_->allow_roaming_);
922 EXPECT_FALSE(capability_->provider_requires_roaming_);
923 EXPECT_FALSE(capability_->AllowRoaming());
924 capability_->provider_requires_roaming_ = true;
925 EXPECT_TRUE(capability_->AllowRoaming());
926 capability_->provider_requires_roaming_ = false;
927 cellular_->allow_roaming_ = true;
928 EXPECT_TRUE(capability_->AllowRoaming());
929}
930
Darin Petkovb4fccd22012-08-10 11:59:26 +0200931TEST_F(CellularCapabilityUniversalTest, SetHomeProvider) {
932 static const char kTestCarrier[] = "The Cellular Carrier";
933 static const char kCountry[] = "us";
934 static const char kCode[] = "310160";
935 capability_->imsi_ = "310240123456789";
936
Darin Petkovf508c822012-09-21 13:43:17 +0200937 EXPECT_FALSE(capability_->home_provider_);
938 EXPECT_FALSE(capability_->provider_requires_roaming_);
939
Darin Petkovb4fccd22012-08-10 11:59:26 +0200940 capability_->SetHomeProvider(); // No mobile provider DB available.
941 EXPECT_TRUE(cellular_->home_provider().GetName().empty());
942 EXPECT_TRUE(cellular_->home_provider().GetCountry().empty());
943 EXPECT_TRUE(cellular_->home_provider().GetCode().empty());
Darin Petkovf508c822012-09-21 13:43:17 +0200944 EXPECT_FALSE(capability_->provider_requires_roaming_);
Darin Petkovb4fccd22012-08-10 11:59:26 +0200945
946 InitProviderDB();
947 capability_->SetHomeProvider();
948 EXPECT_EQ("T-Mobile", cellular_->home_provider().GetName());
949 EXPECT_EQ(kCountry, cellular_->home_provider().GetCountry());
950 EXPECT_EQ(kCode, cellular_->home_provider().GetCode());
951 EXPECT_EQ(4, capability_->apn_list_.size());
952 ASSERT_TRUE(capability_->home_provider_);
Darin Petkovf508c822012-09-21 13:43:17 +0200953 EXPECT_FALSE(capability_->provider_requires_roaming_);
Darin Petkovb4fccd22012-08-10 11:59:26 +0200954
955 Cellular::Operator oper;
956 cellular_->set_home_provider(oper);
957 capability_->spn_ = kTestCarrier;
958 capability_->SetHomeProvider();
959 EXPECT_EQ(kTestCarrier, cellular_->home_provider().GetName());
960 EXPECT_EQ(kCountry, cellular_->home_provider().GetCountry());
961 EXPECT_EQ(kCode, cellular_->home_provider().GetCode());
Darin Petkovf508c822012-09-21 13:43:17 +0200962 EXPECT_FALSE(capability_->provider_requires_roaming_);
Darin Petkovb4fccd22012-08-10 11:59:26 +0200963
964 static const char kCubic[] = "Cubic";
965 capability_->spn_ = kCubic;
966 capability_->SetHomeProvider();
967 EXPECT_EQ(kCubic, cellular_->home_provider().GetName());
968 EXPECT_EQ("", cellular_->home_provider().GetCode());
969 ASSERT_TRUE(capability_->home_provider_);
Darin Petkovf508c822012-09-21 13:43:17 +0200970 EXPECT_TRUE(capability_->provider_requires_roaming_);
Darin Petkovb4fccd22012-08-10 11:59:26 +0200971
972 static const char kCUBIC[] = "CUBIC";
973 capability_->spn_ = kCUBIC;
974 capability_->home_provider_ = NULL;
975 capability_->SetHomeProvider();
976 EXPECT_EQ(kCUBIC, cellular_->home_provider().GetName());
977 EXPECT_EQ("", cellular_->home_provider().GetCode());
978 ASSERT_TRUE(capability_->home_provider_);
Darin Petkovf508c822012-09-21 13:43:17 +0200979 EXPECT_TRUE(capability_->provider_requires_roaming_);
Darin Petkovb4fccd22012-08-10 11:59:26 +0200980}
981
Ben Chan6d0d1e72012-11-06 21:19:28 -0800982TEST_F(CellularCapabilityUniversalTest, UpdateOLP) {
983 CellularService::OLP test_olp;
984 test_olp.SetURL("http://testurl");
985 test_olp.SetMethod("POST");
986 test_olp.SetPostData("esn=${esn}&imei=${imei}&imsi=${imsi}&mdn=${mdn}&"
987 "meid=${meid}&min=${min}&iccid=${iccid}");
988
989 MockCellularOperatorInfoGetOLPHelper get_olp_helper(test_olp);
990
991 capability_->esn_ = "0";
992 capability_->imei_ = "1";
993 capability_->imsi_ = "2";
994 capability_->mdn_ = "3";
995 capability_->meid_= "4";
996 capability_->min_ = "5";
997 capability_->sim_identifier_ = "6";
998 capability_->operator_id_ = "123456";
999 cellular_->cellular_operator_info_ = &cellular_operator_info_;
1000
1001 EXPECT_CALL(cellular_operator_info_, GetOLP(capability_->operator_id_, _))
Ben Chan092b12b2012-11-07 22:04:05 -08001002 .WillRepeatedly(Invoke(&get_olp_helper,
1003 &MockCellularOperatorInfoGetOLPHelper::GetOLP));
Ben Chan6d0d1e72012-11-06 21:19:28 -08001004
1005 SetService();
1006 capability_->UpdateOLP();
1007 const CellularService::OLP &olp = cellular_->service()->olp();
1008 EXPECT_EQ("http://testurl", olp.GetURL());
1009 EXPECT_EQ("POST", olp.GetMethod());
1010 EXPECT_EQ("esn=0&imei=1&imsi=2&mdn=3&meid=4&min=5&iccid=6",
1011 olp.GetPostData());
1012}
1013
Darin Petkova4ca3c32012-08-17 16:05:24 +02001014TEST_F(CellularCapabilityUniversalTest, UpdateOperatorInfo) {
1015 static const char kOperatorName[] = "Swisscom";
1016 InitProviderDB();
1017 capability_->serving_operator_.SetCode("22801");
1018 SetService();
1019 capability_->UpdateOperatorInfo();
1020 EXPECT_EQ(kOperatorName, capability_->serving_operator_.GetName());
1021 EXPECT_EQ("ch", capability_->serving_operator_.GetCountry());
1022 EXPECT_EQ(kOperatorName, cellular_->service()->serving_operator().GetName());
1023
1024 static const char kTestOperator[] = "Testcom";
1025 capability_->serving_operator_.SetName(kTestOperator);
1026 capability_->serving_operator_.SetCountry("");
1027 capability_->UpdateOperatorInfo();
1028 EXPECT_EQ(kTestOperator, capability_->serving_operator_.GetName());
1029 EXPECT_EQ("ch", capability_->serving_operator_.GetCountry());
1030 EXPECT_EQ(kTestOperator, cellular_->service()->serving_operator().GetName());
1031}
1032
Ben Chan092b12b2012-11-07 22:04:05 -08001033TEST_F(CellularCapabilityUniversalTest, UpdateOperatorInfoViaOperatorId) {
1034 static const char kOperatorName[] = "Swisscom";
1035 static const char kOperatorId[] = "22801";
1036 InitProviderDB();
1037 capability_->serving_operator_.SetCode("");
1038 SetService();
1039 capability_->UpdateOperatorInfo();
1040 EXPECT_EQ("", capability_->serving_operator_.GetName());
1041 EXPECT_EQ("", capability_->serving_operator_.GetCountry());
1042 EXPECT_EQ("", cellular_->service()->serving_operator().GetName());
1043
1044 capability_->operator_id_ = kOperatorId;
1045
1046 // Service activation is not needed
1047 cellular_->cellular_operator_info_ = &cellular_operator_info_;
1048 EXPECT_CALL(cellular_operator_info_, GetOLP(_, _))
1049 .WillOnce(Return(false));
1050 capability_->UpdateOperatorInfo();
1051 EXPECT_EQ("", capability_->serving_operator_.GetName());
1052 EXPECT_EQ("", capability_->serving_operator_.GetCountry());
1053 EXPECT_EQ("", cellular_->service()->serving_operator().GetName());
1054
1055 // Service activation is needed
1056 capability_->mdn_ = "0000000000";
1057 cellular_->cellular_operator_info_ = &cellular_operator_info_;
1058 EXPECT_CALL(cellular_operator_info_, GetOLP(_, _))
1059 .WillOnce(Return(true));
1060
1061 capability_->UpdateOperatorInfo();
1062 EXPECT_EQ(kOperatorId, capability_->serving_operator_.GetCode());
1063 EXPECT_EQ(kOperatorName, capability_->serving_operator_.GetName());
1064 EXPECT_EQ("ch", capability_->serving_operator_.GetCountry());
1065 EXPECT_EQ(kOperatorName, cellular_->service()->serving_operator().GetName());
1066}
1067
Darin Petkova4ca3c32012-08-17 16:05:24 +02001068TEST_F(CellularCapabilityUniversalTest, CreateFriendlyServiceName) {
1069 CellularCapabilityUniversal::friendly_service_name_id_ = 0;
1070 EXPECT_EQ("GSMNetwork0", capability_->CreateFriendlyServiceName());
1071 EXPECT_EQ("GSMNetwork1", capability_->CreateFriendlyServiceName());
1072
Ben Chan092b12b2012-11-07 22:04:05 -08001073 // Service activation is not needed
1074 capability_->operator_id_ = "0123";
1075 EXPECT_EQ("GSMNetwork2", capability_->CreateFriendlyServiceName());
1076
1077 // Service activation is needed
1078 capability_->mdn_ = "0000000000";
1079 cellular_->cellular_operator_info_ = &cellular_operator_info_;
1080 EXPECT_CALL(cellular_operator_info_, GetOLP(_, _))
1081 .WillOnce(Return(true));
1082 EXPECT_EQ("cellular_0123", capability_->CreateFriendlyServiceName());
1083 EXPECT_EQ("0123", capability_->serving_operator_.GetCode());
1084
Darin Petkova4ca3c32012-08-17 16:05:24 +02001085 capability_->serving_operator_.SetCode("1234");
1086 EXPECT_EQ("cellular_1234", capability_->CreateFriendlyServiceName());
1087
1088 static const char kHomeProvider[] = "The GSM Home Provider";
1089 cellular_->home_provider_.SetName(kHomeProvider);
1090 EXPECT_EQ("cellular_1234", capability_->CreateFriendlyServiceName());
1091 capability_->registration_state_ = MM_MODEM_3GPP_REGISTRATION_STATE_HOME;
1092 EXPECT_EQ(kHomeProvider, capability_->CreateFriendlyServiceName());
1093
1094 static const char kTestOperator[] = "A GSM Operator";
1095 capability_->serving_operator_.SetName(kTestOperator);
1096 EXPECT_EQ(kTestOperator, capability_->CreateFriendlyServiceName());
1097
1098 capability_->registration_state_ = MM_MODEM_3GPP_REGISTRATION_STATE_ROAMING;
1099 EXPECT_EQ(StringPrintf("%s | %s", kHomeProvider, kTestOperator),
1100 capability_->CreateFriendlyServiceName());
1101}
1102
Ben Chan15786032012-11-04 21:28:02 -08001103TEST_F(CellularCapabilityUniversalTest, IsServiceActivationRequired) {
1104 capability_->mdn_ = "0000000000";
1105 cellular_->cellular_operator_info_ = NULL;
1106 EXPECT_FALSE(capability_->IsServiceActivationRequired());
1107
1108 cellular_->cellular_operator_info_ = &cellular_operator_info_;
1109 EXPECT_CALL(cellular_operator_info_, GetOLP(_, _))
1110 .WillOnce(Return(false))
1111 .WillRepeatedly(Return(true));
1112 EXPECT_FALSE(capability_->IsServiceActivationRequired());
1113
1114 capability_->mdn_ = "";
1115 EXPECT_FALSE(capability_->IsServiceActivationRequired());
1116 capability_->mdn_ = "1234567890";
1117 EXPECT_FALSE(capability_->IsServiceActivationRequired());
1118 capability_->mdn_ = "+1-234-567-890";
1119 EXPECT_FALSE(capability_->IsServiceActivationRequired());
1120 capability_->mdn_ = "0000000000";
1121 EXPECT_TRUE(capability_->IsServiceActivationRequired());
1122 capability_->mdn_ = "0-000-000-000";
1123 EXPECT_TRUE(capability_->IsServiceActivationRequired());
1124 capability_->mdn_ = "+0-000-000-000";
1125 EXPECT_TRUE(capability_->IsServiceActivationRequired());
1126}
1127
Jason Glasgowef965562012-04-10 16:12:35 -04001128} // namespace shill