Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 1 | // Copyright (c) 2013 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/ethernet.h" |
| 6 | |
| 7 | #include <netinet/ether.h> |
| 8 | #include <linux/if.h> // Needs definitions from netinet/ether.h |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 9 | #include <linux/sockios.h> |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 10 | |
| 11 | #include <base/memory/ref_counted.h> |
| 12 | #include <base/memory/scoped_ptr.h> |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 13 | |
| 14 | #include "shill/mock_device_info.h" |
| 15 | #include "shill/mock_dhcp_config.h" |
| 16 | #include "shill/mock_dhcp_provider.h" |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 17 | #include "shill/mock_eap_credentials.h" |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 18 | #include "shill/mock_eap_listener.h" |
| 19 | #include "shill/mock_event_dispatcher.h" |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 20 | #include "shill/mock_ethernet_eap_provider.h" |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 21 | #include "shill/mock_ethernet_service.h" |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 22 | #include "shill/mock_glib.h" |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 23 | #include "shill/mock_log.h" |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 24 | #include "shill/mock_manager.h" |
| 25 | #include "shill/mock_metrics.h" |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 26 | #include "shill/mock_proxy_factory.h" |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 27 | #include "shill/mock_rtnl_handler.h" |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 28 | #include "shill/mock_service.h" |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 29 | #include "shill/mock_sockets.h" |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 30 | #include "shill/mock_supplicant_interface_proxy.h" |
| 31 | #include "shill/mock_supplicant_process_proxy.h" |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 32 | #include "shill/nice_mock_control.h" |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 33 | #include "shill/testing.h" |
| 34 | #include "shill/wpa_supplicant.h" |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 35 | |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 36 | using std::string; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 37 | using testing::_; |
| 38 | using testing::AnyNumber; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 39 | using testing::EndsWith; |
Gaurav Shah | 25ee250 | 2013-04-08 17:55:01 -0700 | [diff] [blame] | 40 | using testing::Eq; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 41 | using testing::Mock; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 42 | using testing::NiceMock; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 43 | using testing::Return; |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 44 | using testing::ReturnRef; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 45 | using testing::StrEq; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 46 | using testing::StrictMock; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 47 | using testing::Throw; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 48 | |
| 49 | namespace shill { |
| 50 | |
| 51 | class EthernetTest : public testing::Test { |
| 52 | public: |
| 53 | EthernetTest() |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 54 | : metrics_(nullptr), |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 55 | manager_(&control_interface_, NULL, &metrics_, &glib_), |
| 56 | device_info_(&control_interface_, &dispatcher_, &metrics_, &manager_), |
| 57 | ethernet_(new Ethernet(&control_interface_, |
| 58 | &dispatcher_, |
| 59 | &metrics_, |
| 60 | &manager_, |
| 61 | kDeviceName, |
| 62 | kDeviceAddress, |
| 63 | kInterfaceIndex)), |
| 64 | dhcp_config_(new MockDHCPConfig(&control_interface_, |
| 65 | kDeviceName)), |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 66 | eap_listener_(new MockEapListener()), |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 67 | mock_sockets_(new StrictMock<MockSockets>()), |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 68 | mock_service_(new MockEthernetService(&control_interface_, &metrics_)), |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 69 | mock_eap_service_(new MockService(&control_interface_, |
| 70 | &dispatcher_, |
| 71 | &metrics_, |
| 72 | &manager_)), |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 73 | supplicant_interface_proxy_( |
| 74 | new NiceMock<MockSupplicantInterfaceProxy>()), |
| 75 | supplicant_process_proxy_(new NiceMock<MockSupplicantProcessProxy>()) {} |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 76 | |
| 77 | virtual void SetUp() { |
| 78 | ethernet_->rtnl_handler_ = &rtnl_handler_; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 79 | ethernet_->proxy_factory_ = &proxy_factory_; |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 80 | ethernet_->eap_listener_.reset(eap_listener_); // Transfers ownership. |
| 81 | ethernet_->sockets_.reset(mock_sockets_); // Transfers ownership. |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 82 | |
| 83 | ethernet_->set_dhcp_provider(&dhcp_provider_); |
| 84 | ON_CALL(manager_, device_info()).WillByDefault(Return(&device_info_)); |
| 85 | EXPECT_CALL(manager_, UpdateEnabledTechnologies()).Times(AnyNumber()); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 86 | EXPECT_CALL(manager_, ethernet_eap_provider()) |
| 87 | .WillRepeatedly(Return(ðernet_eap_provider_)); |
| 88 | ethernet_eap_provider_.set_service(mock_eap_service_); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 89 | } |
| 90 | |
| 91 | virtual void TearDown() { |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 92 | ethernet_eap_provider_.set_service(NULL); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 93 | ethernet_->set_dhcp_provider(NULL); |
| 94 | ethernet_->eap_listener_.reset(); |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 95 | ethernet_->sockets_.reset(); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 96 | } |
| 97 | |
| 98 | protected: |
| 99 | static const char kDeviceName[]; |
| 100 | static const char kDeviceAddress[]; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 101 | static const char kInterfacePath[]; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 102 | static const int kInterfaceIndex; |
| 103 | |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 104 | bool GetIsEapAuthenticated() { return ethernet_->is_eap_authenticated_; } |
| 105 | void SetIsEapAuthenticated(bool is_eap_authenticated) { |
| 106 | ethernet_->is_eap_authenticated_ = is_eap_authenticated; |
| 107 | } |
| 108 | bool GetIsEapDetected() { return ethernet_->is_eap_detected_; } |
| 109 | void SetIsEapDetected(bool is_eap_detected) { |
| 110 | ethernet_->is_eap_detected_ = is_eap_detected; |
| 111 | } |
| 112 | bool GetLinkUp() { return ethernet_->link_up_; } |
| 113 | const ServiceRefPtr &GetSelectedService() { |
| 114 | return ethernet_->selected_service(); |
| 115 | } |
| 116 | ServiceRefPtr GetService() { return ethernet_->service_; } |
| 117 | void SetService(const EthernetServiceRefPtr &service) { |
| 118 | ethernet_->service_ = service; |
| 119 | } |
| 120 | const PropertyStore &GetStore() { return ethernet_->store(); } |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 121 | void StartEthernet() { |
| 122 | EXPECT_CALL(rtnl_handler_, |
| 123 | SetInterfaceFlags(kInterfaceIndex, IFF_UP, IFF_UP)); |
| 124 | ethernet_->Start(NULL, EnabledStateChangedCallback()); |
| 125 | } |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 126 | const SupplicantInterfaceProxyInterface *GetSupplicantInterfaceProxy() { |
| 127 | return ethernet_->supplicant_interface_proxy_.get(); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 128 | } |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 129 | const SupplicantProcessProxyInterface *GetSupplicantProcessProxy() { |
| 130 | return ethernet_->supplicant_process_proxy_.get(); |
| 131 | } |
| 132 | const string &GetSupplicantInterfacePath() { |
| 133 | return ethernet_->supplicant_interface_path_; |
| 134 | } |
| 135 | const string &GetSupplicantNetworkPath() { |
| 136 | return ethernet_->supplicant_network_path_; |
| 137 | } |
| 138 | void SetSupplicantNetworkPath(const string &network_path) { |
| 139 | ethernet_->supplicant_network_path_ = network_path; |
| 140 | } |
| 141 | bool InvokeStartSupplicant() { |
| 142 | return ethernet_->StartSupplicant(); |
| 143 | } |
| 144 | void InvokeStopSupplicant() { |
| 145 | return ethernet_->StopSupplicant(); |
| 146 | } |
| 147 | bool InvokeStartEapAuthentication() { |
| 148 | return ethernet_->StartEapAuthentication(); |
| 149 | } |
| 150 | void StartSupplicant() { |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 151 | MockSupplicantInterfaceProxy *interface_proxy = |
| 152 | ExpectCreateSupplicantInterfaceProxy(); |
| 153 | MockSupplicantProcessProxy *process_proxy = |
| 154 | ExpectCreateSupplicantProcessProxy(); |
| 155 | EXPECT_CALL(*process_proxy, CreateInterface(_)) |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 156 | .WillOnce(Return(kInterfacePath)); |
| 157 | EXPECT_TRUE(InvokeStartSupplicant()); |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 158 | EXPECT_EQ(interface_proxy, GetSupplicantInterfaceProxy()); |
| 159 | EXPECT_EQ(process_proxy, GetSupplicantProcessProxy()); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 160 | EXPECT_EQ(kInterfacePath, GetSupplicantInterfacePath()); |
| 161 | } |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 162 | void TriggerOnEapDetected() { ethernet_->OnEapDetected(); } |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 163 | void TriggerCertification(const string &subject, uint32 depth) { |
| 164 | ethernet_->CertificationTask(subject, depth); |
| 165 | } |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 166 | void TriggerTryEapAuthentication() { |
| 167 | ethernet_->TryEapAuthenticationTask(); |
| 168 | } |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 169 | |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 170 | MockSupplicantInterfaceProxy *ExpectCreateSupplicantInterfaceProxy() { |
| 171 | EXPECT_CALL(proxy_factory_, |
| 172 | CreateSupplicantInterfaceProxy(_, DBus::Path(kInterfacePath), |
| 173 | StrEq(WPASupplicant::kDBusAddr))) |
| 174 | .WillOnce(ReturnAndReleasePointee(&supplicant_interface_proxy_)); |
| 175 | return supplicant_interface_proxy_.get(); |
| 176 | } |
| 177 | MockSupplicantProcessProxy *ExpectCreateSupplicantProcessProxy() { |
| 178 | EXPECT_CALL(proxy_factory_, |
| 179 | CreateSupplicantProcessProxy(StrEq(WPASupplicant::kDBusPath), |
| 180 | StrEq(WPASupplicant::kDBusAddr))) |
| 181 | .WillOnce(ReturnAndReleasePointee(&supplicant_process_proxy_)); |
| 182 | return supplicant_process_proxy_.get(); |
| 183 | } |
| 184 | |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 185 | StrictMock<MockEventDispatcher> dispatcher_; |
| 186 | MockGLib glib_; |
| 187 | NiceMockControl control_interface_; |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 188 | NiceMock<MockMetrics> metrics_; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 189 | MockManager manager_; |
| 190 | MockDeviceInfo device_info_; |
| 191 | EthernetRefPtr ethernet_; |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 192 | MockEthernetEapProvider ethernet_eap_provider_; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 193 | MockDHCPProvider dhcp_provider_; |
| 194 | scoped_refptr<MockDHCPConfig> dhcp_config_; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 195 | |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 196 | // Owned by Ethernet instance, but tracked here for expectations. |
| 197 | MockEapListener *eap_listener_; |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 198 | MockSockets *mock_sockets_; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 199 | |
| 200 | MockRTNLHandler rtnl_handler_; |
| 201 | scoped_refptr<MockEthernetService> mock_service_; |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 202 | scoped_refptr<MockService> mock_eap_service_; |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 203 | NiceMock<MockProxyFactory> proxy_factory_; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 204 | scoped_ptr<MockSupplicantInterfaceProxy> supplicant_interface_proxy_; |
| 205 | scoped_ptr<MockSupplicantProcessProxy> supplicant_process_proxy_; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 206 | }; |
| 207 | |
| 208 | // static |
| 209 | const char EthernetTest::kDeviceName[] = "eth0"; |
| 210 | const char EthernetTest::kDeviceAddress[] = "000102030405"; |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 211 | const char EthernetTest::kInterfacePath[] = "/interface/path"; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 212 | const int EthernetTest::kInterfaceIndex = 123; |
| 213 | |
| 214 | TEST_F(EthernetTest, Construct) { |
| 215 | EXPECT_FALSE(GetLinkUp()); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 216 | EXPECT_FALSE(GetIsEapAuthenticated()); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 217 | EXPECT_FALSE(GetIsEapDetected()); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 218 | EXPECT_TRUE(GetStore().Contains(kEapAuthenticationCompletedProperty)); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 219 | EXPECT_TRUE(GetStore().Contains(kEapAuthenticatorDetectedProperty)); |
| 220 | EXPECT_EQ(NULL, GetService().get()); |
| 221 | } |
| 222 | |
| 223 | TEST_F(EthernetTest, StartStop) { |
Gaurav Shah | 25ee250 | 2013-04-08 17:55:01 -0700 | [diff] [blame] | 224 | StartEthernet(); |
| 225 | |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 226 | EXPECT_FALSE(GetService().get() == NULL); |
| 227 | |
Gaurav Shah | 25ee250 | 2013-04-08 17:55:01 -0700 | [diff] [blame] | 228 | Service* service = GetService().get(); |
| 229 | EXPECT_CALL(manager_, DeregisterService(Eq(service))); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 230 | ethernet_->Stop(NULL, EnabledStateChangedCallback()); |
| 231 | EXPECT_EQ(NULL, GetService().get()); |
| 232 | } |
| 233 | |
| 234 | TEST_F(EthernetTest, LinkEvent) { |
| 235 | StartEthernet(); |
| 236 | |
| 237 | // Link-down event while already down. |
| 238 | EXPECT_CALL(manager_, DeregisterService(_)).Times(0); |
| 239 | EXPECT_CALL(*eap_listener_, Start()).Times(0); |
| 240 | ethernet_->LinkEvent(0, IFF_LOWER_UP); |
| 241 | EXPECT_FALSE(GetLinkUp()); |
| 242 | EXPECT_FALSE(GetIsEapDetected()); |
| 243 | Mock::VerifyAndClearExpectations(&manager_); |
| 244 | |
| 245 | // Link-up event while down. |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 246 | int kFakeFd = 789; |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 247 | EXPECT_CALL(manager_, RegisterService(GetService())); |
| 248 | EXPECT_CALL(*eap_listener_, Start()); |
mukesh agrawal | 8bda796 | 2014-04-01 17:09:35 -0700 | [diff] [blame] | 249 | EXPECT_CALL(*mock_sockets_, Socket(_, _, _)).WillOnce(Return(kFakeFd)); |
| 250 | EXPECT_CALL(*mock_sockets_, Ioctl(kFakeFd, SIOCETHTOOL, _)); |
| 251 | EXPECT_CALL(*mock_sockets_, Close(kFakeFd)); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 252 | ethernet_->LinkEvent(IFF_LOWER_UP, 0); |
| 253 | EXPECT_TRUE(GetLinkUp()); |
| 254 | EXPECT_FALSE(GetIsEapDetected()); |
| 255 | Mock::VerifyAndClearExpectations(&manager_); |
| 256 | |
| 257 | // Link-up event while already up. |
| 258 | EXPECT_CALL(manager_, RegisterService(GetService())).Times(0); |
| 259 | EXPECT_CALL(*eap_listener_, Start()).Times(0); |
| 260 | ethernet_->LinkEvent(IFF_LOWER_UP, 0); |
| 261 | EXPECT_TRUE(GetLinkUp()); |
| 262 | EXPECT_FALSE(GetIsEapDetected()); |
| 263 | Mock::VerifyAndClearExpectations(&manager_); |
| 264 | |
| 265 | // Link-down event while up. |
| 266 | SetIsEapDetected(true); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 267 | // This is done in SetUp, but we have to reestablish this after calling |
| 268 | // VerifyAndClearExpectations() above. |
| 269 | EXPECT_CALL(manager_, ethernet_eap_provider()) |
| 270 | .WillRepeatedly(Return(ðernet_eap_provider_)); |
| 271 | EXPECT_CALL(ethernet_eap_provider_, |
| 272 | ClearCredentialChangeCallback(ethernet_.get())); |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 273 | EXPECT_CALL(manager_, DeregisterService(GetService())); |
| 274 | EXPECT_CALL(*eap_listener_, Stop()); |
| 275 | ethernet_->LinkEvent(0, IFF_LOWER_UP); |
| 276 | EXPECT_FALSE(GetLinkUp()); |
| 277 | EXPECT_FALSE(GetIsEapDetected()); |
| 278 | |
| 279 | // Restore this expectation during shutdown. |
| 280 | EXPECT_CALL(manager_, UpdateEnabledTechnologies()).Times(AnyNumber()); |
| 281 | } |
| 282 | |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 283 | TEST_F(EthernetTest, ConnectToFailure) { |
| 284 | StartEthernet(); |
| 285 | SetService(mock_service_); |
| 286 | EXPECT_EQ(NULL, GetSelectedService().get()); |
Paul Stewart | 75a68b9 | 2013-10-24 10:50:27 -0700 | [diff] [blame] | 287 | EXPECT_CALL(dhcp_provider_, CreateConfig(_, _, _, _, _)). |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 288 | WillOnce(Return(dhcp_config_)); |
| 289 | EXPECT_CALL(*dhcp_config_.get(), RequestIP()).WillOnce(Return(false)); |
| 290 | EXPECT_CALL(dispatcher_, PostTask(_)); // Posts ConfigureStaticIPTask. |
Paul Stewart | dded007 | 2013-10-24 12:38:54 -0700 | [diff] [blame] | 291 | EXPECT_CALL(*mock_service_, SetState(Service::kStateFailure)); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 292 | ethernet_->ConnectTo(mock_service_); |
Paul Stewart | dded007 | 2013-10-24 12:38:54 -0700 | [diff] [blame] | 293 | EXPECT_EQ(mock_service_, GetSelectedService().get()); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 294 | } |
| 295 | |
| 296 | TEST_F(EthernetTest, ConnectToSuccess) { |
| 297 | StartEthernet(); |
| 298 | SetService(mock_service_); |
| 299 | EXPECT_EQ(NULL, GetSelectedService().get()); |
Paul Stewart | 75a68b9 | 2013-10-24 10:50:27 -0700 | [diff] [blame] | 300 | EXPECT_CALL(dhcp_provider_, CreateConfig(_, _, _, _, _)). |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 301 | WillOnce(Return(dhcp_config_)); |
| 302 | EXPECT_CALL(*dhcp_config_.get(), RequestIP()).WillOnce(Return(true)); |
| 303 | EXPECT_CALL(dispatcher_, PostTask(_)); // Posts ConfigureStaticIPTask. |
| 304 | EXPECT_CALL(*mock_service_, SetState(Service::kStateConfiguring)); |
| 305 | ethernet_->ConnectTo(mock_service_.get()); |
| 306 | EXPECT_EQ(GetService().get(), GetSelectedService().get()); |
| 307 | Mock::VerifyAndClearExpectations(mock_service_); |
| 308 | |
| 309 | EXPECT_CALL(*mock_service_, SetState(Service::kStateIdle)); |
| 310 | ethernet_->DisconnectFrom(mock_service_); |
| 311 | EXPECT_EQ(NULL, GetSelectedService().get()); |
| 312 | } |
| 313 | |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 314 | TEST_F(EthernetTest, OnEapDetected) { |
| 315 | EXPECT_FALSE(GetIsEapDetected()); |
| 316 | EXPECT_CALL(*eap_listener_, Stop()); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 317 | EXPECT_CALL(ethernet_eap_provider_, |
| 318 | SetCredentialChangeCallback(ethernet_.get(), _)); |
| 319 | EXPECT_CALL(dispatcher_, PostTask(_)); // Posts TryEapAuthenticationTask. |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 320 | TriggerOnEapDetected(); |
| 321 | EXPECT_TRUE(GetIsEapDetected()); |
| 322 | } |
| 323 | |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 324 | TEST_F(EthernetTest, TryEapAuthenticationNoService) { |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 325 | EXPECT_CALL(*mock_eap_service_, Is8021xConnectable()).Times(0); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 326 | NiceScopedMockLog log; |
| 327 | EXPECT_CALL(log, Log(logging::LOG_INFO, _, |
| 328 | EndsWith("Service is missing; " |
| 329 | "not doing EAP authentication."))); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 330 | TriggerTryEapAuthentication(); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 331 | } |
| 332 | |
| 333 | TEST_F(EthernetTest, TryEapAuthenticationNotConnectableNotAuthenticated) { |
| 334 | SetService(mock_service_); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 335 | EXPECT_CALL(*mock_eap_service_, Is8021xConnectable()).WillOnce(Return(false)); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 336 | NiceScopedMockLog log; |
| 337 | EXPECT_CALL(log, Log(logging::LOG_INFO, _, |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 338 | EndsWith("EAP Service lacks 802.1X credentials; " |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 339 | "not doing EAP authentication."))); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 340 | TriggerTryEapAuthentication(); |
| 341 | SetService(NULL); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 342 | } |
| 343 | |
| 344 | TEST_F(EthernetTest, TryEapAuthenticationNotConnectableAuthenticated) { |
| 345 | SetService(mock_service_); |
| 346 | SetIsEapAuthenticated(true); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 347 | EXPECT_CALL(*mock_eap_service_, Is8021xConnectable()).WillOnce(Return(false)); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 348 | NiceScopedMockLog log; |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 349 | EXPECT_CALL(log, Log(_, _, _)).Times(AnyNumber()); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 350 | EXPECT_CALL(log, Log(logging::LOG_INFO, _, |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 351 | EndsWith("EAP Service lost 802.1X credentials; " |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 352 | "terminating EAP authentication."))); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 353 | TriggerTryEapAuthentication(); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 354 | EXPECT_FALSE(GetIsEapAuthenticated()); |
| 355 | } |
| 356 | |
| 357 | TEST_F(EthernetTest, TryEapAuthenticationEapNotDetected) { |
| 358 | SetService(mock_service_); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 359 | EXPECT_CALL(*mock_eap_service_, Is8021xConnectable()).WillOnce(Return(true)); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 360 | NiceScopedMockLog log; |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 361 | EXPECT_CALL(log, Log(logging::LOG_WARNING, _, |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 362 | EndsWith("EAP authenticator not detected; " |
| 363 | "not doing EAP authentication."))); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 364 | TriggerTryEapAuthentication(); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 365 | } |
| 366 | |
| 367 | TEST_F(EthernetTest, StartSupplicant) { |
| 368 | // Save the mock proxy pointers before the Ethernet instance accepts it. |
| 369 | MockSupplicantInterfaceProxy *interface_proxy = |
| 370 | supplicant_interface_proxy_.get(); |
| 371 | MockSupplicantProcessProxy *process_proxy = supplicant_process_proxy_.get(); |
| 372 | |
| 373 | StartSupplicant(); |
| 374 | |
| 375 | // Starting it again should not invoke another call to create an interface. |
| 376 | Mock::VerifyAndClearExpectations(process_proxy); |
| 377 | EXPECT_CALL(*process_proxy, CreateInterface(_)).Times(0); |
| 378 | EXPECT_TRUE(InvokeStartSupplicant()); |
| 379 | |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 380 | // Also, the mock pointers should remain; if the MockProxyFactory was |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 381 | // invoked again, they would be NULL. |
| 382 | EXPECT_EQ(interface_proxy, GetSupplicantInterfaceProxy()); |
| 383 | EXPECT_EQ(process_proxy, GetSupplicantProcessProxy()); |
| 384 | EXPECT_EQ(kInterfacePath, GetSupplicantInterfacePath()); |
| 385 | } |
| 386 | |
| 387 | TEST_F(EthernetTest, StartSupplicantWithInterfaceExistsException) { |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 388 | MockSupplicantProcessProxy *process_proxy = |
| 389 | ExpectCreateSupplicantProcessProxy(); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 390 | MockSupplicantInterfaceProxy *interface_proxy = |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 391 | ExpectCreateSupplicantInterfaceProxy(); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 392 | EXPECT_CALL(*process_proxy, CreateInterface(_)) |
| 393 | .WillOnce(Throw(DBus::Error( |
| 394 | "fi.w1.wpa_supplicant1.InterfaceExists", |
| 395 | "test threw fi.w1.wpa_supplicant1.InterfaceExists"))); |
| 396 | EXPECT_CALL(*process_proxy, GetInterface(kDeviceName)) |
| 397 | .WillOnce(Return(kInterfacePath)); |
| 398 | EXPECT_TRUE(InvokeStartSupplicant()); |
| 399 | EXPECT_EQ(interface_proxy, GetSupplicantInterfaceProxy()); |
| 400 | EXPECT_EQ(process_proxy, GetSupplicantProcessProxy()); |
| 401 | EXPECT_EQ(kInterfacePath, GetSupplicantInterfacePath()); |
| 402 | } |
| 403 | |
| 404 | TEST_F(EthernetTest, StartSupplicantWithUnknownException) { |
Ben Chan | a55469d | 2014-01-27 16:35:29 -0800 | [diff] [blame] | 405 | MockSupplicantProcessProxy *process_proxy = |
| 406 | ExpectCreateSupplicantProcessProxy(); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 407 | EXPECT_CALL(*process_proxy, CreateInterface(_)) |
| 408 | .WillOnce(Throw(DBus::Error( |
| 409 | "fi.w1.wpa_supplicant1.UnknownError", |
| 410 | "test threw fi.w1.wpa_supplicant1.UnknownError"))); |
| 411 | EXPECT_CALL(*process_proxy, GetInterface(kDeviceName)).Times(0); |
| 412 | EXPECT_FALSE(InvokeStartSupplicant()); |
| 413 | EXPECT_EQ(NULL, GetSupplicantInterfaceProxy()); |
| 414 | EXPECT_EQ(NULL, GetSupplicantProcessProxy()); |
| 415 | EXPECT_EQ("", GetSupplicantInterfacePath()); |
| 416 | } |
| 417 | |
| 418 | TEST_F(EthernetTest, StartEapAuthentication) { |
| 419 | MockSupplicantInterfaceProxy *interface_proxy = |
| 420 | supplicant_interface_proxy_.get(); |
| 421 | |
| 422 | StartSupplicant(); |
| 423 | SetService(mock_service_); |
| 424 | |
| 425 | EXPECT_CALL(*mock_service_, ClearEAPCertification()); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 426 | MockEapCredentials mock_eap_credentials; |
| 427 | EXPECT_CALL(*mock_eap_service_, eap()) |
| 428 | .WillOnce(Return(&mock_eap_credentials)); |
| 429 | EXPECT_CALL(mock_eap_credentials, PopulateSupplicantProperties(_, _, _, _)); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 430 | EXPECT_CALL(*interface_proxy, RemoveNetwork(_)).Times(0); |
| 431 | EXPECT_CALL(*interface_proxy, AddNetwork(_)) |
| 432 | .WillOnce(Throw(DBus::Error( |
| 433 | "fi.w1.wpa_supplicant1.UnknownError", |
| 434 | "test threw fi.w1.wpa_supplicant1.UnknownError"))); |
| 435 | EXPECT_CALL(*interface_proxy, SelectNetwork(_)).Times(0); |
Paul Stewart | be9abfd | 2013-04-22 12:18:48 -0700 | [diff] [blame] | 436 | EXPECT_CALL(*interface_proxy, EAPLogon()).Times(0); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 437 | EXPECT_FALSE(InvokeStartEapAuthentication()); |
| 438 | Mock::VerifyAndClearExpectations(mock_service_); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 439 | Mock::VerifyAndClearExpectations(mock_eap_service_); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 440 | Mock::VerifyAndClearExpectations(interface_proxy); |
| 441 | EXPECT_EQ("", GetSupplicantNetworkPath()); |
| 442 | |
| 443 | EXPECT_CALL(*mock_service_, ClearEAPCertification()); |
| 444 | EXPECT_CALL(*interface_proxy, RemoveNetwork(_)).Times(0); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 445 | EXPECT_CALL(*mock_eap_service_, eap()) |
| 446 | .WillOnce(Return(&mock_eap_credentials)); |
| 447 | EXPECT_CALL(mock_eap_credentials, PopulateSupplicantProperties(_, _, _, _)); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 448 | const char kFirstNetworkPath[] = "/network/first-path"; |
| 449 | EXPECT_CALL(*interface_proxy, AddNetwork(_)) |
| 450 | .WillOnce(Return(kFirstNetworkPath)); |
| 451 | EXPECT_CALL(*interface_proxy, SelectNetwork(StrEq(kFirstNetworkPath))); |
Paul Stewart | be9abfd | 2013-04-22 12:18:48 -0700 | [diff] [blame] | 452 | EXPECT_CALL(*interface_proxy, EAPLogon()); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 453 | EXPECT_TRUE(InvokeStartEapAuthentication()); |
| 454 | Mock::VerifyAndClearExpectations(mock_service_); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 455 | Mock::VerifyAndClearExpectations(mock_eap_service_); |
| 456 | Mock::VerifyAndClearExpectations(&mock_eap_credentials); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 457 | Mock::VerifyAndClearExpectations(interface_proxy); |
| 458 | EXPECT_EQ(kFirstNetworkPath, GetSupplicantNetworkPath()); |
| 459 | |
| 460 | EXPECT_CALL(*mock_service_, ClearEAPCertification()); |
| 461 | EXPECT_CALL(*interface_proxy, RemoveNetwork(StrEq(kFirstNetworkPath))); |
Paul Stewart | 35eff13 | 2013-04-12 12:08:40 -0700 | [diff] [blame] | 462 | EXPECT_CALL(*mock_eap_service_, eap()) |
| 463 | .WillOnce(Return(&mock_eap_credentials)); |
| 464 | EXPECT_CALL(mock_eap_credentials, PopulateSupplicantProperties(_, _, _, _)); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 465 | const char kSecondNetworkPath[] = "/network/second-path"; |
| 466 | EXPECT_CALL(*interface_proxy, AddNetwork(_)) |
| 467 | .WillOnce(Return(kSecondNetworkPath)); |
| 468 | EXPECT_CALL(*interface_proxy, SelectNetwork(StrEq(kSecondNetworkPath))); |
Paul Stewart | be9abfd | 2013-04-22 12:18:48 -0700 | [diff] [blame] | 469 | EXPECT_CALL(*interface_proxy, EAPLogon()); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 470 | EXPECT_TRUE(InvokeStartEapAuthentication()); |
| 471 | EXPECT_EQ(kSecondNetworkPath, GetSupplicantNetworkPath()); |
| 472 | } |
| 473 | |
| 474 | TEST_F(EthernetTest, StopSupplicant) { |
| 475 | MockSupplicantProcessProxy *process_proxy = supplicant_process_proxy_.get(); |
Paul Stewart | be9abfd | 2013-04-22 12:18:48 -0700 | [diff] [blame] | 476 | MockSupplicantInterfaceProxy *interface_proxy = |
| 477 | supplicant_interface_proxy_.get(); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 478 | StartSupplicant(); |
| 479 | SetIsEapAuthenticated(true); |
| 480 | SetSupplicantNetworkPath("/network/1"); |
Paul Stewart | be9abfd | 2013-04-22 12:18:48 -0700 | [diff] [blame] | 481 | EXPECT_CALL(*interface_proxy, EAPLogoff()); |
Paul Stewart | 9413bcc | 2013-04-04 16:12:43 -0700 | [diff] [blame] | 482 | EXPECT_CALL(*process_proxy, RemoveInterface(StrEq(kInterfacePath))); |
| 483 | InvokeStopSupplicant(); |
| 484 | EXPECT_EQ(NULL, GetSupplicantInterfaceProxy()); |
| 485 | EXPECT_EQ(NULL, GetSupplicantProcessProxy()); |
| 486 | EXPECT_EQ("", GetSupplicantInterfacePath()); |
| 487 | EXPECT_EQ("", GetSupplicantNetworkPath()); |
| 488 | EXPECT_FALSE(GetIsEapAuthenticated()); |
| 489 | } |
| 490 | |
| 491 | TEST_F(EthernetTest, Certification) { |
| 492 | const string kSubjectName("subject-name"); |
| 493 | const uint32 kDepth = 123; |
| 494 | // Should not crash due to no service_. |
| 495 | TriggerCertification(kSubjectName, kDepth); |
| 496 | EXPECT_CALL(*mock_service_, AddEAPCertification(kSubjectName, kDepth)); |
| 497 | SetService(mock_service_); |
| 498 | TriggerCertification(kSubjectName, kDepth); |
| 499 | } |
| 500 | |
Paul Stewart | ced3ad7 | 2013-04-03 13:39:25 -0700 | [diff] [blame] | 501 | } // namespace shill |