Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2019 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 | |
| 17 | package com.android; |
| 18 | |
| 19 | import static org.mockito.ArgumentMatchers.anyInt; |
Brad Ebinger | 6c53e7f | 2023-01-27 16:26:44 -0800 | [diff] [blame] | 20 | import static org.mockito.ArgumentMatchers.anyString; |
Brad Ebinger | 9c5578a | 2020-09-23 17:03:48 -0700 | [diff] [blame] | 21 | import static org.mockito.Mockito.doAnswer; |
Tomasz Wasilczyk | d78e870 | 2024-03-14 11:11:46 -0700 | [diff] [blame] | 22 | import static org.mockito.Mockito.when; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 23 | |
Tomasz Wasilczyk | f7b28c5 | 2024-11-11 15:55:27 -0800 | [diff] [blame^] | 24 | import android.annotation.NonNull; |
| 25 | import android.annotation.Nullable; |
Rafael Higuera Silva | 0b1ccf6 | 2022-02-11 17:58:27 +0000 | [diff] [blame] | 26 | import android.content.AttributionSource; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 27 | import android.content.BroadcastReceiver; |
James.cf Lin | cdad386 | 2020-02-25 15:55:03 +0800 | [diff] [blame] | 28 | import android.content.ContentResolver; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 29 | import android.content.Context; |
| 30 | import android.content.Intent; |
| 31 | import android.content.IntentFilter; |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 32 | import android.content.pm.PackageManager; |
Tomasz Wasilczyk | f7b28c5 | 2024-11-11 15:55:27 -0800 | [diff] [blame^] | 33 | import android.content.res.AssetManager; |
| 34 | import android.content.res.Resources; |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 35 | import android.os.Binder; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 36 | import android.os.Handler; |
Hall Liu | 12feea2 | 2021-03-22 15:37:41 -0700 | [diff] [blame] | 37 | import android.os.Looper; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 38 | import android.os.PersistableBundle; |
Rafael Higuera Silva | 0b1ccf6 | 2022-02-11 17:58:27 +0000 | [diff] [blame] | 39 | import android.os.Process; |
Jack Yu | 58d04bd | 2024-09-10 17:32:39 -0700 | [diff] [blame] | 40 | import android.os.UserHandle; |
Gil Cukierman | 6dac5eb | 2022-09-19 16:09:04 +0000 | [diff] [blame] | 41 | import android.os.UserManager; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 42 | import android.telecom.TelecomManager; |
| 43 | import android.telephony.CarrierConfigManager; |
| 44 | import android.telephony.SubscriptionManager; |
| 45 | import android.telephony.TelephonyManager; |
James.cf Lin | cdad386 | 2020-02-25 15:55:03 +0800 | [diff] [blame] | 46 | import android.telephony.ims.ImsManager; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 47 | import android.test.mock.MockContext; |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 48 | import android.util.Log; |
Brad Ebinger | 9c5578a | 2020-09-23 17:03:48 -0700 | [diff] [blame] | 49 | import android.util.SparseArray; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 50 | |
Tomasz Wasilczyk | f7b28c5 | 2024-11-11 15:55:27 -0800 | [diff] [blame^] | 51 | import androidx.test.InstrumentationRegistry; |
| 52 | |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 53 | import org.mockito.Mock; |
Tomasz Wasilczyk | f7b28c5 | 2024-11-11 15:55:27 -0800 | [diff] [blame^] | 54 | import org.mockito.Mockito; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 55 | import org.mockito.MockitoAnnotations; |
Brad Ebinger | 9c5578a | 2020-09-23 17:03:48 -0700 | [diff] [blame] | 56 | import org.mockito.stubbing.Answer; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 57 | |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 58 | import java.util.HashSet; |
Brad Ebinger | a68a497 | 2020-01-30 17:31:23 -0800 | [diff] [blame] | 59 | import java.util.concurrent.Executor; |
| 60 | |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 61 | public class TestContext extends MockContext { |
| 62 | |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 63 | private static final String TAG = "TestContext"; |
| 64 | // Stub used to grant all permissions |
| 65 | public static final String STUB_PERMISSION_ENABLE_ALL = "stub_permission_enable_all"; |
| 66 | |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 67 | @Mock CarrierConfigManager mMockCarrierConfigManager; |
| 68 | @Mock TelecomManager mMockTelecomManager; |
| 69 | @Mock TelephonyManager mMockTelephonyManager; |
| 70 | @Mock SubscriptionManager mMockSubscriptionManager; |
James.cf Lin | cdad386 | 2020-02-25 15:55:03 +0800 | [diff] [blame] | 71 | @Mock ImsManager mMockImsManager; |
Gil Cukierman | 6dac5eb | 2022-09-19 16:09:04 +0000 | [diff] [blame] | 72 | @Mock UserManager mMockUserManager; |
Tomasz Wasilczyk | d78e870 | 2024-03-14 11:11:46 -0700 | [diff] [blame] | 73 | @Mock PackageManager mPackageManager; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 74 | |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 75 | private final SparseArray<PersistableBundle> mCarrierConfigs = new SparseArray<>(); |
| 76 | |
| 77 | private Intent mIntent; |
| 78 | |
| 79 | private BroadcastReceiver mReceiver; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 80 | |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 81 | private final HashSet<String> mPermissionTable = new HashSet<>(); |
| 82 | |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 83 | public TestContext() { |
| 84 | MockitoAnnotations.initMocks(this); |
Brad Ebinger | 9c5578a | 2020-09-23 17:03:48 -0700 | [diff] [blame] | 85 | doAnswer((Answer<PersistableBundle>) invocation -> { |
| 86 | int subId = (int) invocation.getArguments()[0]; |
Brad Ebinger | 6c53e7f | 2023-01-27 16:26:44 -0800 | [diff] [blame] | 87 | return getTestConfigs(subId); |
Brad Ebinger | 9c5578a | 2020-09-23 17:03:48 -0700 | [diff] [blame] | 88 | }).when(mMockCarrierConfigManager).getConfigForSubId(anyInt()); |
Brad Ebinger | 6c53e7f | 2023-01-27 16:26:44 -0800 | [diff] [blame] | 89 | doAnswer((Answer<PersistableBundle>) invocation -> { |
| 90 | int subId = (int) invocation.getArguments()[0]; |
| 91 | return getTestConfigs(subId); |
| 92 | }).when(mMockCarrierConfigManager).getConfigForSubId(anyInt(), anyString()); |
Tomasz Wasilczyk | d78e870 | 2024-03-14 11:11:46 -0700 | [diff] [blame] | 93 | when(mPackageManager.hasSystemFeature(anyString())).thenReturn(true); |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 94 | } |
| 95 | |
| 96 | @Override |
Tomasz Wasilczyk | f7b28c5 | 2024-11-11 15:55:27 -0800 | [diff] [blame^] | 97 | public AssetManager getAssets() { |
| 98 | return Mockito.mock(AssetManager.class); |
| 99 | } |
| 100 | |
| 101 | @Override |
Brad Ebinger | a68a497 | 2020-01-30 17:31:23 -0800 | [diff] [blame] | 102 | public Executor getMainExecutor() { |
| 103 | // Just run on current thread |
| 104 | return Runnable::run; |
| 105 | } |
| 106 | |
| 107 | @Override |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 108 | public Context getApplicationContext() { |
| 109 | return this; |
| 110 | } |
| 111 | |
| 112 | @Override |
Tomasz Wasilczyk | f7b28c5 | 2024-11-11 15:55:27 -0800 | [diff] [blame^] | 113 | public @NonNull Context createAttributionContext(@Nullable String attributionTag) { |
| 114 | return this; |
| 115 | } |
| 116 | |
| 117 | @Override |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 118 | public String getPackageName() { |
| 119 | return "com.android.phone.tests"; |
| 120 | } |
| 121 | |
| 122 | @Override |
Tomasz Wasilczyk | 33c4452 | 2024-11-07 21:18:16 -0800 | [diff] [blame] | 123 | public String getOpPackageName() { |
| 124 | return getPackageName(); |
| 125 | } |
| 126 | |
| 127 | @Override |
Philip P. Moltmann | 8d34f0c | 2020-03-05 16:24:02 -0800 | [diff] [blame] | 128 | public String getAttributionTag() { |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 129 | return ""; |
| 130 | } |
| 131 | |
| 132 | @Override |
Rafael Higuera Silva | 0b1ccf6 | 2022-02-11 17:58:27 +0000 | [diff] [blame] | 133 | public AttributionSource getAttributionSource() { |
| 134 | return new AttributionSource(Process.myUid(), getPackageName(), ""); |
| 135 | } |
| 136 | |
| 137 | @Override |
Jack Yu | 58d04bd | 2024-09-10 17:32:39 -0700 | [diff] [blame] | 138 | public void startActivityAsUser(Intent intent, UserHandle user) { |
| 139 | throw new UnsupportedOperationException(); |
| 140 | } |
| 141 | |
| 142 | @Override |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 143 | public void sendBroadcast(Intent intent) { |
| 144 | mIntent = intent; |
| 145 | } |
| 146 | |
| 147 | @Override |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 148 | public Intent registerReceiver(BroadcastReceiver receiver, IntentFilter filter) { |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 149 | mReceiver = receiver; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 150 | return null; |
| 151 | } |
| 152 | |
| 153 | @Override |
| 154 | public Intent registerReceiver(BroadcastReceiver receiver, IntentFilter filter, int flags) { |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 155 | mReceiver = receiver; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 156 | return null; |
| 157 | } |
| 158 | |
| 159 | @Override |
| 160 | public Intent registerReceiver(BroadcastReceiver receiver, IntentFilter filter, |
| 161 | String broadcastPermission, Handler scheduler) { |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 162 | mReceiver = receiver; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 163 | return null; |
| 164 | } |
| 165 | |
| 166 | @Override |
| 167 | public Intent registerReceiver(BroadcastReceiver receiver, IntentFilter filter, |
| 168 | String broadcastPermission, Handler scheduler, int flags) { |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 169 | mReceiver = receiver; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 170 | return null; |
| 171 | } |
| 172 | |
| 173 | @Override |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 174 | public void unregisterReceiver(BroadcastReceiver receiver) { |
| 175 | mReceiver = null; |
| 176 | } |
| 177 | |
| 178 | @Override |
Tomasz Wasilczyk | d78e870 | 2024-03-14 11:11:46 -0700 | [diff] [blame] | 179 | public PackageManager getPackageManager() { |
| 180 | return mPackageManager; |
| 181 | } |
| 182 | |
| 183 | @Override |
James.cf Lin | cdad386 | 2020-02-25 15:55:03 +0800 | [diff] [blame] | 184 | public ContentResolver getContentResolver() { |
| 185 | return null; |
| 186 | } |
| 187 | |
| 188 | @Override |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 189 | public Object getSystemService(String name) { |
| 190 | switch (name) { |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 191 | case Context.CARRIER_CONFIG_SERVICE: { |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 192 | return mMockCarrierConfigManager; |
| 193 | } |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 194 | case Context.TELECOM_SERVICE: { |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 195 | return mMockTelecomManager; |
| 196 | } |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 197 | case Context.TELEPHONY_SERVICE: { |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 198 | return mMockTelephonyManager; |
| 199 | } |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 200 | case Context.TELEPHONY_SUBSCRIPTION_SERVICE: { |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 201 | return mMockSubscriptionManager; |
| 202 | } |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 203 | case Context.TELEPHONY_IMS_SERVICE: { |
James.cf Lin | cdad386 | 2020-02-25 15:55:03 +0800 | [diff] [blame] | 204 | return mMockImsManager; |
| 205 | } |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 206 | case Context.USER_SERVICE: { |
Gil Cukierman | 6dac5eb | 2022-09-19 16:09:04 +0000 | [diff] [blame] | 207 | return mMockUserManager; |
| 208 | } |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 209 | } |
| 210 | return null; |
| 211 | } |
| 212 | |
| 213 | @Override |
| 214 | public String getSystemServiceName(Class<?> serviceClass) { |
| 215 | if (serviceClass == CarrierConfigManager.class) { |
| 216 | return Context.CARRIER_CONFIG_SERVICE; |
| 217 | } |
| 218 | if (serviceClass == TelecomManager.class) { |
| 219 | return Context.TELECOM_SERVICE; |
| 220 | } |
| 221 | if (serviceClass == TelephonyManager.class) { |
| 222 | return Context.TELEPHONY_SERVICE; |
| 223 | } |
| 224 | if (serviceClass == SubscriptionManager.class) { |
| 225 | return Context.TELEPHONY_SUBSCRIPTION_SERVICE; |
| 226 | } |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 227 | if (serviceClass == ImsManager.class) { |
| 228 | return Context.TELEPHONY_IMS_SERVICE; |
| 229 | } |
Gil Cukierman | 6dac5eb | 2022-09-19 16:09:04 +0000 | [diff] [blame] | 230 | if (serviceClass == UserManager.class) { |
| 231 | return Context.USER_SERVICE; |
| 232 | } |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 233 | return null; |
| 234 | } |
| 235 | |
Hall Liu | 12feea2 | 2021-03-22 15:37:41 -0700 | [diff] [blame] | 236 | @Override |
Tomasz Wasilczyk | 310544d | 2024-10-24 14:08:18 -0700 | [diff] [blame] | 237 | public Looper getMainLooper() { |
| 238 | return Looper.getMainLooper(); |
| 239 | } |
| 240 | |
| 241 | @Override |
Hall Liu | 12feea2 | 2021-03-22 15:37:41 -0700 | [diff] [blame] | 242 | public Handler getMainThreadHandler() { |
| 243 | return new Handler(Looper.getMainLooper()); |
| 244 | } |
| 245 | |
Tomasz Wasilczyk | f7b28c5 | 2024-11-11 15:55:27 -0800 | [diff] [blame^] | 246 | @Override |
| 247 | public Resources.Theme getTheme() { |
| 248 | return InstrumentationRegistry.getTargetContext().getTheme(); |
| 249 | } |
| 250 | |
Brad Ebinger | 9c5578a | 2020-09-23 17:03:48 -0700 | [diff] [blame] | 251 | /** |
| 252 | * @return CarrierConfig PersistableBundle for the subscription specified. |
| 253 | */ |
| 254 | public PersistableBundle getCarrierConfig(int subId) { |
| 255 | PersistableBundle b = mCarrierConfigs.get(subId); |
| 256 | if (b == null) { |
| 257 | b = new PersistableBundle(); |
| 258 | mCarrierConfigs.put(subId, b); |
| 259 | } |
| 260 | return b; |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 261 | } |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 262 | |
| 263 | @Override |
| 264 | public void enforceCallingOrSelfPermission(String permission, String message) { |
| 265 | if (checkCallingOrSelfPermission(permission) != PackageManager.PERMISSION_GRANTED) { |
| 266 | throw new SecurityException(permission + " denied: " + message); |
| 267 | } |
| 268 | } |
| 269 | |
| 270 | @Override |
| 271 | public void enforcePermission(String permission, int pid, int uid, String message) { |
| 272 | enforceCallingOrSelfPermission(permission, message); |
| 273 | } |
| 274 | |
| 275 | @Override |
| 276 | public void enforceCallingPermission(String permission, String message) { |
| 277 | enforceCallingOrSelfPermission(permission, message); |
| 278 | } |
| 279 | |
| 280 | @Override |
| 281 | public int checkCallingOrSelfPermission(String permission) { |
| 282 | return checkPermission(permission, Binder.getCallingPid(), Binder.getCallingUid()); |
| 283 | } |
| 284 | |
| 285 | @Override |
| 286 | public int checkPermission(String permission, int pid, int uid) { |
| 287 | synchronized (mPermissionTable) { |
| 288 | if (mPermissionTable.contains(permission) |
| 289 | || mPermissionTable.contains(STUB_PERMISSION_ENABLE_ALL)) { |
| 290 | logd("checkCallingOrSelfPermission: " + permission + " return GRANTED"); |
| 291 | return PackageManager.PERMISSION_GRANTED; |
| 292 | } else { |
| 293 | logd("checkCallingOrSelfPermission: " + permission + " return DENIED"); |
| 294 | return PackageManager.PERMISSION_DENIED; |
| 295 | } |
| 296 | } |
| 297 | } |
| 298 | |
| 299 | public void grantPermission(String permission) { |
| 300 | synchronized (mPermissionTable) { |
Brad Ebinger | 6c53e7f | 2023-01-27 16:26:44 -0800 | [diff] [blame] | 301 | if (permission == null) return; |
| 302 | mPermissionTable.remove(STUB_PERMISSION_ENABLE_ALL); |
| 303 | mPermissionTable.add(permission); |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 304 | } |
| 305 | } |
| 306 | |
| 307 | public void revokePermission(String permission) { |
| 308 | synchronized (mPermissionTable) { |
Brad Ebinger | 6c53e7f | 2023-01-27 16:26:44 -0800 | [diff] [blame] | 309 | if (permission == null) return; |
| 310 | mPermissionTable.remove(permission); |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 311 | } |
| 312 | } |
| 313 | |
| 314 | public void revokeAllPermissions() { |
| 315 | synchronized (mPermissionTable) { |
| 316 | mPermissionTable.clear(); |
| 317 | } |
| 318 | } |
| 319 | |
Sarah Chin | 7146248 | 2022-11-18 02:25:25 -0800 | [diff] [blame] | 320 | public Intent getBroadcast() { |
| 321 | return mIntent; |
| 322 | } |
| 323 | |
| 324 | public BroadcastReceiver getBroadcastReceiver() { |
| 325 | return mReceiver; |
| 326 | } |
| 327 | |
Brad Ebinger | 6c53e7f | 2023-01-27 16:26:44 -0800 | [diff] [blame] | 328 | private PersistableBundle getTestConfigs(int subId) { |
| 329 | if (subId < 0) { |
| 330 | return new PersistableBundle(); |
| 331 | } |
| 332 | PersistableBundle b = getCarrierConfig(subId); |
| 333 | return (b != null ? b : new PersistableBundle()); |
| 334 | } |
| 335 | |
Rambo Wang | 7e3bc12 | 2021-03-23 09:24:38 -0700 | [diff] [blame] | 336 | private static void logd(String s) { |
| 337 | Log.d(TAG, s); |
| 338 | } |
Brad Ebinger | dc555b4 | 2019-12-09 16:12:57 -0800 | [diff] [blame] | 339 | } |