Merge "[Settings] Enable support on testing"
This commit is contained in:
@@ -60,9 +60,12 @@ android_robolectric_test {
|
||||
static_libs: [
|
||||
"SettingsLib-robo-testutils",
|
||||
"android-support-annotations",
|
||||
"androidx.test.core",
|
||||
"androidx.test.runner",
|
||||
"androidx.test.ext.junit",
|
||||
],
|
||||
|
||||
java_resource_dirs: ["config"],
|
||||
java_resource_dirs: ["config", "resources"],
|
||||
|
||||
instrumentation_for: "SettingsRoboTestStub",
|
||||
|
||||
|
@@ -1,3 +1,4 @@
|
||||
sdk=NEWEST_SDK
|
||||
shadows=\
|
||||
com.android.settings.testutils.shadow.ShadowThreadUtils
|
||||
com.android.settings.testutils.shadow.ShadowThreadUtils \
|
||||
com.android.settings.network.ShadowServiceManagerExtend
|
||||
|
@@ -0,0 +1 @@
|
||||
org.robolectric.android.internal.NoOpThreadChecker
|
@@ -0,0 +1 @@
|
||||
org.robolectric.android.internal.LocalActivityInvoker
|
@@ -0,0 +1 @@
|
||||
org.robolectric.android.internal.LocalPermissionGranter
|
@@ -0,0 +1 @@
|
||||
org.robolectric.android.internal.LocalControlledLooper
|
@@ -0,0 +1 @@
|
||||
org.robolectric.android.internal.LocalUiController
|
@@ -0,0 +1,53 @@
|
||||
/*
|
||||
* Copyright (C) 2019 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.settings.network;
|
||||
|
||||
import android.os.Binder;
|
||||
import android.os.IBinder;
|
||||
import android.os.IInterface;
|
||||
import android.os.ServiceManager;
|
||||
|
||||
import org.robolectric.annotation.Implementation;
|
||||
import org.robolectric.annotation.Implements;
|
||||
import org.robolectric.shadows.ShadowServiceManager;
|
||||
import org.robolectric.util.ReflectionHelpers;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
@Implements(value = ServiceManager.class)
|
||||
public class ShadowServiceManagerExtend extends ShadowServiceManager {
|
||||
private static final Map<String, IBinder> EXTRA_SERVICES = new HashMap<>();
|
||||
|
||||
@Implementation
|
||||
public static IBinder getService(String name) {
|
||||
final IBinder iBinder = ShadowServiceManager.getService(name);
|
||||
if (iBinder == null) {
|
||||
return EXTRA_SERVICES.get(name);
|
||||
}
|
||||
return iBinder;
|
||||
}
|
||||
|
||||
public static void addService(String name, Class<? extends IInterface> classService,
|
||||
String fullNameClass) {
|
||||
final Binder service = new Binder();
|
||||
service.attachInterface(ReflectionHelpers.createNullProxy(classService), fullNameClass);
|
||||
|
||||
ShadowServiceManager.addService(name, service);
|
||||
EXTRA_SERVICES.put(name, service);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user