blob: 1ddaf66d2274bb5886b2d23f6e4e9d0c88cdb58f [file] [log] [blame]
Erik Kline92c4db02017-05-31 10:21:32 +09001/*
2 * Copyright (C) 2017 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.connectivity.tethering;
18
19import static android.provider.Settings.Global.TETHER_OFFLOAD_DISABLED;
Erik Kline7990aef2017-06-01 20:11:25 +090020import static org.junit.Assert.assertEquals;
21import static org.junit.Assert.assertTrue;
Erik Kline92c4db02017-05-31 10:21:32 +090022import static org.junit.Assert.fail;
23import static org.mockito.Matchers.any;
24import static org.mockito.Matchers.anyObject;
Erik Kline7990aef2017-06-01 20:11:25 +090025import static org.mockito.Matchers.eq;
Erik Kline92c4db02017-05-31 10:21:32 +090026import static org.mockito.Mockito.inOrder;
27import static org.mockito.Mockito.never;
Erik Kline7990aef2017-06-01 20:11:25 +090028import static org.mockito.Mockito.reset;
Erik Kline92c4db02017-05-31 10:21:32 +090029import static org.mockito.Mockito.times;
30import static org.mockito.Mockito.when;
31
32import android.content.Context;
Erik Klinef3a08b42017-06-07 16:33:19 +090033import android.content.pm.ApplicationInfo;
Erik Kline7990aef2017-06-01 20:11:25 +090034import android.net.LinkAddress;
35import android.net.LinkProperties;
36import android.net.RouteInfo;
Erik Kline92c4db02017-05-31 10:21:32 +090037import android.net.util.SharedLog;
38import android.provider.Settings;
39import android.provider.Settings.SettingNotFoundException;
40
41import android.support.test.filters.SmallTest;
42import android.support.test.runner.AndroidJUnit4;
43import android.test.mock.MockContentResolver;
44import com.android.internal.util.test.FakeSettingsProvider;
45
Erik Kline7990aef2017-06-01 20:11:25 +090046import java.net.InetAddress;
47import java.util.ArrayList;
48
Erik Kline92c4db02017-05-31 10:21:32 +090049import org.junit.Before;
50import org.junit.runner.RunWith;
51import org.junit.Test;
Erik Kline7990aef2017-06-01 20:11:25 +090052import org.mockito.ArgumentCaptor;
Erik Kline92c4db02017-05-31 10:21:32 +090053import org.mockito.InOrder;
54import org.mockito.Mock;
55import org.mockito.MockitoAnnotations;
56
57
58@RunWith(AndroidJUnit4.class)
59@SmallTest
60public class OffloadControllerTest {
61
62 @Mock private OffloadHardwareInterface mHardware;
Erik Klinef3a08b42017-06-07 16:33:19 +090063 @Mock private ApplicationInfo mApplicationInfo;
Erik Kline92c4db02017-05-31 10:21:32 +090064 @Mock private Context mContext;
Erik Kline7fd696c2017-06-12 18:20:08 +090065 private final ArgumentCaptor<ArrayList> mStringArrayCaptor =
66 ArgumentCaptor.forClass(ArrayList.class);
Erik Kline92c4db02017-05-31 10:21:32 +090067 private MockContentResolver mContentResolver;
68
69 @Before public void setUp() throws Exception {
70 MockitoAnnotations.initMocks(this);
Erik Klinef3a08b42017-06-07 16:33:19 +090071 when(mContext.getApplicationInfo()).thenReturn(mApplicationInfo);
72 when(mContext.getPackageName()).thenReturn("OffloadControllerTest");
Erik Kline92c4db02017-05-31 10:21:32 +090073 mContentResolver = new MockContentResolver(mContext);
74 mContentResolver.addProvider(Settings.AUTHORITY, new FakeSettingsProvider());
Erik Kline92c4db02017-05-31 10:21:32 +090075 when(mContext.getContentResolver()).thenReturn(mContentResolver);
76 }
77
78 private void setupFunctioningHardwareInterface() {
79 when(mHardware.initOffloadConfig()).thenReturn(true);
80 when(mHardware.initOffloadControl(any(OffloadHardwareInterface.ControlCallback.class)))
81 .thenReturn(true);
82 }
83
84 @Test
85 public void testNoSettingsValueAllowsStart() {
86 setupFunctioningHardwareInterface();
87 try {
88 Settings.Global.getInt(mContentResolver, TETHER_OFFLOAD_DISABLED);
89 fail();
90 } catch (SettingNotFoundException expected) {}
91
92 final OffloadController offload =
93 new OffloadController(null, mHardware, mContentResolver, new SharedLog("test"));
94 offload.start();
95
96 final InOrder inOrder = inOrder(mHardware);
97 inOrder.verify(mHardware, times(1)).initOffloadConfig();
98 inOrder.verify(mHardware, times(1)).initOffloadControl(
99 any(OffloadHardwareInterface.ControlCallback.class));
100 inOrder.verifyNoMoreInteractions();
101 }
102
103 @Test
104 public void testSettingsAllowsStart() {
105 setupFunctioningHardwareInterface();
106 Settings.Global.putInt(mContentResolver, TETHER_OFFLOAD_DISABLED, 0);
107
108 final OffloadController offload =
109 new OffloadController(null, mHardware, mContentResolver, new SharedLog("test"));
110 offload.start();
111
112 final InOrder inOrder = inOrder(mHardware);
113 inOrder.verify(mHardware, times(1)).initOffloadConfig();
114 inOrder.verify(mHardware, times(1)).initOffloadControl(
115 any(OffloadHardwareInterface.ControlCallback.class));
116 inOrder.verifyNoMoreInteractions();
117 }
118
119 @Test
120 public void testSettingsDisablesStart() {
121 setupFunctioningHardwareInterface();
122 Settings.Global.putInt(mContentResolver, TETHER_OFFLOAD_DISABLED, 1);
123
124 final OffloadController offload =
125 new OffloadController(null, mHardware, mContentResolver, new SharedLog("test"));
126 offload.start();
127
128 final InOrder inOrder = inOrder(mHardware);
129 inOrder.verify(mHardware, never()).initOffloadConfig();
130 inOrder.verify(mHardware, never()).initOffloadControl(anyObject());
131 inOrder.verifyNoMoreInteractions();
132 }
Erik Kline7990aef2017-06-01 20:11:25 +0900133
134 @Test
135 public void testSetUpstreamLinkPropertiesWorking() throws Exception {
136 setupFunctioningHardwareInterface();
137 final OffloadController offload =
138 new OffloadController(null, mHardware, mContentResolver, new SharedLog("test"));
139 offload.start();
140
141 final InOrder inOrder = inOrder(mHardware);
142 inOrder.verify(mHardware, times(1)).initOffloadConfig();
143 inOrder.verify(mHardware, times(1)).initOffloadControl(
144 any(OffloadHardwareInterface.ControlCallback.class));
145 inOrder.verifyNoMoreInteractions();
146
147 offload.setUpstreamLinkProperties(null);
148 inOrder.verify(mHardware, times(1)).setUpstreamParameters(
149 eq(null), eq(null), eq(null), eq(null));
150 inOrder.verifyNoMoreInteractions();
151 reset(mHardware);
152
153 final LinkProperties lp = new LinkProperties();
154
155 final String testIfName = "rmnet_data17";
156 lp.setInterfaceName(testIfName);
157 offload.setUpstreamLinkProperties(lp);
158 inOrder.verify(mHardware, times(1)).setUpstreamParameters(
Erik Kline11854592017-06-15 18:06:34 +0900159 eq(testIfName), eq(null), eq(null), eq(null));
Erik Kline7990aef2017-06-01 20:11:25 +0900160 inOrder.verifyNoMoreInteractions();
161
162 final String ipv4Addr = "192.0.2.5";
163 final String linkAddr = ipv4Addr + "/24";
164 lp.addLinkAddress(new LinkAddress(linkAddr));
165 offload.setUpstreamLinkProperties(lp);
166 inOrder.verify(mHardware, times(1)).setUpstreamParameters(
Erik Kline11854592017-06-15 18:06:34 +0900167 eq(testIfName), eq(ipv4Addr), eq(null), eq(null));
Erik Kline7990aef2017-06-01 20:11:25 +0900168 inOrder.verifyNoMoreInteractions();
169
170 final String ipv4Gateway = "192.0.2.1";
171 lp.addRoute(new RouteInfo(InetAddress.getByName(ipv4Gateway)));
172 offload.setUpstreamLinkProperties(lp);
173 inOrder.verify(mHardware, times(1)).setUpstreamParameters(
Erik Kline11854592017-06-15 18:06:34 +0900174 eq(testIfName), eq(ipv4Addr), eq(ipv4Gateway), eq(null));
Erik Kline7990aef2017-06-01 20:11:25 +0900175 inOrder.verifyNoMoreInteractions();
176
177 final String ipv6Gw1 = "fe80::cafe";
178 lp.addRoute(new RouteInfo(InetAddress.getByName(ipv6Gw1)));
179 offload.setUpstreamLinkProperties(lp);
180 inOrder.verify(mHardware, times(1)).setUpstreamParameters(
181 eq(testIfName), eq(ipv4Addr), eq(ipv4Gateway), mStringArrayCaptor.capture());
182 ArrayList<String> v6gws = mStringArrayCaptor.getValue();
183 assertEquals(1, v6gws.size());
184 assertTrue(v6gws.contains(ipv6Gw1));
185 inOrder.verifyNoMoreInteractions();
186
187 final String ipv6Gw2 = "fe80::d00d";
188 lp.addRoute(new RouteInfo(InetAddress.getByName(ipv6Gw2)));
189 offload.setUpstreamLinkProperties(lp);
190 inOrder.verify(mHardware, times(1)).setUpstreamParameters(
191 eq(testIfName), eq(ipv4Addr), eq(ipv4Gateway), mStringArrayCaptor.capture());
192 v6gws = mStringArrayCaptor.getValue();
193 assertEquals(2, v6gws.size());
194 assertTrue(v6gws.contains(ipv6Gw1));
195 assertTrue(v6gws.contains(ipv6Gw2));
196 inOrder.verifyNoMoreInteractions();
197
198 final LinkProperties stacked = new LinkProperties();
199 stacked.setInterfaceName("stacked");
200 stacked.addLinkAddress(new LinkAddress("192.0.2.129/25"));
201 stacked.addRoute(new RouteInfo(InetAddress.getByName("192.0.2.254")));
202 stacked.addRoute(new RouteInfo(InetAddress.getByName("fe80::bad:f00")));
203 assertTrue(lp.addStackedLink(stacked));
204 offload.setUpstreamLinkProperties(lp);
205 inOrder.verify(mHardware, times(1)).setUpstreamParameters(
206 eq(testIfName), eq(ipv4Addr), eq(ipv4Gateway), mStringArrayCaptor.capture());
207 v6gws = mStringArrayCaptor.getValue();
208 assertEquals(2, v6gws.size());
209 assertTrue(v6gws.contains(ipv6Gw1));
210 assertTrue(v6gws.contains(ipv6Gw2));
211 inOrder.verifyNoMoreInteractions();
212 }
Erik Kline92c4db02017-05-31 10:21:32 +0900213}