Thieu Le | 3426c8f | 2012-01-11 17:35:11 -0800 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium OS Authors. All rights reserved. |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 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/default_profile.h" |
| 6 | |
| 7 | #include <map> |
| 8 | #include <string> |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 9 | #include <vector> |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 10 | |
Chris Masone | 6515aab | 2011-10-12 16:19:09 -0700 | [diff] [blame] | 11 | #include <base/file_path.h> |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 12 | #include <chromeos/dbus/service_constants.h> |
| 13 | #include <gtest/gtest.h> |
| 14 | #include <gmock/gmock.h> |
| 15 | |
Chris Masone | 6515aab | 2011-10-12 16:19:09 -0700 | [diff] [blame] | 16 | #include "shill/key_file_store.h" |
| 17 | #include "shill/glib.h" |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 18 | #include "shill/manager.h" |
| 19 | #include "shill/mock_control.h" |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 20 | #include "shill/mock_device.h" |
Paul Stewart | f284a23 | 2012-05-01 10:24:37 -0700 | [diff] [blame] | 21 | #include "shill/mock_service.h" |
Chris Masone | aa48237 | 2011-09-14 16:40:37 -0700 | [diff] [blame] | 22 | #include "shill/mock_store.h" |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 23 | #include "shill/portal_detector.h" |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 24 | #include "shill/property_store_unittest.h" |
| 25 | |
| 26 | using std::map; |
| 27 | using std::string; |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 28 | using std::vector; |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 29 | using ::testing::_; |
Paul Stewart | 870523b | 2012-01-11 17:00:42 -0800 | [diff] [blame] | 30 | using ::testing::DoAll; |
Chris Masone | aa48237 | 2011-09-14 16:40:37 -0700 | [diff] [blame] | 31 | using ::testing::Return; |
Paul Stewart | 870523b | 2012-01-11 17:00:42 -0800 | [diff] [blame] | 32 | using ::testing::SetArgumentPointee; |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 33 | |
| 34 | namespace shill { |
| 35 | |
| 36 | class DefaultProfileTest : public PropertyStoreTest { |
| 37 | public: |
Chris Masone | 7aa5f90 | 2011-07-11 11:13:35 -0700 | [diff] [blame] | 38 | DefaultProfileTest() |
Chris Masone | 2176a88 | 2011-09-14 22:29:15 -0700 | [diff] [blame] | 39 | : profile_(new DefaultProfile(control_interface(), |
Chris Masone | 9d77993 | 2011-08-25 16:33:41 -0700 | [diff] [blame] | 40 | manager(), |
Chris Masone | 6515aab | 2011-10-12 16:19:09 -0700 | [diff] [blame] | 41 | FilePath(storage_path()), |
Paul Stewart | d0a3b81 | 2012-03-28 22:48:22 -0700 | [diff] [blame] | 42 | DefaultProfile::kDefaultId, |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 43 | properties_)), |
| 44 | device_(new MockDevice(control_interface(), |
| 45 | dispatcher(), |
Thieu Le | 3426c8f | 2012-01-11 17:35:11 -0800 | [diff] [blame] | 46 | metrics(), |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 47 | manager(), |
| 48 | "null0", |
| 49 | "addr0", |
| 50 | 0)) { |
Chris Masone | 7aa5f90 | 2011-07-11 11:13:35 -0700 | [diff] [blame] | 51 | } |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 52 | |
| 53 | virtual ~DefaultProfileTest() {} |
| 54 | |
Chris Masone | 6515aab | 2011-10-12 16:19:09 -0700 | [diff] [blame] | 55 | virtual void SetUp() { |
| 56 | PropertyStoreTest::SetUp(); |
| 57 | FilePath final_path; |
| 58 | ASSERT_TRUE(profile_->GetStoragePath(&final_path)); |
| 59 | scoped_ptr<KeyFileStore> storage(new KeyFileStore(&real_glib_)); |
| 60 | storage->set_path(final_path); |
| 61 | ASSERT_TRUE(storage->Open()); |
| 62 | profile_->set_storage(storage.release()); // Passes ownership. |
| 63 | } |
| 64 | |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 65 | protected: |
Chris Masone | 2ae797d | 2011-08-23 20:41:00 -0700 | [diff] [blame] | 66 | static const char kTestStoragePath[]; |
| 67 | |
Chris Masone | 6515aab | 2011-10-12 16:19:09 -0700 | [diff] [blame] | 68 | GLib real_glib_; |
Paul Stewart | 870523b | 2012-01-11 17:00:42 -0800 | [diff] [blame] | 69 | scoped_refptr<DefaultProfile> profile_; |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 70 | scoped_refptr<MockDevice> device_; |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 71 | Manager::Properties properties_; |
| 72 | }; |
| 73 | |
Chris Masone | 2ae797d | 2011-08-23 20:41:00 -0700 | [diff] [blame] | 74 | const char DefaultProfileTest::kTestStoragePath[] = "/no/where"; |
| 75 | |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 76 | TEST_F(DefaultProfileTest, GetProperties) { |
| 77 | Error error(Error::kInvalidProperty, ""); |
| 78 | { |
| 79 | map<string, ::DBus::Variant> props; |
| 80 | ::DBus::Error dbus_error; |
Chris Masone | 7aa5f90 | 2011-07-11 11:13:35 -0700 | [diff] [blame] | 81 | DBusAdaptor::GetProperties(profile_->store(), &props, &dbus_error); |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 82 | ASSERT_FALSE(props.find(flimflam::kOfflineModeProperty) == props.end()); |
| 83 | EXPECT_FALSE(props[flimflam::kOfflineModeProperty].reader().get_bool()); |
| 84 | } |
| 85 | properties_.offline_mode = true; |
| 86 | { |
| 87 | map<string, ::DBus::Variant> props; |
| 88 | ::DBus::Error dbus_error; |
Chris Masone | 7aa5f90 | 2011-07-11 11:13:35 -0700 | [diff] [blame] | 89 | DBusAdaptor::GetProperties(profile_->store(), &props, &dbus_error); |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 90 | ASSERT_FALSE(props.find(flimflam::kOfflineModeProperty) == props.end()); |
| 91 | EXPECT_TRUE(props[flimflam::kOfflineModeProperty].reader().get_bool()); |
| 92 | } |
| 93 | { |
| 94 | Error error(Error::kInvalidProperty, ""); |
| 95 | EXPECT_FALSE( |
mukesh agrawal | de29fa8 | 2011-09-16 16:16:36 -0700 | [diff] [blame] | 96 | profile_->mutable_store()->SetBoolProperty( |
| 97 | flimflam::kOfflineModeProperty, |
| 98 | true, |
| 99 | &error)); |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 100 | } |
| 101 | } |
| 102 | |
Chris Masone | aa48237 | 2011-09-14 16:40:37 -0700 | [diff] [blame] | 103 | TEST_F(DefaultProfileTest, Save) { |
Chris Masone | b9c0059 | 2011-10-06 13:10:39 -0700 | [diff] [blame] | 104 | scoped_ptr<MockStore> storage(new MockStore); |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 105 | EXPECT_CALL(*storage.get(), SetBool(DefaultProfile::kStorageId, |
| 106 | DefaultProfile::kStorageArpGateway, |
| 107 | true)) |
| 108 | .WillOnce(Return(true)); |
Chris Masone | b9c0059 | 2011-10-06 13:10:39 -0700 | [diff] [blame] | 109 | EXPECT_CALL(*storage.get(), SetString(DefaultProfile::kStorageId, |
| 110 | DefaultProfile::kStorageName, |
| 111 | DefaultProfile::kDefaultId)) |
Chris Masone | aa48237 | 2011-09-14 16:40:37 -0700 | [diff] [blame] | 112 | .WillOnce(Return(true)); |
Chris Masone | b9c0059 | 2011-10-06 13:10:39 -0700 | [diff] [blame] | 113 | EXPECT_CALL(*storage.get(), SetString(DefaultProfile::kStorageId, |
Paul Stewart | d32f484 | 2012-01-11 16:08:13 -0800 | [diff] [blame] | 114 | DefaultProfile::kStorageHostName, |
Chris Masone | b9c0059 | 2011-10-06 13:10:39 -0700 | [diff] [blame] | 115 | "")) |
Chris Masone | aa48237 | 2011-09-14 16:40:37 -0700 | [diff] [blame] | 116 | .WillOnce(Return(true)); |
Chris Masone | b9c0059 | 2011-10-06 13:10:39 -0700 | [diff] [blame] | 117 | EXPECT_CALL(*storage.get(), SetBool(DefaultProfile::kStorageId, |
| 118 | DefaultProfile::kStorageOfflineMode, |
| 119 | false)) |
Chris Masone | aa48237 | 2011-09-14 16:40:37 -0700 | [diff] [blame] | 120 | .WillOnce(Return(true)); |
Paul Stewart | d32f484 | 2012-01-11 16:08:13 -0800 | [diff] [blame] | 121 | EXPECT_CALL(*storage.get(), SetString(DefaultProfile::kStorageId, |
| 122 | DefaultProfile::kStorageCheckPortalList, |
| 123 | "")) |
| 124 | .WillOnce(Return(true)); |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 125 | EXPECT_CALL(*storage.get(), SetString(DefaultProfile::kStorageId, |
| 126 | DefaultProfile::kStoragePortalURL, |
| 127 | "")) |
| 128 | .WillOnce(Return(true)); |
Paul Stewart | c681fa0 | 2012-03-02 19:40:04 -0800 | [diff] [blame] | 129 | EXPECT_CALL(*storage.get(), |
| 130 | SetString(DefaultProfile::kStorageId, |
| 131 | DefaultProfile::kStoragePortalCheckInterval, |
| 132 | "0")) |
| 133 | .WillOnce(Return(true)); |
Chris Masone | b9c0059 | 2011-10-06 13:10:39 -0700 | [diff] [blame] | 134 | EXPECT_CALL(*storage.get(), Flush()).WillOnce(Return(true)); |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 135 | |
Chris Masone | b9c0059 | 2011-10-06 13:10:39 -0700 | [diff] [blame] | 136 | EXPECT_CALL(*device_.get(), Save(storage.get())).WillOnce(Return(true)); |
| 137 | profile_->set_storage(storage.release()); |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 138 | |
| 139 | manager()->RegisterDevice(device_); |
Chris Masone | b9c0059 | 2011-10-06 13:10:39 -0700 | [diff] [blame] | 140 | ASSERT_TRUE(profile_->Save()); |
Chris Masone | 877ff98 | 2011-09-21 16:18:24 -0700 | [diff] [blame] | 141 | manager()->DeregisterDevice(device_); |
Chris Masone | aa48237 | 2011-09-14 16:40:37 -0700 | [diff] [blame] | 142 | } |
| 143 | |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 144 | TEST_F(DefaultProfileTest, LoadManagerDefaultProperties) { |
| 145 | scoped_ptr<MockStore> storage(new MockStore); |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 146 | Manager::Properties manager_props; |
| 147 | EXPECT_CALL(*storage.get(), GetBool(DefaultProfile::kStorageId, |
| 148 | DefaultProfile::kStorageArpGateway, |
| 149 | &manager_props.arp_gateway)) |
| 150 | .WillOnce(Return(false)); |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 151 | EXPECT_CALL(*storage.get(), GetString(DefaultProfile::kStorageId, |
| 152 | DefaultProfile::kStorageHostName, |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 153 | &manager_props.host_name)) |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 154 | .WillOnce(Return(false)); |
| 155 | EXPECT_CALL(*storage.get(), GetBool(DefaultProfile::kStorageId, |
| 156 | DefaultProfile::kStorageOfflineMode, |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 157 | &manager_props.offline_mode)) |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 158 | .WillOnce(Return(false)); |
| 159 | EXPECT_CALL(*storage.get(), GetString(DefaultProfile::kStorageId, |
| 160 | DefaultProfile::kStorageCheckPortalList, |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 161 | &manager_props.check_portal_list)) |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 162 | .WillOnce(Return(false)); |
| 163 | EXPECT_CALL(*storage.get(), GetString(DefaultProfile::kStorageId, |
| 164 | DefaultProfile::kStoragePortalURL, |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 165 | &manager_props.portal_url)) |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 166 | .WillOnce(Return(false)); |
Paul Stewart | c681fa0 | 2012-03-02 19:40:04 -0800 | [diff] [blame] | 167 | EXPECT_CALL(*storage.get(), |
| 168 | GetString(DefaultProfile::kStorageId, |
| 169 | DefaultProfile::kStoragePortalCheckInterval, |
| 170 | _)) |
| 171 | .WillOnce(Return(false)); |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 172 | profile_->set_storage(storage.release()); |
| 173 | |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 174 | ASSERT_TRUE(profile_->LoadManagerProperties(&manager_props)); |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 175 | EXPECT_TRUE(manager_props.arp_gateway); |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 176 | EXPECT_EQ("", manager_props.host_name); |
| 177 | EXPECT_FALSE(manager_props.offline_mode); |
Paul Stewart | f555cf8 | 2012-03-15 14:42:43 -0700 | [diff] [blame] | 178 | EXPECT_EQ(PortalDetector::kDefaultCheckPortalList, |
| 179 | manager_props.check_portal_list); |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 180 | EXPECT_EQ(PortalDetector::kDefaultURL, manager_props.portal_url); |
Paul Stewart | c681fa0 | 2012-03-02 19:40:04 -0800 | [diff] [blame] | 181 | EXPECT_EQ(PortalDetector::kDefaultCheckIntervalSeconds, |
| 182 | manager_props.portal_check_interval_seconds); |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 183 | } |
| 184 | |
Paul Stewart | 870523b | 2012-01-11 17:00:42 -0800 | [diff] [blame] | 185 | TEST_F(DefaultProfileTest, LoadManagerProperties) { |
| 186 | scoped_ptr<MockStore> storage(new MockStore); |
Paul Stewart | d32f484 | 2012-01-11 16:08:13 -0800 | [diff] [blame] | 187 | const string host_name("hostname"); |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 188 | EXPECT_CALL(*storage.get(), GetBool(DefaultProfile::kStorageId, |
| 189 | DefaultProfile::kStorageArpGateway, |
| 190 | _)) |
| 191 | .WillOnce(DoAll(SetArgumentPointee<2>(false), Return(true))); |
Paul Stewart | d32f484 | 2012-01-11 16:08:13 -0800 | [diff] [blame] | 192 | EXPECT_CALL(*storage.get(), GetString(DefaultProfile::kStorageId, |
| 193 | DefaultProfile::kStorageHostName, |
| 194 | _)) |
| 195 | .WillOnce(DoAll(SetArgumentPointee<2>(host_name), Return(true))); |
Paul Stewart | 870523b | 2012-01-11 17:00:42 -0800 | [diff] [blame] | 196 | EXPECT_CALL(*storage.get(), GetBool(DefaultProfile::kStorageId, |
| 197 | DefaultProfile::kStorageOfflineMode, |
| 198 | _)) |
| 199 | .WillOnce(DoAll(SetArgumentPointee<2>(true), Return(true))); |
| 200 | const string portal_list("technology1,technology2"); |
| 201 | EXPECT_CALL(*storage.get(), GetString(DefaultProfile::kStorageId, |
| 202 | DefaultProfile::kStorageCheckPortalList, |
| 203 | _)) |
| 204 | .WillOnce(DoAll(SetArgumentPointee<2>(portal_list), Return(true))); |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 205 | const string portal_url("http://www.chromium.org"); |
| 206 | EXPECT_CALL(*storage.get(), GetString(DefaultProfile::kStorageId, |
| 207 | DefaultProfile::kStoragePortalURL, |
| 208 | _)) |
| 209 | .WillOnce(DoAll(SetArgumentPointee<2>(portal_url), Return(true))); |
Paul Stewart | c681fa0 | 2012-03-02 19:40:04 -0800 | [diff] [blame] | 210 | const string portal_check_interval_string("10"); |
| 211 | const int portal_check_interval_int = 10; |
| 212 | EXPECT_CALL(*storage.get(), |
| 213 | GetString(DefaultProfile::kStorageId, |
| 214 | DefaultProfile::kStoragePortalCheckInterval, |
| 215 | _)) |
| 216 | .WillOnce(DoAll(SetArgumentPointee<2>(portal_check_interval_string), |
| 217 | Return(true))); |
Paul Stewart | 870523b | 2012-01-11 17:00:42 -0800 | [diff] [blame] | 218 | profile_->set_storage(storage.release()); |
| 219 | |
| 220 | Manager::Properties manager_props; |
| 221 | ASSERT_TRUE(profile_->LoadManagerProperties(&manager_props)); |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 222 | EXPECT_FALSE(manager_props.arp_gateway); |
Paul Stewart | d32f484 | 2012-01-11 16:08:13 -0800 | [diff] [blame] | 223 | EXPECT_EQ(host_name, manager_props.host_name); |
Paul Stewart | 870523b | 2012-01-11 17:00:42 -0800 | [diff] [blame] | 224 | EXPECT_TRUE(manager_props.offline_mode); |
| 225 | EXPECT_EQ(portal_list, manager_props.check_portal_list); |
Paul Stewart | e692740 | 2012-01-23 16:11:30 -0800 | [diff] [blame] | 226 | EXPECT_EQ(portal_url, manager_props.portal_url); |
Paul Stewart | c681fa0 | 2012-03-02 19:40:04 -0800 | [diff] [blame] | 227 | EXPECT_EQ(portal_check_interval_int, |
| 228 | manager_props.portal_check_interval_seconds); |
Paul Stewart | 870523b | 2012-01-11 17:00:42 -0800 | [diff] [blame] | 229 | } |
| 230 | |
Chris Masone | 2ae797d | 2011-08-23 20:41:00 -0700 | [diff] [blame] | 231 | TEST_F(DefaultProfileTest, GetStoragePath) { |
| 232 | FilePath path; |
| 233 | EXPECT_TRUE(profile_->GetStoragePath(&path)); |
Chris Masone | 6515aab | 2011-10-12 16:19:09 -0700 | [diff] [blame] | 234 | EXPECT_EQ(storage_path() + "/default.profile", path.value()); |
Chris Masone | 2ae797d | 2011-08-23 20:41:00 -0700 | [diff] [blame] | 235 | } |
| 236 | |
Paul Stewart | f284a23 | 2012-05-01 10:24:37 -0700 | [diff] [blame] | 237 | TEST_F(DefaultProfileTest, ConfigureService) { |
| 238 | scoped_ptr<MockStore> storage(new MockStore); |
| 239 | EXPECT_CALL(*storage, ContainsGroup(_)) |
| 240 | .WillRepeatedly(Return(false)); |
| 241 | EXPECT_CALL(*storage, Flush()) |
| 242 | .WillOnce(Return(true)); |
| 243 | |
| 244 | scoped_refptr<MockService> unknown_service(new MockService( |
| 245 | control_interface(), |
| 246 | dispatcher(), |
| 247 | metrics(), |
| 248 | manager())); |
| 249 | EXPECT_CALL(*unknown_service, technology()) |
| 250 | .WillOnce(Return(Technology::kUnknown)); |
| 251 | EXPECT_CALL(*unknown_service, Save(_)) .Times(0); |
| 252 | |
| 253 | scoped_refptr<MockService> ethernet_service(new MockService( |
| 254 | control_interface(), |
| 255 | dispatcher(), |
| 256 | metrics(), |
| 257 | manager())); |
| 258 | EXPECT_CALL(*ethernet_service, technology()) |
| 259 | .WillOnce(Return(Technology::kEthernet)); |
| 260 | EXPECT_CALL(*ethernet_service, Save(storage.get())) |
| 261 | .WillOnce(Return(true)); |
| 262 | |
| 263 | profile_->set_storage(storage.release()); |
| 264 | EXPECT_FALSE(profile_->ConfigureService(unknown_service)); |
| 265 | EXPECT_TRUE(profile_->ConfigureService(ethernet_service)); |
| 266 | } |
| 267 | |
Chris Masone | 88cbd5f | 2011-07-03 14:30:04 -0700 | [diff] [blame] | 268 | } // namespace shill |