DcTrackerTest.java revision ecb75ffc91e7036ae87c5f0488fa871d4e079922
127b650c406018355a88a41528db7859e232728a0Jack Yu/* 227b650c406018355a88a41528db7859e232728a0Jack Yu * Copyright (C) 2016 The Android Open Source Project 327b650c406018355a88a41528db7859e232728a0Jack Yu * 427b650c406018355a88a41528db7859e232728a0Jack Yu * Licensed under the Apache License, Version 2.0 (the "License"); 527b650c406018355a88a41528db7859e232728a0Jack Yu * you may not use this file except in compliance with the License. 627b650c406018355a88a41528db7859e232728a0Jack Yu * You may obtain a copy of the License at 727b650c406018355a88a41528db7859e232728a0Jack Yu * 827b650c406018355a88a41528db7859e232728a0Jack Yu * http://www.apache.org/licenses/LICENSE-2.0 927b650c406018355a88a41528db7859e232728a0Jack Yu * 1027b650c406018355a88a41528db7859e232728a0Jack Yu * Unless required by applicable law or agreed to in writing, software 1127b650c406018355a88a41528db7859e232728a0Jack Yu * distributed under the License is distributed on an "AS IS" BASIS, 1227b650c406018355a88a41528db7859e232728a0Jack Yu * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1327b650c406018355a88a41528db7859e232728a0Jack Yu * See the License for the specific language governing permissions and 1427b650c406018355a88a41528db7859e232728a0Jack Yu * limitations under the License. 1527b650c406018355a88a41528db7859e232728a0Jack Yu */ 1627b650c406018355a88a41528db7859e232728a0Jack Yu 17e8eb48626c3e6ad93c1839b1a9e87030c4b33ce4Jack Yupackage com.android.internal.telephony.dataconnection; 1827b650c406018355a88a41528db7859e232728a0Jack Yu 198e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static com.android.internal.telephony.TelephonyTestUtils.waitForMs; 208e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu 218e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.junit.Assert.assertArrayEquals; 228e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.junit.Assert.assertEquals; 238e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.junit.Assert.assertFalse; 248e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.junit.Assert.assertTrue; 258e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.junit.Assert.fail; 268e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Matchers.any; 278e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Matchers.anyInt; 288e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Matchers.anyLong; 298e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Matchers.anyString; 308e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Matchers.eq; 318e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Mockito.doAnswer; 328e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Mockito.doReturn; 338e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Mockito.never; 348e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Mockito.times; 358e9d1e601dce62cd0328701d7054e03db24727c7Jack Yuimport static org.mockito.Mockito.verify; 368e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu 3727b650c406018355a88a41528db7859e232728a0Jack Yuimport android.app.AlarmManager; 3827b650c406018355a88a41528db7859e232728a0Jack Yuimport android.app.PendingIntent; 39fe809fa371e9eab6d3b89fd2dad38c5f1479e6fefionaxuimport android.content.ContentResolver; 4027b650c406018355a88a41528db7859e232728a0Jack Yuimport android.content.Context; 417d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yuimport android.content.Intent; 4227b650c406018355a88a41528db7859e232728a0Jack Yuimport android.database.Cursor; 4327b650c406018355a88a41528db7859e232728a0Jack Yuimport android.database.MatrixCursor; 4427b650c406018355a88a41528db7859e232728a0Jack Yuimport android.net.LinkProperties; 450979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yuimport android.net.NetworkCapabilities; 460979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yuimport android.net.NetworkRequest; 4727b650c406018355a88a41528db7859e232728a0Jack Yuimport android.net.Uri; 4840cd4e909fd3a8ee462475814a949e08391ff8f5fionaxuimport android.os.AsyncResult; 4927b650c406018355a88a41528db7859e232728a0Jack Yuimport android.os.HandlerThread; 50783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yuimport android.os.IBinder; 5127b650c406018355a88a41528db7859e232728a0Jack Yuimport android.os.Message; 52783061ca03572618c01ce244d70d82fa4328d45ffionaxuimport android.os.PersistableBundle; 53fe809fa371e9eab6d3b89fd2dad38c5f1479e6fefionaxuimport android.provider.Settings; 5427b650c406018355a88a41528db7859e232728a0Jack Yuimport android.provider.Telephony; 55e73ef117c8f5a7ea2feaa9ba8a15ec2de4137c7dJordan Liuimport android.support.test.filters.FlakyTest; 56783061ca03572618c01ce244d70d82fa4328d45ffionaxuimport android.telephony.CarrierConfigManager; 5727b650c406018355a88a41528db7859e232728a0Jack Yuimport android.telephony.ServiceState; 584c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxuimport android.telephony.SubscriptionInfo; 594c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxuimport android.telephony.SubscriptionManager; 6027b650c406018355a88a41528db7859e232728a0Jack Yuimport android.test.mock.MockContentProvider; 6127b650c406018355a88a41528db7859e232728a0Jack Yuimport android.test.mock.MockContentResolver; 6227b650c406018355a88a41528db7859e232728a0Jack Yuimport android.test.suitebuilder.annotation.MediumTest; 630979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yuimport android.util.LocalLog; 6427b650c406018355a88a41528db7859e232728a0Jack Yu 65e8eb48626c3e6ad93c1839b1a9e87030c4b33ce4Jack Yuimport com.android.internal.telephony.DctConstants; 66e8eb48626c3e6ad93c1839b1a9e87030c4b33ce4Jack Yuimport com.android.internal.telephony.ISub; 67e8eb48626c3e6ad93c1839b1a9e87030c4b33ce4Jack Yuimport com.android.internal.telephony.Phone; 68e8eb48626c3e6ad93c1839b1a9e87030c4b33ce4Jack Yuimport com.android.internal.telephony.PhoneConstants; 69e8eb48626c3e6ad93c1839b1a9e87030c4b33ce4Jack Yuimport com.android.internal.telephony.TelephonyTest; 70fe809fa371e9eab6d3b89fd2dad38c5f1479e6fefionaxuimport com.android.internal.telephony.TestApplication; 713d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxuimport com.android.internal.telephony.dataconnection.DcTracker.DataAllowFailReason; 7227b650c406018355a88a41528db7859e232728a0Jack Yu 7327b650c406018355a88a41528db7859e232728a0Jack Yuimport org.junit.After; 7427b650c406018355a88a41528db7859e232728a0Jack Yuimport org.junit.Before; 7527b650c406018355a88a41528db7859e232728a0Jack Yuimport org.junit.Test; 7627b650c406018355a88a41528db7859e232728a0Jack Yuimport org.mockito.ArgumentCaptor; 77783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yuimport org.mockito.Mock; 784c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxuimport org.mockito.invocation.InvocationOnMock; 794c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxuimport org.mockito.stubbing.Answer; 8027b650c406018355a88a41528db7859e232728a0Jack Yu 811d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yuimport java.lang.reflect.Method; 8227b650c406018355a88a41528db7859e232728a0Jack Yuimport java.util.Arrays; 8327b650c406018355a88a41528db7859e232728a0Jack Yuimport java.util.List; 8427b650c406018355a88a41528db7859e232728a0Jack Yuimport java.util.regex.Matcher; 8527b650c406018355a88a41528db7859e232728a0Jack Yuimport java.util.regex.Pattern; 8627b650c406018355a88a41528db7859e232728a0Jack Yu 8727b650c406018355a88a41528db7859e232728a0Jack Yupublic class DcTrackerTest extends TelephonyTest { 8827b650c406018355a88a41528db7859e232728a0Jack Yu 8927b650c406018355a88a41528db7859e232728a0Jack Yu private final static String[] sNetworkAttributes = new String[]{ 9027b650c406018355a88a41528db7859e232728a0Jack Yu "mobile,0,0,0,-1,true", "mobile_mms,2,0,2,60000,true", 9127b650c406018355a88a41528db7859e232728a0Jack Yu "mobile_supl,3,0,2,60000,true", "mobile_dun,4,0,2,60000,true", 9227b650c406018355a88a41528db7859e232728a0Jack Yu "mobile_hipri,5,0,3,60000,true", "mobile_fota,10,0,2,60000,true", 9327b650c406018355a88a41528db7859e232728a0Jack Yu "mobile_ims,11,0,2,60000,true", "mobile_cbs,12,0,2,60000,true", 9427b650c406018355a88a41528db7859e232728a0Jack Yu "mobile_ia,14,0,2,-1,true", "mobile_emergency,15,0,2,-1,true"}; 9527b650c406018355a88a41528db7859e232728a0Jack Yu 961d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu private final static List<String> sApnTypes = Arrays.asList( 9727b650c406018355a88a41528db7859e232728a0Jack Yu "default", "mms", "cbs", "fota", "supl", "ia", "emergency", "dun", "hipri", "ims"); 9827b650c406018355a88a41528db7859e232728a0Jack Yu 998e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu public static final String FAKE_APN1 = "FAKE APN 1"; 1008e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu public static final String FAKE_APN2 = "FAKE APN 2"; 1018e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu public static final String FAKE_APN3 = "FAKE APN 3"; 1028e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu public static final String FAKE_IFNAME = "FAKE IFNAME"; 1038e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu public static final String FAKE_PCSCF_ADDRESS = "22.33.44.55"; 1048e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu public static final String FAKE_GATEWAY = "11.22.33.44"; 1058e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu public static final String FAKE_DNS = "55.66.77.88"; 1068e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu public static final String FAKE_ADDRESS = "99.88.77.66"; 10727b650c406018355a88a41528db7859e232728a0Jack Yu 108783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yu @Mock 109783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yu ISub mIsub; 110783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yu @Mock 111783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yu IBinder mBinder; 1120979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu @Mock 1130979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu NetworkRequest mNetworkRequest; 1144c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu @Mock 1154c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu SubscriptionInfo mSubscriptionInfo; 116783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yu 11727b650c406018355a88a41528db7859e232728a0Jack Yu private DcTracker mDct; 1187e9240253edb59e0aa657de434faa1ccdf17a742Amit Mahajan private DcTrackerTestHandler mDcTrackerTestHandler; 11927b650c406018355a88a41528db7859e232728a0Jack Yu 12027b650c406018355a88a41528db7859e232728a0Jack Yu private AlarmManager mAlarmManager; 12127b650c406018355a88a41528db7859e232728a0Jack Yu 122783061ca03572618c01ce244d70d82fa4328d45ffionaxu private PersistableBundle mBundle; 123783061ca03572618c01ce244d70d82fa4328d45ffionaxu 1244c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu private SubscriptionManager.OnSubscriptionsChangedListener mOnSubscriptionsChangedListener; 1254c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 12627b650c406018355a88a41528db7859e232728a0Jack Yu private final ApnSettingContentProvider mApnSettingContentProvider = 12727b650c406018355a88a41528db7859e232728a0Jack Yu new ApnSettingContentProvider(); 12827b650c406018355a88a41528db7859e232728a0Jack Yu 12927b650c406018355a88a41528db7859e232728a0Jack Yu private class DcTrackerTestHandler extends HandlerThread { 13027b650c406018355a88a41528db7859e232728a0Jack Yu 13127b650c406018355a88a41528db7859e232728a0Jack Yu private DcTrackerTestHandler(String name) { 13227b650c406018355a88a41528db7859e232728a0Jack Yu super(name); 13327b650c406018355a88a41528db7859e232728a0Jack Yu } 13427b650c406018355a88a41528db7859e232728a0Jack Yu 13527b650c406018355a88a41528db7859e232728a0Jack Yu @Override 13627b650c406018355a88a41528db7859e232728a0Jack Yu public void onLooperPrepared() { 13727b650c406018355a88a41528db7859e232728a0Jack Yu mDct = new DcTracker(mPhone); 13827b650c406018355a88a41528db7859e232728a0Jack Yu setReady(true); 13927b650c406018355a88a41528db7859e232728a0Jack Yu } 14027b650c406018355a88a41528db7859e232728a0Jack Yu } 14127b650c406018355a88a41528db7859e232728a0Jack Yu 14227b650c406018355a88a41528db7859e232728a0Jack Yu private class ApnSettingContentProvider extends MockContentProvider { 14327b650c406018355a88a41528db7859e232728a0Jack Yu 14427b650c406018355a88a41528db7859e232728a0Jack Yu @Override 14527b650c406018355a88a41528db7859e232728a0Jack Yu public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, 14627b650c406018355a88a41528db7859e232728a0Jack Yu String sortOrder) { 14727b650c406018355a88a41528db7859e232728a0Jack Yu logd("ApnSettingContentProvider: query"); 14827b650c406018355a88a41528db7859e232728a0Jack Yu logd(" uri = " + uri); 14927b650c406018355a88a41528db7859e232728a0Jack Yu logd(" projection = " + Arrays.toString(projection)); 15027b650c406018355a88a41528db7859e232728a0Jack Yu logd(" selection = " + selection); 15127b650c406018355a88a41528db7859e232728a0Jack Yu logd(" selectionArgs = " + Arrays.toString(selectionArgs)); 15227b650c406018355a88a41528db7859e232728a0Jack Yu logd(" sortOrder = " + sortOrder); 15327b650c406018355a88a41528db7859e232728a0Jack Yu 15427b650c406018355a88a41528db7859e232728a0Jack Yu if (uri.compareTo(Telephony.Carriers.CONTENT_URI) == 0) { 15527b650c406018355a88a41528db7859e232728a0Jack Yu if (projection == null && selectionArgs == null && selection != null) { 15627b650c406018355a88a41528db7859e232728a0Jack Yu 15727b650c406018355a88a41528db7859e232728a0Jack Yu Pattern pattern = Pattern.compile("^numeric = '([0-9]*)'"); 15827b650c406018355a88a41528db7859e232728a0Jack Yu Matcher matcher = pattern.matcher(selection); 15927b650c406018355a88a41528db7859e232728a0Jack Yu if (!matcher.find()) { 16027b650c406018355a88a41528db7859e232728a0Jack Yu logd("Cannot find MCC/MNC from " + selection); 16127b650c406018355a88a41528db7859e232728a0Jack Yu return null; 16227b650c406018355a88a41528db7859e232728a0Jack Yu } 16327b650c406018355a88a41528db7859e232728a0Jack Yu 16427b650c406018355a88a41528db7859e232728a0Jack Yu String plmn = matcher.group(1); 16527b650c406018355a88a41528db7859e232728a0Jack Yu 16627b650c406018355a88a41528db7859e232728a0Jack Yu logd("Query '" + plmn + "' APN settings"); 16727b650c406018355a88a41528db7859e232728a0Jack Yu MatrixCursor mc = new MatrixCursor( 16827b650c406018355a88a41528db7859e232728a0Jack Yu new String[]{Telephony.Carriers._ID, Telephony.Carriers.NUMERIC, 16927b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.NAME, Telephony.Carriers.APN, 17027b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.PROXY, Telephony.Carriers.PORT, 17127b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.MMSC, Telephony.Carriers.MMSPROXY, 17227b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.MMSPORT, Telephony.Carriers.USER, 17327b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.PASSWORD, Telephony.Carriers.AUTH_TYPE, 17427b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.TYPE, 17527b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.PROTOCOL, 17627b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.ROAMING_PROTOCOL, 17727b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.CARRIER_ENABLED, Telephony.Carriers.BEARER, 17827b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.BEARER_BITMASK, 17927b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.PROFILE_ID, 18027b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.MODEM_COGNITIVE, 18127b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.MAX_CONNS, Telephony.Carriers.WAIT_TIME, 18227b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.MAX_CONNS_TIME, Telephony.Carriers.MTU, 18327b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.MVNO_TYPE, 18427b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.MVNO_MATCH_DATA}); 18527b650c406018355a88a41528db7859e232728a0Jack Yu 18627b650c406018355a88a41528db7859e232728a0Jack Yu mc.addRow(new Object[]{ 18727b650c406018355a88a41528db7859e232728a0Jack Yu 2163, // id 18827b650c406018355a88a41528db7859e232728a0Jack Yu plmn, // numeric 18927b650c406018355a88a41528db7859e232728a0Jack Yu "sp-mode", // name 19027b650c406018355a88a41528db7859e232728a0Jack Yu FAKE_APN1, // apn 19127b650c406018355a88a41528db7859e232728a0Jack Yu "", // proxy 19227b650c406018355a88a41528db7859e232728a0Jack Yu "", // port 19327b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsc 19427b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsproxy 19527b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsport 19627b650c406018355a88a41528db7859e232728a0Jack Yu "", // user 19727b650c406018355a88a41528db7859e232728a0Jack Yu "", // password 19827b650c406018355a88a41528db7859e232728a0Jack Yu -1, // authtype 19927b650c406018355a88a41528db7859e232728a0Jack Yu "default,supl", // types 20027b650c406018355a88a41528db7859e232728a0Jack Yu "IP", // protocol 20127b650c406018355a88a41528db7859e232728a0Jack Yu "IP", // roaming_protocol 20227b650c406018355a88a41528db7859e232728a0Jack Yu 1, // carrier_enabled 20327b650c406018355a88a41528db7859e232728a0Jack Yu 0, // bearer 20427b650c406018355a88a41528db7859e232728a0Jack Yu 0, // bearer_bitmask 20527b650c406018355a88a41528db7859e232728a0Jack Yu 0, // profile_id 20627b650c406018355a88a41528db7859e232728a0Jack Yu 0, // modem_cognitive 20727b650c406018355a88a41528db7859e232728a0Jack Yu 0, // max_conns 20827b650c406018355a88a41528db7859e232728a0Jack Yu 0, // wait_time 20927b650c406018355a88a41528db7859e232728a0Jack Yu 0, // max_conns_time 21027b650c406018355a88a41528db7859e232728a0Jack Yu 0, // mtu 21127b650c406018355a88a41528db7859e232728a0Jack Yu "", // mvno_type 21227b650c406018355a88a41528db7859e232728a0Jack Yu "" // mnvo_match_data 21327b650c406018355a88a41528db7859e232728a0Jack Yu }); 21427b650c406018355a88a41528db7859e232728a0Jack Yu 21527b650c406018355a88a41528db7859e232728a0Jack Yu mc.addRow(new Object[]{ 21627b650c406018355a88a41528db7859e232728a0Jack Yu 2164, // id 21727b650c406018355a88a41528db7859e232728a0Jack Yu plmn, // numeric 21827b650c406018355a88a41528db7859e232728a0Jack Yu "mopera U", // name 21927b650c406018355a88a41528db7859e232728a0Jack Yu FAKE_APN2, // apn 22027b650c406018355a88a41528db7859e232728a0Jack Yu "", // proxy 22127b650c406018355a88a41528db7859e232728a0Jack Yu "", // port 22227b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsc 22327b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsproxy 22427b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsport 22527b650c406018355a88a41528db7859e232728a0Jack Yu "", // user 22627b650c406018355a88a41528db7859e232728a0Jack Yu "", // password 22727b650c406018355a88a41528db7859e232728a0Jack Yu -1, // authtype 22827b650c406018355a88a41528db7859e232728a0Jack Yu "default,supl", // types 22927b650c406018355a88a41528db7859e232728a0Jack Yu "IP", // protocol 23027b650c406018355a88a41528db7859e232728a0Jack Yu "IP", // roaming_protocol 23127b650c406018355a88a41528db7859e232728a0Jack Yu 1, // carrier_enabled 23227b650c406018355a88a41528db7859e232728a0Jack Yu 0, // bearer 23327b650c406018355a88a41528db7859e232728a0Jack Yu 0, // bearer_bitmask 23427b650c406018355a88a41528db7859e232728a0Jack Yu 0, // profile_id 23527b650c406018355a88a41528db7859e232728a0Jack Yu 0, // modem_cognitive 23627b650c406018355a88a41528db7859e232728a0Jack Yu 0, // max_conns 23727b650c406018355a88a41528db7859e232728a0Jack Yu 0, // wait_time 23827b650c406018355a88a41528db7859e232728a0Jack Yu 0, // max_conns_time 23927b650c406018355a88a41528db7859e232728a0Jack Yu 0, // mtu 24027b650c406018355a88a41528db7859e232728a0Jack Yu "", // mvno_type 24127b650c406018355a88a41528db7859e232728a0Jack Yu "" // mnvo_match_data 24227b650c406018355a88a41528db7859e232728a0Jack Yu }); 24327b650c406018355a88a41528db7859e232728a0Jack Yu 24427b650c406018355a88a41528db7859e232728a0Jack Yu mc.addRow(new Object[]{ 24527b650c406018355a88a41528db7859e232728a0Jack Yu 2165, // id 24627b650c406018355a88a41528db7859e232728a0Jack Yu plmn, // numeric 24727b650c406018355a88a41528db7859e232728a0Jack Yu "b-mobile for Nexus", // name 24827b650c406018355a88a41528db7859e232728a0Jack Yu FAKE_APN3, // apn 24927b650c406018355a88a41528db7859e232728a0Jack Yu "", // proxy 25027b650c406018355a88a41528db7859e232728a0Jack Yu "", // port 25127b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsc 25227b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsproxy 25327b650c406018355a88a41528db7859e232728a0Jack Yu "", // mmsport 25427b650c406018355a88a41528db7859e232728a0Jack Yu "", // user 25527b650c406018355a88a41528db7859e232728a0Jack Yu "", // password 2568e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu -1, // authtype 257783061ca03572618c01ce244d70d82fa4328d45ffionaxu "ims", // types 25827b650c406018355a88a41528db7859e232728a0Jack Yu "IP", // protocol 25927b650c406018355a88a41528db7859e232728a0Jack Yu "IP", // roaming_protocol 26027b650c406018355a88a41528db7859e232728a0Jack Yu 1, // carrier_enabled 26127b650c406018355a88a41528db7859e232728a0Jack Yu 0, // bearer 26227b650c406018355a88a41528db7859e232728a0Jack Yu 0, // bearer_bitmask 26327b650c406018355a88a41528db7859e232728a0Jack Yu 0, // profile_id 26427b650c406018355a88a41528db7859e232728a0Jack Yu 0, // modem_cognitive 26527b650c406018355a88a41528db7859e232728a0Jack Yu 0, // max_conns 26627b650c406018355a88a41528db7859e232728a0Jack Yu 0, // wait_time 26727b650c406018355a88a41528db7859e232728a0Jack Yu 0, // max_conns_time 26827b650c406018355a88a41528db7859e232728a0Jack Yu 0, // mtu 26927b650c406018355a88a41528db7859e232728a0Jack Yu "", // mvno_type 27027b650c406018355a88a41528db7859e232728a0Jack Yu "" // mnvo_match_data 27127b650c406018355a88a41528db7859e232728a0Jack Yu }); 27227b650c406018355a88a41528db7859e232728a0Jack Yu 27327b650c406018355a88a41528db7859e232728a0Jack Yu return mc; 27427b650c406018355a88a41528db7859e232728a0Jack Yu } 27527b650c406018355a88a41528db7859e232728a0Jack Yu } 27627b650c406018355a88a41528db7859e232728a0Jack Yu 27727b650c406018355a88a41528db7859e232728a0Jack Yu return null; 27827b650c406018355a88a41528db7859e232728a0Jack Yu } 27927b650c406018355a88a41528db7859e232728a0Jack Yu } 28027b650c406018355a88a41528db7859e232728a0Jack Yu 28127b650c406018355a88a41528db7859e232728a0Jack Yu @Before 28227b650c406018355a88a41528db7859e232728a0Jack Yu public void setUp() throws Exception { 283fe809fa371e9eab6d3b89fd2dad38c5f1479e6fefionaxu // set the lazy cp to the real content provider in order to use the real settings 284fe809fa371e9eab6d3b89fd2dad38c5f1479e6fefionaxu ContentResolver realContentResolver = TestApplication.getAppContext().getContentResolver(); 285fe809fa371e9eab6d3b89fd2dad38c5f1479e6fefionaxu Settings.Global.getInt(realContentResolver, Settings.Global.MOBILE_DATA, 1); 286fe809fa371e9eab6d3b89fd2dad38c5f1479e6fefionaxu 28727b650c406018355a88a41528db7859e232728a0Jack Yu logd("DcTrackerTest +Setup!"); 28827b650c406018355a88a41528db7859e232728a0Jack Yu super.setUp(getClass().getSimpleName()); 28927b650c406018355a88a41528db7859e232728a0Jack Yu 29027b650c406018355a88a41528db7859e232728a0Jack Yu doReturn("fake.action_detached").when(mPhone).getActionDetached(); 29127b650c406018355a88a41528db7859e232728a0Jack Yu doReturn("fake.action_attached").when(mPhone).getActionAttached(); 29227b650c406018355a88a41528db7859e232728a0Jack Yu doReturn("44010").when(mSimRecords).getOperatorNumeric(); 29327b650c406018355a88a41528db7859e232728a0Jack Yu 29427b650c406018355a88a41528db7859e232728a0Jack Yu mContextFixture.putStringArrayResource(com.android.internal.R.array.networkAttributes, 29527b650c406018355a88a41528db7859e232728a0Jack Yu sNetworkAttributes); 29627b650c406018355a88a41528db7859e232728a0Jack Yu mContextFixture.putStringArrayResource(com.android.internal.R.array. 29727b650c406018355a88a41528db7859e232728a0Jack Yu config_mobile_tcp_buffers, new String[]{ 29827b650c406018355a88a41528db7859e232728a0Jack Yu "umts:131072,262144,1452032,4096,16384,399360", 29927b650c406018355a88a41528db7859e232728a0Jack Yu "hspa:131072,262144,2441216,4096,16384,399360", 30027b650c406018355a88a41528db7859e232728a0Jack Yu "hsupa:131072,262144,2441216,4096,16384,399360", 30127b650c406018355a88a41528db7859e232728a0Jack Yu "hsdpa:131072,262144,2441216,4096,16384,399360", 30227b650c406018355a88a41528db7859e232728a0Jack Yu "hspap:131072,262144,2441216,4096,16384,399360", 30327b650c406018355a88a41528db7859e232728a0Jack Yu "edge:16384,32768,131072,4096,16384,65536", 30427b650c406018355a88a41528db7859e232728a0Jack Yu "gprs:4096,8192,24576,4096,8192,24576", 30527b650c406018355a88a41528db7859e232728a0Jack Yu "1xrtt:16384,32768,131070,4096,16384,102400", 30627b650c406018355a88a41528db7859e232728a0Jack Yu "evdo:131072,262144,1048576,4096,16384,524288", 30727b650c406018355a88a41528db7859e232728a0Jack Yu "lte:524288,1048576,8388608,262144,524288,4194304"}); 30827b650c406018355a88a41528db7859e232728a0Jack Yu 3097d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu ((MockContentResolver) mContext.getContentResolver()).addProvider( 31027b650c406018355a88a41528db7859e232728a0Jack Yu Telephony.Carriers.CONTENT_URI.getAuthority(), mApnSettingContentProvider); 31127b650c406018355a88a41528db7859e232728a0Jack Yu 31227b650c406018355a88a41528db7859e232728a0Jack Yu doReturn(true).when(mSimRecords).getRecordsLoaded(); 31327b650c406018355a88a41528db7859e232728a0Jack Yu doReturn(PhoneConstants.State.IDLE).when(mCT).getState(); 31427b650c406018355a88a41528db7859e232728a0Jack Yu doReturn(true).when(mSST).getDesiredPowerState(); 315f9665d579a68b00057cc171b2f1c39a010b7e40afionaxu doReturn(true).when(mSST).getPowerStateFromCarrier(); 3164c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu doAnswer( 3174c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu new Answer<Void>() { 3184c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu @Override 3194c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu public Void answer(InvocationOnMock invocation) throws Throwable { 3204c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu mOnSubscriptionsChangedListener = 3214c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu (SubscriptionManager.OnSubscriptionsChangedListener) 3224c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu invocation.getArguments()[0]; 3234c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu return null; 3244c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu } 3254c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu } 3264c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu ).when(mSubscriptionManager).addOnSubscriptionsChangedListener(any()); 3274c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu doReturn(mSubscriptionInfo).when(mSubscriptionManager).getActiveSubscriptionInfo(anyInt()); 32827b650c406018355a88a41528db7859e232728a0Jack Yu 329783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yu doReturn(1).when(mIsub).getDefaultDataSubId(); 330783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yu doReturn(mIsub).when(mBinder).queryLocalInterface(anyString()); 3311d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu mServiceManagerMockedServices.put("isub", mBinder); 332783e33ac9e332b7eefa6bb125fbdb82e0c928c73Jack Yu 33391abb5484d609dd4f117dd3dc234fe9a1b619c91Jack Yu mContextFixture.putStringArrayResource( 33491abb5484d609dd4f117dd3dc234fe9a1b619c91Jack Yu com.android.internal.R.array.config_cell_retries_per_error_code, 33591abb5484d609dd4f117dd3dc234fe9a1b619c91Jack Yu new String[]{"36,2"}); 33691abb5484d609dd4f117dd3dc234fe9a1b619c91Jack Yu 3377d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu mAlarmManager = (AlarmManager) mContext.getSystemService(Context.ALARM_SERVICE); 338783061ca03572618c01ce244d70d82fa4328d45ffionaxu mBundle = mContextFixture.getCarrierConfigBundle(); 33927b650c406018355a88a41528db7859e232728a0Jack Yu 3407e9240253edb59e0aa657de434faa1ccdf17a742Amit Mahajan mDcTrackerTestHandler = new DcTrackerTestHandler(getClass().getSimpleName()); 3417e9240253edb59e0aa657de434faa1ccdf17a742Amit Mahajan mDcTrackerTestHandler.start(); 34227b650c406018355a88a41528db7859e232728a0Jack Yu waitUntilReady(); 34327b650c406018355a88a41528db7859e232728a0Jack Yu waitForMs(600); 34427b650c406018355a88a41528db7859e232728a0Jack Yu logd("DcTrackerTest -Setup!"); 34527b650c406018355a88a41528db7859e232728a0Jack Yu } 34627b650c406018355a88a41528db7859e232728a0Jack Yu 34727b650c406018355a88a41528db7859e232728a0Jack Yu @After 34827b650c406018355a88a41528db7859e232728a0Jack Yu public void tearDown() throws Exception { 34927b650c406018355a88a41528db7859e232728a0Jack Yu logd("DcTrackerTest -tearDown"); 35027b650c406018355a88a41528db7859e232728a0Jack Yu mDct.removeCallbacksAndMessages(null); 35127b650c406018355a88a41528db7859e232728a0Jack Yu mDct = null; 3527e9240253edb59e0aa657de434faa1ccdf17a742Amit Mahajan mDcTrackerTestHandler.quitSafely(); 35327b650c406018355a88a41528db7859e232728a0Jack Yu super.tearDown(); 35427b650c406018355a88a41528db7859e232728a0Jack Yu } 35527b650c406018355a88a41528db7859e232728a0Jack Yu 3567d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Create a successful data response 3573a5b9323f422134b68a92c36813001ec8bed2866Jack Yu public static DataCallResponse createDataCallResponse() { 3587d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 3598e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu return new DataCallResponse(0, -1, 1, 2, "IP", FAKE_IFNAME, 3608e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu FAKE_ADDRESS, FAKE_DNS, FAKE_GATEWAY, FAKE_PCSCF_ADDRESS, 1440); 3618e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu } 3628e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu 3638e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu private void verifyDataProfile(DataProfile dp, String apn, int profileId, 3648e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu int supportedApnTypesBitmap) { 3658e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(profileId, dp.profileId); 3668e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(apn, dp.apn); 3678e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals("IP", dp.protocol); 3688e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(0, dp.authType); 3698e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals("", dp.user); 3708e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals("", dp.password); 3718e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(0, dp.type); 3728e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(0, dp.maxConnsTime); 3738e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(0, dp.maxConns); 3748e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(0, dp.waitTime); 3758e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertTrue(dp.enabled); 3768e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(supportedApnTypesBitmap, dp.supportedApnTypesBitmap); 3778e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals("IP", dp.roamingProtocol); 3788e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(0, dp.bearerBitmap); 3798e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals(0, dp.mtu); 3808e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals("", dp.mvnoType); 3818e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertEquals("", dp.mvnoMatchData); 3828e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu assertFalse(dp.modemCognitive); 3837d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu } 38427b650c406018355a88a41528db7859e232728a0Jack Yu 3857d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu private void verifyDataConnected(final String apnSetting) { 38627b650c406018355a88a41528db7859e232728a0Jack Yu verify(mPhone, times(1)).notifyDataConnection(eq(Phone.REASON_CONNECTED), 38727b650c406018355a88a41528db7859e232728a0Jack Yu eq(PhoneConstants.APN_TYPE_DEFAULT)); 38827b650c406018355a88a41528db7859e232728a0Jack Yu 38927b650c406018355a88a41528db7859e232728a0Jack Yu verify(mAlarmManager, times(1)).set(eq(AlarmManager.ELAPSED_REALTIME_WAKEUP), anyLong(), 39027b650c406018355a88a41528db7859e232728a0Jack Yu any(PendingIntent.class)); 39127b650c406018355a88a41528db7859e232728a0Jack Yu 3927d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu assertEquals(apnSetting, mDct.getActiveApnString(PhoneConstants.APN_TYPE_DEFAULT)); 39327b650c406018355a88a41528db7859e232728a0Jack Yu assertArrayEquals(new String[]{PhoneConstants.APN_TYPE_DEFAULT}, mDct.getActiveApnTypes()); 39427b650c406018355a88a41528db7859e232728a0Jack Yu assertTrue(mDct.getAnyDataEnabled()); 39527b650c406018355a88a41528db7859e232728a0Jack Yu 39627b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(DctConstants.State.CONNECTED, mDct.getOverallState()); 39727b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(DctConstants.State.CONNECTED, mDct.getState(PhoneConstants.APN_TYPE_DEFAULT)); 39827b650c406018355a88a41528db7859e232728a0Jack Yu 39927b650c406018355a88a41528db7859e232728a0Jack Yu LinkProperties linkProperties = mDct.getLinkProperties(PhoneConstants.APN_TYPE_DEFAULT); 40027b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(FAKE_IFNAME, linkProperties.getInterfaceName()); 40127b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(1, linkProperties.getAddresses().size()); 40227b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(FAKE_ADDRESS, linkProperties.getAddresses().get(0).getHostAddress()); 40327b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(1, linkProperties.getDnsServers().size()); 40427b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(FAKE_DNS, linkProperties.getDnsServers().get(0).getHostAddress()); 40527b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(FAKE_GATEWAY, linkProperties.getRoutes().get(0).getGateway().getHostAddress()); 40627b650c406018355a88a41528db7859e232728a0Jack Yu } 40727b650c406018355a88a41528db7859e232728a0Jack Yu 4083d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu private boolean isDataAllowed(DataAllowFailReason dataAllowFailReasons) { 4091d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu try { 4103d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu Method method = DcTracker.class.getDeclaredMethod("isDataAllowed", 4113d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu DataAllowFailReason.class); 4121d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu method.setAccessible(true); 4133d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu return (boolean) method.invoke(mDct, dataAllowFailReasons); 4141d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu } catch (Exception e) { 4151d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu fail(e.toString()); 4161d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu return false; 4171d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu } 4181d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu } 4191d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu 4207d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Test the normal data call setup scenario. 42127b650c406018355a88a41528db7859e232728a0Jack Yu @Test 42227b650c406018355a88a41528db7859e232728a0Jack Yu @MediumTest 42327b650c406018355a88a41528db7859e232728a0Jack Yu public void testDataSetup() { 42427b650c406018355a88a41528db7859e232728a0Jack Yu 4250979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.setDataEnabled(true); 4260979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 4277d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu mSimulatedCommands.setDataCallResponse(true, createDataCallResponse()); 4287d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4293d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu DataAllowFailReason failureReason = new DataAllowFailReason(); 4303d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu boolean allowed = isDataAllowed(failureReason); 4313d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertFalse(failureReason.getDataAllowFailReason(), allowed); 4321d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu 4337d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu logd("Sending EVENT_RECORDS_LOADED"); 4347d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_RECORDS_LOADED, null)); 4357d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu waitForMs(200); 4367d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4377d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu ArgumentCaptor<String> apnTypeArgumentCaptor = ArgumentCaptor.forClass(String.class); 4387d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verify(mPhone, times(sNetworkAttributes.length)).notifyDataConnection( 4397d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu eq(Phone.REASON_SIM_LOADED), apnTypeArgumentCaptor.capture(), 4407d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu eq(PhoneConstants.DataState.DISCONNECTED)); 4417d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4427d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu assertEquals(sApnTypes, apnTypeArgumentCaptor.getAllValues()); 4437d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4447d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu logd("Sending EVENT_DATA_CONNECTION_ATTACHED"); 4457d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_DATA_CONNECTION_ATTACHED, null)); 4467d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu waitForMs(200); 4477d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4487d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu apnTypeArgumentCaptor = ArgumentCaptor.forClass(String.class); 4497d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verify(mPhone, times(sNetworkAttributes.length)).notifyDataConnection( 4507d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu eq(Phone.REASON_DATA_ATTACHED), apnTypeArgumentCaptor.capture(), 4517d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu eq(PhoneConstants.DataState.DISCONNECTED)); 4527d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4537d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu assertEquals(sApnTypes, apnTypeArgumentCaptor.getAllValues()); 4547d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4557d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu apnTypeArgumentCaptor = ArgumentCaptor.forClass(String.class); 4567d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verify(mPhone, times(sNetworkAttributes.length)).notifyDataConnection( 4577d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu eq(Phone.REASON_DATA_ENABLED), apnTypeArgumentCaptor.capture(), 4587d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu eq(PhoneConstants.DataState.DISCONNECTED)); 45927b650c406018355a88a41528db7859e232728a0Jack Yu 4607d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu assertEquals(sApnTypes, apnTypeArgumentCaptor.getAllValues()); 4617d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4627d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu logd("Sending EVENT_ENABLE_NEW_APN"); 4637d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // APN id 0 is APN_TYPE_DEFAULT 4647d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu mDct.setEnabled(0, true); 4657d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu waitForMs(200); 4667d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4673d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu failureReason.clearAllReasons(); 4683d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu allowed = isDataAllowed(failureReason); 4693d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertTrue(failureReason.getDataAllowFailReason(), allowed); 4701d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu 471f9339819516dbe67fb8fcef846a0ae4441ef17bdPaul Duffin ArgumentCaptor<DataProfile> dpCaptor = ArgumentCaptor.forClass(DataProfile.class); 4727d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Verify if RIL command was sent properly. 4737d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verify(mSimulatedCommandsVerifier, times(1)).setupDataCall( 4748e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(ServiceState.RIL_RADIO_TECHNOLOGY_UMTS), dpCaptor.capture(), 4758e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(false), eq(false), any(Message.class)); 4768e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verifyDataProfile(dpCaptor.getValue(), FAKE_APN1, 0, 5); 4777d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4787d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verifyDataConnected(FAKE_APN1); 4797d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu } 4807d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 4817d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Test the scenario where the first data call setup is failed, and then retry the setup later. 4827d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu @Test 4837d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu @MediumTest 4847d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu public void testDataRetry() { 4850979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 4860979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.setDataEnabled(true); 4870979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 4887d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // LOST_CONNECTION(0x10004) is a non-permanent failure, so we'll retry data setup later. 4898e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu DataCallResponse dcResponse = new DataCallResponse(0x10004, -1, 1, 2, "IP", FAKE_IFNAME, 4908e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu FAKE_ADDRESS, FAKE_DNS, FAKE_GATEWAY, FAKE_PCSCF_ADDRESS, 1440); 4917d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Simulate RIL fails the data call setup 4927d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu mSimulatedCommands.setDataCallResponse(false, dcResponse); 49327b650c406018355a88a41528db7859e232728a0Jack Yu 4943d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu DataAllowFailReason failureReason = new DataAllowFailReason(); 4953d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu boolean allowed = isDataAllowed(failureReason); 4963d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertFalse(failureReason.getDataAllowFailReason(), allowed); 4971d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu 49827b650c406018355a88a41528db7859e232728a0Jack Yu logd("Sending EVENT_RECORDS_LOADED"); 49927b650c406018355a88a41528db7859e232728a0Jack Yu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_RECORDS_LOADED, null)); 50027b650c406018355a88a41528db7859e232728a0Jack Yu waitForMs(200); 50127b650c406018355a88a41528db7859e232728a0Jack Yu 50227b650c406018355a88a41528db7859e232728a0Jack Yu ArgumentCaptor<String> apnTypeArgumentCaptor = ArgumentCaptor.forClass(String.class); 50327b650c406018355a88a41528db7859e232728a0Jack Yu verify(mPhone, times(sNetworkAttributes.length)).notifyDataConnection( 50427b650c406018355a88a41528db7859e232728a0Jack Yu eq(Phone.REASON_SIM_LOADED), apnTypeArgumentCaptor.capture(), 50527b650c406018355a88a41528db7859e232728a0Jack Yu eq(PhoneConstants.DataState.DISCONNECTED)); 50627b650c406018355a88a41528db7859e232728a0Jack Yu 50727b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(sApnTypes, apnTypeArgumentCaptor.getAllValues()); 50827b650c406018355a88a41528db7859e232728a0Jack Yu 50927b650c406018355a88a41528db7859e232728a0Jack Yu logd("Sending EVENT_DATA_CONNECTION_ATTACHED"); 51027b650c406018355a88a41528db7859e232728a0Jack Yu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_DATA_CONNECTION_ATTACHED, null)); 51127b650c406018355a88a41528db7859e232728a0Jack Yu waitForMs(200); 51227b650c406018355a88a41528db7859e232728a0Jack Yu 51327b650c406018355a88a41528db7859e232728a0Jack Yu apnTypeArgumentCaptor = ArgumentCaptor.forClass(String.class); 51427b650c406018355a88a41528db7859e232728a0Jack Yu verify(mPhone, times(sNetworkAttributes.length)).notifyDataConnection( 51527b650c406018355a88a41528db7859e232728a0Jack Yu eq(Phone.REASON_DATA_ATTACHED), apnTypeArgumentCaptor.capture(), 51627b650c406018355a88a41528db7859e232728a0Jack Yu eq(PhoneConstants.DataState.DISCONNECTED)); 51727b650c406018355a88a41528db7859e232728a0Jack Yu 51827b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(sApnTypes, apnTypeArgumentCaptor.getAllValues()); 51927b650c406018355a88a41528db7859e232728a0Jack Yu 52027b650c406018355a88a41528db7859e232728a0Jack Yu apnTypeArgumentCaptor = ArgumentCaptor.forClass(String.class); 52127b650c406018355a88a41528db7859e232728a0Jack Yu verify(mPhone, times(sNetworkAttributes.length)).notifyDataConnection( 52227b650c406018355a88a41528db7859e232728a0Jack Yu eq(Phone.REASON_DATA_ENABLED), apnTypeArgumentCaptor.capture(), 52327b650c406018355a88a41528db7859e232728a0Jack Yu eq(PhoneConstants.DataState.DISCONNECTED)); 52427b650c406018355a88a41528db7859e232728a0Jack Yu 52527b650c406018355a88a41528db7859e232728a0Jack Yu assertEquals(sApnTypes, apnTypeArgumentCaptor.getAllValues()); 52627b650c406018355a88a41528db7859e232728a0Jack Yu 52727b650c406018355a88a41528db7859e232728a0Jack Yu logd("Sending EVENT_ENABLE_NEW_APN"); 52827b650c406018355a88a41528db7859e232728a0Jack Yu // APN id 0 is APN_TYPE_DEFAULT 52927b650c406018355a88a41528db7859e232728a0Jack Yu mDct.setEnabled(0, true); 53027b650c406018355a88a41528db7859e232728a0Jack Yu waitForMs(200); 5317d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 5323d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 5333d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu failureReason.clearAllReasons(); 5343d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu allowed = isDataAllowed(failureReason); 5353d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertTrue(failureReason.getDataAllowFailReason(), allowed); 5361d70c5957152ac4c8541f530e42ce596ca3f11d5Jack Yu 537f9339819516dbe67fb8fcef846a0ae4441ef17bdPaul Duffin ArgumentCaptor<DataProfile> dpCaptor = ArgumentCaptor.forClass(DataProfile.class); 5387d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Verify if RIL command was sent properly. 5397d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verify(mSimulatedCommandsVerifier, times(1)).setupDataCall( 5408e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(ServiceState.RIL_RADIO_TECHNOLOGY_UMTS), dpCaptor.capture(), 5418e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(false), eq(false), any(Message.class)); 5428e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verifyDataProfile(dpCaptor.getValue(), FAKE_APN1, 0, 5); 5437d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 5447d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Make sure we never notify connected because the data call setup is supposed to fail. 5457d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verify(mPhone, never()).notifyDataConnection(eq(Phone.REASON_CONNECTED), 5467d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu eq(PhoneConstants.APN_TYPE_DEFAULT)); 5477d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 5487d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Verify the retry manger schedule another data call setup. 5497d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verify(mAlarmManager, times(1)).setExact(eq(AlarmManager.ELAPSED_REALTIME_WAKEUP), 5507d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu anyLong(), any(PendingIntent.class)); 5517d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 5527d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // This time we'll let RIL command succeed. 5537d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu mSimulatedCommands.setDataCallResponse(true, createDataCallResponse()); 5547d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 5557d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Simulate the timer expires. 5567d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu Intent intent = new Intent("com.android.internal.telephony.data-reconnect.default"); 5577d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu intent.putExtra("reconnect_alarm_extra_type", PhoneConstants.APN_TYPE_DEFAULT); 5587d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu intent.putExtra(PhoneConstants.SUBSCRIPTION_KEY, 0); 5597d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu intent.addFlags(Intent.FLAG_RECEIVER_FOREGROUND); 5607d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu mContext.sendBroadcast(intent); 5617d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu waitForMs(200); 5627d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 563f9339819516dbe67fb8fcef846a0ae4441ef17bdPaul Duffin dpCaptor = ArgumentCaptor.forClass(DataProfile.class); 5647d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Verify if RIL command was sent properly. 5658e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verify(mSimulatedCommandsVerifier, times(2)).setupDataCall( 5668e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(ServiceState.RIL_RADIO_TECHNOLOGY_UMTS), dpCaptor.capture(), 5678e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(false), eq(false), any(Message.class)); 5688e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verifyDataProfile(dpCaptor.getValue(), FAKE_APN2, 0, 5); 5697d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu 5707d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu // Verify connected with APN2 setting. 5717d6d7d6cb68ee37b4bee33588ba2594e9cf0c197Jack Yu verifyDataConnected(FAKE_APN2); 57227b650c406018355a88a41528db7859e232728a0Jack Yu } 573783061ca03572618c01ce244d70d82fa4328d45ffionaxu 574783061ca03572618c01ce244d70d82fa4328d45ffionaxu @Test 575783061ca03572618c01ce244d70d82fa4328d45ffionaxu @MediumTest 576783061ca03572618c01ce244d70d82fa4328d45ffionaxu public void testUserDisableData() throws Exception { 577783061ca03572618c01ce244d70d82fa4328d45ffionaxu //step 1: setup two DataCalls one for Metered: default, another one for Non-metered: IMS 578783061ca03572618c01ce244d70d82fa4328d45ffionaxu //set Default and MMS to be metered in the CarrierConfigManager 579783061ca03572618c01ce244d70d82fa4328d45ffionaxu boolean dataEnabled = mDct.getDataEnabled(); 580783061ca03572618c01ce244d70d82fa4328d45ffionaxu mBundle.putStringArray(CarrierConfigManager.KEY_CARRIER_METERED_APN_TYPES_STRINGS, 581783061ca03572618c01ce244d70d82fa4328d45ffionaxu new String[]{PhoneConstants.APN_TYPE_DEFAULT, PhoneConstants.APN_TYPE_MMS}); 582783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setEnabled(5, true); 583783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setEnabled(0, true); 584783061ca03572618c01ce244d70d82fa4328d45ffionaxu 585783061ca03572618c01ce244d70d82fa4328d45ffionaxu logd("Sending EVENT_RECORDS_LOADED"); 586783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_RECORDS_LOADED, null)); 587783061ca03572618c01ce244d70d82fa4328d45ffionaxu waitForMs(200); 588783061ca03572618c01ce244d70d82fa4328d45ffionaxu 589783061ca03572618c01ce244d70d82fa4328d45ffionaxu logd("Sending EVENT_DATA_CONNECTION_ATTACHED"); 590783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_DATA_CONNECTION_ATTACHED, null)); 591783061ca03572618c01ce244d70d82fa4328d45ffionaxu waitForMs(200); 592783061ca03572618c01ce244d70d82fa4328d45ffionaxu 593783061ca03572618c01ce244d70d82fa4328d45ffionaxu logd("Sending DATA_ENABLED_CMD"); 594783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setDataEnabled(true); 595783061ca03572618c01ce244d70d82fa4328d45ffionaxu 596783061ca03572618c01ce244d70d82fa4328d45ffionaxu waitForMs(200); 597f9339819516dbe67fb8fcef846a0ae4441ef17bdPaul Duffin ArgumentCaptor<DataProfile> dpCaptor = ArgumentCaptor.forClass(DataProfile.class); 5988e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verify(mSimulatedCommandsVerifier, times(2)).setupDataCall( 5998e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(ServiceState.RIL_RADIO_TECHNOLOGY_UMTS), dpCaptor.capture(), 6008e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(false), eq(false), any(Message.class)); 6018e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verifyDataProfile(dpCaptor.getValue(), FAKE_APN1, 0, 5); 602783061ca03572618c01ce244d70d82fa4328d45ffionaxu 603783061ca03572618c01ce244d70d82fa4328d45ffionaxu logd("Sending DATA_DISABLED_CMD"); 604783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setDataEnabled(false); 605783061ca03572618c01ce244d70d82fa4328d45ffionaxu waitForMs(200); 606783061ca03572618c01ce244d70d82fa4328d45ffionaxu 607783061ca03572618c01ce244d70d82fa4328d45ffionaxu // expected tear down all metered DataConnections 608783061ca03572618c01ce244d70d82fa4328d45ffionaxu verify(mSimulatedCommandsVerifier, times(1)).deactivateDataCall(anyInt(), anyInt(), 609783061ca03572618c01ce244d70d82fa4328d45ffionaxu any(Message.class)); 610783061ca03572618c01ce244d70d82fa4328d45ffionaxu assertEquals(DctConstants.State.CONNECTED, mDct.getOverallState()); 611783061ca03572618c01ce244d70d82fa4328d45ffionaxu assertEquals(DctConstants.State.IDLE, mDct.getState(PhoneConstants.APN_TYPE_DEFAULT)); 612783061ca03572618c01ce244d70d82fa4328d45ffionaxu assertEquals(DctConstants.State.CONNECTED, mDct.getState(PhoneConstants.APN_TYPE_IMS)); 613783061ca03572618c01ce244d70d82fa4328d45ffionaxu 614783061ca03572618c01ce244d70d82fa4328d45ffionaxu // reset the setting at the end of this test 615783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setDataEnabled(dataEnabled); 616783061ca03572618c01ce244d70d82fa4328d45ffionaxu waitForMs(200); 617783061ca03572618c01ce244d70d82fa4328d45ffionaxu } 618783061ca03572618c01ce244d70d82fa4328d45ffionaxu 619783061ca03572618c01ce244d70d82fa4328d45ffionaxu @Test 620783061ca03572618c01ce244d70d82fa4328d45ffionaxu @MediumTest 621783061ca03572618c01ce244d70d82fa4328d45ffionaxu public void testUserDisableRoaming() throws Exception { 622783061ca03572618c01ce244d70d82fa4328d45ffionaxu //step 1: setup two DataCalls one for Metered: default, another one for Non-metered: IMS 6233d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu //step 2: set roaming disabled, data is enabled 6243d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu //step 3: under roaming service 6253d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu //step 4: only tear down metered data connections. 6263d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 627783061ca03572618c01ce244d70d82fa4328d45ffionaxu //set Default and MMS to be metered in the CarrierConfigManager 628783061ca03572618c01ce244d70d82fa4328d45ffionaxu boolean roamingEnabled = mDct.getDataOnRoamingEnabled(); 6293d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu boolean dataEnabled = mDct.getDataEnabled(); 6303d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 6313d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mBundle.putStringArray(CarrierConfigManager.KEY_CARRIER_METERED_ROAMING_APN_TYPES_STRINGS, 632783061ca03572618c01ce244d70d82fa4328d45ffionaxu new String[]{PhoneConstants.APN_TYPE_DEFAULT, PhoneConstants.APN_TYPE_MMS}); 633783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setEnabled(5, true); 634783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setEnabled(0, true); 635783061ca03572618c01ce244d70d82fa4328d45ffionaxu 636783061ca03572618c01ce244d70d82fa4328d45ffionaxu logd("Sending EVENT_RECORDS_LOADED"); 637783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_RECORDS_LOADED, null)); 638783061ca03572618c01ce244d70d82fa4328d45ffionaxu waitForMs(200); 639783061ca03572618c01ce244d70d82fa4328d45ffionaxu 640783061ca03572618c01ce244d70d82fa4328d45ffionaxu logd("Sending EVENT_DATA_CONNECTION_ATTACHED"); 641783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_DATA_CONNECTION_ATTACHED, null)); 642783061ca03572618c01ce244d70d82fa4328d45ffionaxu waitForMs(200); 643783061ca03572618c01ce244d70d82fa4328d45ffionaxu 644783061ca03572618c01ce244d70d82fa4328d45ffionaxu logd("Sending DATA_ENABLED_CMD"); 645783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setDataEnabled(true); 646783061ca03572618c01ce244d70d82fa4328d45ffionaxu 6478e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu waitForMs(300); 648f9339819516dbe67fb8fcef846a0ae4441ef17bdPaul Duffin ArgumentCaptor<DataProfile> dpCaptor = ArgumentCaptor.forClass(DataProfile.class); 6498e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verify(mSimulatedCommandsVerifier, times(2)).setupDataCall( 6508e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(ServiceState.RIL_RADIO_TECHNOLOGY_UMTS), dpCaptor.capture(), 6518e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(false), eq(false), any(Message.class)); 6528e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verifyDataProfile(dpCaptor.getValue(), FAKE_APN1, 0, 5); 653783061ca03572618c01ce244d70d82fa4328d45ffionaxu 6543d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu //user is in roaming 6553d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu doReturn(true).when(mServiceState).getDataRoaming(); 656783061ca03572618c01ce244d70d82fa4328d45ffionaxu logd("Sending DISABLE_ROAMING_CMD"); 657783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.setDataOnRoamingEnabled(false); 658783061ca03572618c01ce244d70d82fa4328d45ffionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_ROAMING_ON)); 659783061ca03572618c01ce244d70d82fa4328d45ffionaxu waitForMs(200); 660783061ca03572618c01ce244d70d82fa4328d45ffionaxu 661783061ca03572618c01ce244d70d82fa4328d45ffionaxu // expected tear down all metered DataConnections 6623d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu verify(mSimulatedCommandsVerifier, times(1)).deactivateDataCall(anyInt(), anyInt(), 663783061ca03572618c01ce244d70d82fa4328d45ffionaxu any(Message.class)); 6643d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertEquals(DctConstants.State.CONNECTED, mDct.getOverallState()); 6653d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertEquals(DctConstants.State.IDLE, mDct.getState(PhoneConstants.APN_TYPE_DEFAULT)); 6663d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertEquals(DctConstants.State.CONNECTED, mDct.getState(PhoneConstants.APN_TYPE_IMS)); 6673d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 6683d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu // reset roaming settings / data enabled settings at end of this test 6693d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mDct.setDataOnRoamingEnabled(roamingEnabled); 6703d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mDct.setDataEnabled(dataEnabled); 6713d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu waitForMs(200); 6723d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu } 6733d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 67492428df50d736a3d1d0f32779a22c65fcec0efabJordan Liu @FlakyTest 6753d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu @Test 6763d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu @MediumTest 6773d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu public void testDataCallOnUserDisableRoaming() throws Exception { 6783d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu //step 1: mock under roaming service and user disabled roaming from settings. 6793d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu //step 2: user toggled data settings on 6803d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu //step 3: only non-metered data call is established 6813d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 6823d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu boolean roamingEnabled = mDct.getDataOnRoamingEnabled(); 6833d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu boolean dataEnabled = mDct.getDataEnabled(); 6843d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 6853d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu //set Default and MMS to be metered in the CarrierConfigManager 6863d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mBundle.putStringArray(CarrierConfigManager.KEY_CARRIER_METERED_ROAMING_APN_TYPES_STRINGS, 6873d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu new String[]{PhoneConstants.APN_TYPE_DEFAULT, PhoneConstants.APN_TYPE_MMS}); 6883d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mDct.setEnabled(5, true); 6893d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mDct.setEnabled(0, true); 6903d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu doReturn(true).when(mServiceState).getDataRoaming(); 6913d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 6923d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu logd("Sending DISABLE_ROAMING_CMD"); 6933d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mDct.setDataOnRoamingEnabled(false); 6943d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 6953d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu logd("Sending EVENT_RECORDS_LOADED"); 6963d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_RECORDS_LOADED, null)); 6973d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu waitForMs(200); 6983d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 6993d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu logd("Sending EVENT_DATA_CONNECTION_ATTACHED"); 7003d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_DATA_CONNECTION_ATTACHED, null)); 7013d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu waitForMs(200); 7023d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 7033d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu logd("Sending DATA_ENABLED_CMD"); 7043d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu mDct.setDataEnabled(true); 7053d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 7063d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu waitForMs(200); 707f9339819516dbe67fb8fcef846a0ae4441ef17bdPaul Duffin ArgumentCaptor<DataProfile> dpCaptor = ArgumentCaptor.forClass(DataProfile.class); 7083d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu verify(mSimulatedCommandsVerifier, times(1)).setupDataCall( 7098e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(ServiceState.RIL_RADIO_TECHNOLOGY_UMTS), dpCaptor.capture(), 7108e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(false), eq(false), any(Message.class)); 7118e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verifyDataProfile(dpCaptor.getValue(), FAKE_APN3, 2, 64); 7123d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu 7133d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertEquals(DctConstants.State.CONNECTED, mDct.getOverallState()); 714783061ca03572618c01ce244d70d82fa4328d45ffionaxu assertEquals(DctConstants.State.IDLE, mDct.getState(PhoneConstants.APN_TYPE_DEFAULT)); 7153d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertEquals(DctConstants.State.CONNECTED, mDct.getState(PhoneConstants.APN_TYPE_IMS)); 716ecb75ffc91e7036ae87c5f0488fa871d4e079922Jack Yu 717ecb75ffc91e7036ae87c5f0488fa871d4e079922Jack Yu // reset roaming settings / data enabled settings at end of this test 718ecb75ffc91e7036ae87c5f0488fa871d4e079922Jack Yu mDct.setDataOnRoamingEnabled(roamingEnabled); 719ecb75ffc91e7036ae87c5f0488fa871d4e079922Jack Yu mDct.setDataEnabled(dataEnabled); 720ecb75ffc91e7036ae87c5f0488fa871d4e079922Jack Yu waitForMs(200); 721783061ca03572618c01ce244d70d82fa4328d45ffionaxu } 7220979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7230979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu // Test the default data switch scenario. 7240979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu @Test 7250979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu @MediumTest 7260979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu public void testDDSResetAutoAttach() throws Exception { 7270979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7280979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.setDataEnabled(true); 7290979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7300979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mContextFixture.putBooleanResource( 7310979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu com.android.internal.R.bool.config_auto_attach_data_on_creation, true); 7320979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7330979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mSimulatedCommands.setDataCallResponse(true, createDataCallResponse()); 7340979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7353d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu DataAllowFailReason failureReason = new DataAllowFailReason(); 7363d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu boolean allowed = isDataAllowed(failureReason); 7373d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertFalse(failureReason.getDataAllowFailReason(), allowed); 7380979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7390979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu ArgumentCaptor<Integer> intArgumentCaptor = ArgumentCaptor.forClass(Integer.class); 7400979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu verify(mUiccController, times(1)).registerForIccChanged(eq(mDct), 7410979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu intArgumentCaptor.capture(), eq(null)); 7420979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu // Ideally this should send EVENT_ICC_CHANGED. 7430979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.sendMessage(mDct.obtainMessage(intArgumentCaptor.getValue(), null)); 7440979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu waitForMs(100); 7450979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7460979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu verify(mSimRecords, times(1)).registerForRecordsLoaded(eq(mDct), 7470979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu intArgumentCaptor.capture(), eq(null)); 7480979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu // Ideally this should send EVENT_RECORDS_LOADED. 7490979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.sendMessage(mDct.obtainMessage(intArgumentCaptor.getValue(), null)); 7500979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu waitForMs(100); 7510979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7520979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu verify(mSST, times(1)).registerForDataConnectionAttached(eq(mDct), 7530979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu intArgumentCaptor.capture(), eq(null)); 7540979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu // Ideally this should send EVENT_DATA_CONNECTION_ATTACHED"); 7550979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.sendMessage(mDct.obtainMessage(intArgumentCaptor.getValue(), null)); 7560979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu waitForMs(200); 7570979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 75864fbcce906012e4b429c354ba3a200a6ee410010Lorenzo Colitti NetworkRequest nr = new NetworkRequest.Builder() 75964fbcce906012e4b429c354ba3a200a6ee410010Lorenzo Colitti .addCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET).build(); 7600979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu LocalLog l = new LocalLog(100); 7610979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.requestNetwork(nr, l); 7620979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu waitForMs(200); 7630979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7640979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu verifyDataConnected(FAKE_APN1); 7650979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7660979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu assertTrue(mDct.getAutoAttachOnCreation()); 7670979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.update(); 7680979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu // The auto attach flag should be reset after update 7690979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu assertFalse(mDct.getAutoAttachOnCreation()); 7700979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7710979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu verify(mSST, times(1)).registerForDataConnectionDetached(eq(mDct), 7720979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu intArgumentCaptor.capture(), eq(null)); 7730979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu // Ideally this should send EVENT_DATA_CONNECTION_DETACHED 7740979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu mDct.sendMessage(mDct.obtainMessage(intArgumentCaptor.getValue(), null)); 7750979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu waitForMs(200); 7760979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu 7770979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu // Data should not be allowed since auto attach flag has been reset. 7783d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu failureReason.clearAllReasons(); 7793d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu allowed = isDataAllowed(failureReason); 7803d8c0f70a6fa7a53fda3c5d592de0ac3aa247e3cfionaxu assertFalse(failureReason.getDataAllowFailReason(), allowed); 7810979b71e48405cab10bdf1d1b4170cfce72838a7Jack Yu } 7824c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 7834c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu // Test for API carrierActionSetMeteredApnsEnabled. 78492428df50d736a3d1d0f32779a22c65fcec0efabJordan Liu @FlakyTest 7854c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu @Test 7864c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu @MediumTest 7874c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu public void testCarrierActionSetMeteredApnsEnabled() throws Exception { 7884c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu //step 1: setup two DataCalls one for Internet and IMS 7894c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu //step 2: set data is enabled 7904c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu //step 3: cold sim is detected 7914c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu //step 4: all data connection is torn down 7924c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu mBundle.putStringArray(CarrierConfigManager.KEY_CARRIER_METERED_APN_TYPES_STRINGS, 7934c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu new String[]{PhoneConstants.APN_TYPE_DEFAULT, PhoneConstants.APN_TYPE_MMS}); 7944c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 7954c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu boolean dataEnabled = mDct.getDataEnabled(); 7964c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu mDct.setDataEnabled(true); 7974c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 7984c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu mDct.setEnabled(5, true); 7994c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu mDct.setEnabled(0, true); 8004c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 8014c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu logd("Sending EVENT_RECORDS_LOADED"); 8024c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_RECORDS_LOADED, null)); 8034c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu waitForMs(200); 8044c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 8054c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu logd("Sending EVENT_DATA_CONNECTION_ATTACHED"); 8064c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu mDct.sendMessage(mDct.obtainMessage(DctConstants.EVENT_DATA_CONNECTION_ATTACHED, null)); 8074c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu waitForMs(200); 8084c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 809f9339819516dbe67fb8fcef846a0ae4441ef17bdPaul Duffin ArgumentCaptor<DataProfile> dpCaptor = ArgumentCaptor.forClass(DataProfile.class); 8108e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verify(mSimulatedCommandsVerifier, times(2)).setupDataCall( 8118e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(ServiceState.RIL_RADIO_TECHNOLOGY_UMTS), dpCaptor.capture(), 8128e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu eq(false), eq(false), any(Message.class)); 8138e9d1e601dce62cd0328701d7054e03db24727c7Jack Yu verifyDataProfile(dpCaptor.getValue(), FAKE_APN1, 0, 5); 8144c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu assertEquals(DctConstants.State.CONNECTED, mDct.getOverallState()); 8154c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 81640cd4e909fd3a8ee462475814a949e08391ff8f5fionaxu Message msg = mDct.obtainMessage(DctConstants.EVENT_SET_CARRIER_DATA_ENABLED); 81740cd4e909fd3a8ee462475814a949e08391ff8f5fionaxu AsyncResult.forMessage(msg).result = false; 81840cd4e909fd3a8ee462475814a949e08391ff8f5fionaxu mDct.sendMessage(msg); 8196a7fb078d1cacba7cf2e83b71242bb5c4c27c975fionaxu 8204c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu waitForMs(100); 8214c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 8224c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu // Validate all metered data connections have been torn down 8234c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu verify(mSimulatedCommandsVerifier, times(1)).deactivateDataCall(anyInt(), anyInt(), 8244c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu any(Message.class)); 8254c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu assertEquals(DctConstants.State.CONNECTED, mDct.getOverallState()); 8264c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu assertEquals(DctConstants.State.IDLE, mDct.getState(PhoneConstants.APN_TYPE_DEFAULT)); 8274c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu 8284c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu // Reset settings at the end of test 8294c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu mDct.setDataEnabled(dataEnabled); 8304c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu waitForMs(200); 8314c31e4c0d2db31fe84081aa6f1e2bcc08b31f9d3fionaxu } 832783061ca03572618c01ce244d70d82fa4328d45ffionaxu} 833