blob: 6fb322554d4828f191924a536da18de3a7c5aa28 [file] [log] [blame]
Lorenzo Colitti7421a012013-08-20 22:51:24 +09001/*
2 * Copyright (C) 2012 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package com.android.server;
18
Lorenzo Colitti7421a012013-08-20 22:51:24 +090019import static org.mockito.Mockito.doReturn;
20import static org.mockito.Mockito.mock;
21import static org.mockito.Mockito.reset;
22import static org.mockito.Mockito.timeout;
23import static org.mockito.Mockito.verify;
24import static org.mockito.Mockito.verifyNoMoreInteractions;
25
Lorenzo Colittia0868002017-07-11 02:29:28 +090026import android.content.Context;
27import android.net.INetd;
28import android.net.LinkAddress;
Lorenzo Colittia0868002017-07-11 02:29:28 +090029import android.net.LocalServerSocket;
Brett Chabot1ae2aa62019-03-04 14:14:56 -080030import android.net.LocalSocket;
Lorenzo Colittia0868002017-07-11 02:29:28 +090031import android.os.BatteryStats;
32import android.os.Binder;
33import android.os.IBinder;
Lorenzo Colittia0868002017-07-11 02:29:28 +090034import android.test.suitebuilder.annotation.SmallTest;
35
Brett Chabot1ae2aa62019-03-04 14:14:56 -080036import androidx.test.runner.AndroidJUnit4;
37
Lorenzo Colittia0868002017-07-11 02:29:28 +090038import com.android.internal.app.IBatteryStats;
39import com.android.server.NetworkManagementService.SystemServices;
40import com.android.server.net.BaseNetworkObserver;
41
Lorenzo Colittia0868002017-07-11 02:29:28 +090042import org.junit.After;
43import org.junit.Before;
44import org.junit.Test;
45import org.junit.runner.RunWith;
46import org.mockito.Mock;
47import org.mockito.MockitoAnnotations;
48
Brett Chabot1ae2aa62019-03-04 14:14:56 -080049import java.io.IOException;
50import java.io.OutputStream;
51
Lorenzo Colitti7421a012013-08-20 22:51:24 +090052/**
53 * Tests for {@link NetworkManagementService}.
54 */
Lorenzo Colittia0868002017-07-11 02:29:28 +090055@RunWith(AndroidJUnit4.class)
56@SmallTest
57public class NetworkManagementServiceTest {
Lorenzo Colitti7421a012013-08-20 22:51:24 +090058
59 private static final String SOCKET_NAME = "__test__NetworkManagementServiceTest";
60 private NetworkManagementService mNMService;
61 private LocalServerSocket mServerSocket;
62 private LocalSocket mSocket;
63 private OutputStream mOutputStream;
64
Lorenzo Colittia0868002017-07-11 02:29:28 +090065 @Mock private Context mContext;
66 @Mock private IBatteryStats.Stub mBatteryStatsService;
67 @Mock private INetd.Stub mNetdService;
68
69 private final SystemServices mServices = new SystemServices() {
70 @Override
71 public IBinder getService(String name) {
72 switch (name) {
73 case BatteryStats.SERVICE_NAME:
74 return mBatteryStatsService;
75 default:
76 throw new UnsupportedOperationException("Unknown service " + name);
77 }
78 }
79 @Override
80 public void registerLocalService(NetworkManagementInternal nmi) {
81 }
82 @Override
83 public INetd getNetd() {
84 return mNetdService;
85 }
86 };
87
88 @Before
Lorenzo Colitti7421a012013-08-20 22:51:24 +090089 public void setUp() throws Exception {
Lorenzo Colittia0868002017-07-11 02:29:28 +090090 MockitoAnnotations.initMocks(this);
Lorenzo Colitti7421a012013-08-20 22:51:24 +090091
92 // Set up a sheltered test environment.
Lorenzo Colitti7421a012013-08-20 22:51:24 +090093 mServerSocket = new LocalServerSocket(SOCKET_NAME);
94
95 // Start the service and wait until it connects to our socket.
Lorenzo Colittia0868002017-07-11 02:29:28 +090096 mNMService = NetworkManagementService.create(mContext, SOCKET_NAME, mServices);
Lorenzo Colitti7421a012013-08-20 22:51:24 +090097 mSocket = mServerSocket.accept();
98 mOutputStream = mSocket.getOutputStream();
99 }
100
Lorenzo Colittia0868002017-07-11 02:29:28 +0900101 @After
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900102 public void tearDown() throws Exception {
Hugo Benichie93c5692018-01-29 14:00:44 +0900103 mNMService.shutdown();
104 // Once NetworkManagementService#shutdown() actually does something and shutdowns
105 // the underlying NativeDaemonConnector, the block below should be uncommented.
106 // if (mOutputStream != null) mOutputStream.close();
107 // if (mSocket != null) mSocket.close();
108 // if (mServerSocket != null) mServerSocket.close();
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900109 }
110
111 /**
112 * Sends a message on the netd socket and gives the events some time to make it back.
113 */
114 private void sendMessage(String message) throws IOException {
115 // Strings are null-terminated, so add "\0" at the end.
116 mOutputStream.write((message + "\0").getBytes());
117 }
118
119 private static <T> T expectSoon(T mock) {
Lorenzo Colittia0868002017-07-11 02:29:28 +0900120 return verify(mock, timeout(200));
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900121 }
122
123 /**
124 * Tests that network observers work properly.
125 */
Lorenzo Colittia0868002017-07-11 02:29:28 +0900126 @Test
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900127 public void testNetworkObservers() throws Exception {
128 BaseNetworkObserver observer = mock(BaseNetworkObserver.class);
129 doReturn(new Binder()).when(observer).asBinder(); // Used by registerObserver.
130 mNMService.registerObserver(observer);
131
132 // Forget everything that happened to the mock so far, so we can explicitly verify
133 // everything that happens and does not happen to it from now on.
134 reset(observer);
135
136 // Now send NetworkManagementService messages and ensure that the observer methods are
137 // called. After every valid message we expect a callback soon after; to ensure that
138 // invalid messages don't cause any callbacks, we call verifyNoMoreInteractions at the end.
139
140 /**
141 * Interface changes.
142 */
143 sendMessage("600 Iface added rmnet12");
144 expectSoon(observer).interfaceAdded("rmnet12");
145
146 sendMessage("600 Iface removed eth1");
147 expectSoon(observer).interfaceRemoved("eth1");
148
149 sendMessage("607 Iface removed eth1");
150 // Invalid code.
151
152 sendMessage("600 Iface borked lo down");
153 // Invalid event.
154
155 sendMessage("600 Iface changed clat4 up again");
156 // Extra tokens.
157
158 sendMessage("600 Iface changed clat4 up");
159 expectSoon(observer).interfaceStatusChanged("clat4", true);
160
161 sendMessage("600 Iface linkstate rmnet0 down");
162 expectSoon(observer).interfaceLinkStateChanged("rmnet0", false);
163
164 sendMessage("600 IFACE linkstate clat4 up");
165 // Invalid group.
166
167 /**
168 * Bandwidth control events.
169 */
170 sendMessage("601 limit alert data rmnet_usb0");
171 expectSoon(observer).limitReached("data", "rmnet_usb0");
172
173 sendMessage("601 invalid alert data rmnet0");
174 // Invalid group.
175
176 sendMessage("601 limit increased data rmnet0");
177 // Invalid event.
178
179
180 /**
181 * Interface class activity.
182 */
Ashish Sharmaa3f828b2014-03-18 16:38:58 -0700183
Lorenzo Colittia0868002017-07-11 02:29:28 +0900184 sendMessage("613 IfaceClass active 1 1234 10012");
185 expectSoon(observer).interfaceClassDataActivityChanged("1", true, 1234);
Ashish Sharmaa3f828b2014-03-18 16:38:58 -0700186
Lorenzo Colittia0868002017-07-11 02:29:28 +0900187 sendMessage("613 IfaceClass idle 9 5678");
188 expectSoon(observer).interfaceClassDataActivityChanged("9", false, 5678);
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900189
Lorenzo Colittia0868002017-07-11 02:29:28 +0900190 sendMessage("613 IfaceClass reallyactive 9 4321");
191 expectSoon(observer).interfaceClassDataActivityChanged("9", false, 4321);
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900192
Lorenzo Colittia0868002017-07-11 02:29:28 +0900193 sendMessage("613 InterfaceClass reallyactive 1");
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900194 // Invalid group.
195
196
197 /**
198 * IP address changes.
199 */
200 sendMessage("614 Address updated fe80::1/64 wlan0 128 253");
Lorenzo Colitti64483942013-11-15 18:43:52 +0900201 expectSoon(observer).addressUpdated("wlan0", new LinkAddress("fe80::1/64", 128, 253));
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900202
Lorenzo Colitti5ad421a2013-11-17 15:05:02 +0900203 // There is no "added", so we take this as "removed".
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900204 sendMessage("614 Address added fe80::1/64 wlan0 128 253");
Lorenzo Colitti64483942013-11-15 18:43:52 +0900205 expectSoon(observer).addressRemoved("wlan0", new LinkAddress("fe80::1/64", 128, 253));
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900206
207 sendMessage("614 Address removed 2001:db8::1/64 wlan0 1 0");
Lorenzo Colitti64483942013-11-15 18:43:52 +0900208 expectSoon(observer).addressRemoved("wlan0", new LinkAddress("2001:db8::1/64", 1, 0));
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900209
Lorenzo Colittia9626c12013-11-04 17:44:09 +0900210 sendMessage("614 Address removed 2001:db8::1/64 wlan0 1");
211 // Not enough arguments.
212
Lorenzo Colitti5ad421a2013-11-17 15:05:02 +0900213 sendMessage("666 Address removed 2001:db8::1/64 wlan0 1 0");
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900214 // Invalid code.
215
Lorenzo Colitti5ae4a532013-10-31 11:59:46 +0900216
217 /**
218 * DNS information broadcasts.
219 */
220 sendMessage("615 DnsInfo servers rmnet_usb0 3600 2001:db8::1");
221 expectSoon(observer).interfaceDnsServerInfo("rmnet_usb0", 3600,
222 new String[]{"2001:db8::1"});
223
224 sendMessage("615 DnsInfo servers wlan0 14400 2001:db8::1,2001:db8::2");
225 expectSoon(observer).interfaceDnsServerInfo("wlan0", 14400,
226 new String[]{"2001:db8::1", "2001:db8::2"});
227
228 // We don't check for negative lifetimes, only for parse errors.
229 sendMessage("615 DnsInfo servers wlan0 -3600 ::1");
230 expectSoon(observer).interfaceDnsServerInfo("wlan0", -3600,
231 new String[]{"::1"});
232
233 sendMessage("615 DnsInfo servers wlan0 SIXHUNDRED ::1");
234 // Non-numeric lifetime.
235
236 sendMessage("615 DnsInfo servers wlan0 2001:db8::1");
237 // Missing lifetime.
238
239 sendMessage("615 DnsInfo servers wlan0 3600");
240 // No servers.
241
242 sendMessage("615 DnsInfo servers 3600 wlan0 2001:db8::1,2001:db8::2");
243 // Non-numeric lifetime.
244
245 sendMessage("615 DnsInfo wlan0 7200 2001:db8::1,2001:db8::2");
246 // Invalid tokens.
247
248 sendMessage("666 DnsInfo servers wlan0 5400 2001:db8::1");
249 // Invalid code.
250
251 // No syntax checking on the addresses.
252 sendMessage("615 DnsInfo servers wlan0 600 ,::,,foo,::1,");
253 expectSoon(observer).interfaceDnsServerInfo("wlan0", 600,
254 new String[]{"", "::", "", "foo", "::1"});
255
Lorenzo Colitti7421a012013-08-20 22:51:24 +0900256 // Make sure nothing else was called.
257 verifyNoMoreInteractions(observer);
258 }
259}