Merge changes Iabad7300,I85363e28

* changes:
  Stubbed setOemNetworkPreference in Connectivity
  Update OemNetworkPreferences to use 1:1 Map
This commit is contained in:
James Mattis
2021-02-06 04:33:51 +00:00
committed by Gerrit Code Review
5 changed files with 138 additions and 52 deletions

View File

@@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2020 The Android Open Source Project * Copyright (C) 2021 The Android Open Source Project
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@@ -18,14 +18,14 @@ package android.net;
import android.annotation.IntDef; import android.annotation.IntDef;
import android.annotation.NonNull; import android.annotation.NonNull;
import android.os.Bundle;
import android.os.Parcelable; import android.os.Parcelable;
import android.util.SparseArray;
import java.lang.annotation.Retention; import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy; import java.lang.annotation.RetentionPolicy;
import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.HashMap;
import java.util.Map;
import java.util.Objects; import java.util.Objects;
/** @hide */ /** @hide */
@@ -60,16 +60,16 @@ public final class OemNetworkPreferences implements Parcelable {
public static final int OEM_NETWORK_PREFERENCE_OEM_PRIVATE_ONLY = 4; public static final int OEM_NETWORK_PREFERENCE_OEM_PRIVATE_ONLY = 4;
@NonNull @NonNull
private final SparseArray<List<String>> mNetworkMappings; private final Bundle mNetworkMappings;
@NonNull @NonNull
public SparseArray<List<String>> getNetworkPreferences() { public Map<String, Integer> getNetworkPreferences() {
return mNetworkMappings.clone(); return convertToUnmodifiableMap(mNetworkMappings);
} }
private OemNetworkPreferences(@NonNull SparseArray<List<String>> networkMappings) { private OemNetworkPreferences(@NonNull final Bundle networkMappings) {
Objects.requireNonNull(networkMappings); Objects.requireNonNull(networkMappings);
mNetworkMappings = networkMappings.clone(); mNetworkMappings = (Bundle) networkMappings.clone();
} }
@Override @Override
@@ -99,26 +99,45 @@ public final class OemNetworkPreferences implements Parcelable {
* @hide * @hide
*/ */
public static final class Builder { public static final class Builder {
private final SparseArray<List<String>> mNetworkMappings; private final Bundle mNetworkMappings;
public Builder() { public Builder() {
mNetworkMappings = new SparseArray<>(); mNetworkMappings = new Bundle();
}
public Builder(@NonNull final OemNetworkPreferences preferences) {
Objects.requireNonNull(preferences);
mNetworkMappings = (Bundle) preferences.mNetworkMappings.clone();
} }
/** /**
* Add a network preference for a list of packages. * Add a network preference for a given package. Previously stored values for the given
* package will be overwritten.
* *
* @param packageName full package name (e.g.: "com.google.apps.contacts") of the app
* to use the given preference
* @param preference the desired network preference to use * @param preference the desired network preference to use
* @param packages full package names (e.g.: "com.google.apps.contacts") for apps to use
* the given preference
* @return The builder to facilitate chaining. * @return The builder to facilitate chaining.
*/ */
@NonNull @NonNull
public Builder addNetworkPreference(@OemNetworkPreference final int preference, public Builder addNetworkPreference(@NonNull final String packageName,
@NonNull List<String> packages) { @OemNetworkPreference final int preference) {
Objects.requireNonNull(packages); Objects.requireNonNull(packageName);
mNetworkMappings.put(preference, mNetworkMappings.putInt(packageName, preference);
Collections.unmodifiableList(new ArrayList<>(packages))); return this;
}
/**
* Remove a network preference for a given package.
*
* @param packageName full package name (e.g.: "com.google.apps.contacts") of the app to
* remove a preference for.
* @return The builder to facilitate chaining.
*/
@NonNull
public Builder removeNetworkPreference(@NonNull final String packageName) {
Objects.requireNonNull(packageName);
mNetworkMappings.remove(packageName);
return this; return this;
} }
@@ -131,6 +150,14 @@ public final class OemNetworkPreferences implements Parcelable {
} }
} }
private static Map<String, Integer> convertToUnmodifiableMap(@NonNull final Bundle bundle) {
final Map<String, Integer> networkPreferences = new HashMap<>();
for (final String key : bundle.keySet()) {
networkPreferences.put(key, bundle.getInt(key));
}
return Collections.unmodifiableMap(networkPreferences);
}
/** @hide */ /** @hide */
@IntDef(prefix = "OEM_NETWORK_PREFERENCE_", value = { @IntDef(prefix = "OEM_NETWORK_PREFERENCE_", value = {
OEM_NETWORK_PREFERENCE_DEFAULT, OEM_NETWORK_PREFERENCE_DEFAULT,
@@ -168,7 +195,7 @@ public final class OemNetworkPreferences implements Parcelable {
@Override @Override
public void writeToParcel(@NonNull android.os.Parcel dest, int flags) { public void writeToParcel(@NonNull android.os.Parcel dest, int flags) {
dest.writeSparseArray(mNetworkMappings); dest.writeBundle(mNetworkMappings);
} }
@Override @Override
@@ -187,7 +214,7 @@ public final class OemNetworkPreferences implements Parcelable {
@Override @Override
public OemNetworkPreferences createFromParcel(@NonNull android.os.Parcel in) { public OemNetworkPreferences createFromParcel(@NonNull android.os.Parcel in) {
return new OemNetworkPreferences( return new OemNetworkPreferences(
in.readSparseArray(getClass().getClassLoader())); in.readBundle(getClass().getClassLoader()));
} }
}; };
} }

View File

@@ -4845,9 +4845,13 @@ public class ConnectivityManager {
} }
} }
private void setOemNetworkPreference(@NonNull OemNetworkPreferences preference) { private void setOemNetworkPreference(@NonNull final OemNetworkPreferences preference) {
Log.d(TAG, "setOemNetworkPreference called with preference: " try {
+ preference.toString()); mService.setOemNetworkPreference(preference);
} catch (RemoteException e) {
Log.e(TAG, "setOemNetworkPreference() failed for preference: " + preference.toString());
throw e.rethrowFromSystemServer();
}
} }
@NonNull @NonNull

View File

@@ -29,6 +29,7 @@ import android.net.NetworkCapabilities;
import android.net.NetworkInfo; import android.net.NetworkInfo;
import android.net.NetworkRequest; import android.net.NetworkRequest;
import android.net.NetworkState; import android.net.NetworkState;
import android.net.OemNetworkPreferences;
import android.net.ProxyInfo; import android.net.ProxyInfo;
import android.net.UidRange; import android.net.UidRange;
import android.net.QosSocketInfo; import android.net.QosSocketInfo;
@@ -240,4 +241,6 @@ interface IConnectivityManager
void registerQosSocketCallback(in QosSocketInfo socketInfo, in IQosCallback callback); void registerQosSocketCallback(in QosSocketInfo socketInfo, in IQosCallback callback);
void unregisterQosCallback(in IQosCallback callback); void unregisterQosCallback(in IQosCallback callback);
void setOemNetworkPreference(in OemNetworkPreferences preference);
} }

View File

@@ -120,6 +120,7 @@ import android.net.NetworkState;
import android.net.NetworkTestResultParcelable; import android.net.NetworkTestResultParcelable;
import android.net.NetworkUtils; import android.net.NetworkUtils;
import android.net.NetworkWatchlistManager; import android.net.NetworkWatchlistManager;
import android.net.OemNetworkPreferences;
import android.net.PrivateDnsConfigParcel; import android.net.PrivateDnsConfigParcel;
import android.net.ProxyInfo; import android.net.ProxyInfo;
import android.net.QosCallbackException; import android.net.QosCallbackException;
@@ -9100,6 +9101,7 @@ public class ConnectivityService extends IConnectivityManager.Stub
} }
} }
} }
/** /**
* Registers {@link QosSocketFilter} with {@link IQosCallback}. * Registers {@link QosSocketFilter} with {@link IQosCallback}.
* *
@@ -9149,4 +9151,10 @@ public class ConnectivityService extends IConnectivityManager.Stub
public void unregisterQosCallback(@NonNull final IQosCallback callback) { public void unregisterQosCallback(@NonNull final IQosCallback callback) {
mQosCallbackTracker.unregisterCallback(callback); mQosCallbackTracker.unregisterCallback(callback);
} }
@Override
public void setOemNetworkPreference(@NonNull final OemNetworkPreferences preference) {
// TODO http://b/176495594 track multiple default networks with networkPreferences
if (DBG) log("setOemNetworkPreference() called with: " + preference.toString());
}
} }

View File

@@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2020 The Android Open Source Project * Copyright (C) 2021 The Android Open Source Project
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@@ -20,22 +20,20 @@ import static com.android.testutils.MiscAsserts.assertThrows;
import static com.android.testutils.ParcelUtils.assertParcelSane; import static com.android.testutils.ParcelUtils.assertParcelSane;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import android.os.Build; import android.os.Build;
import android.util.SparseArray;
import androidx.test.filters.SmallTest; import androidx.test.filters.SmallTest;
import com.android.testutils.DevSdkIgnoreRule.IgnoreUpTo; import com.android.testutils.DevSdkIgnoreRule.IgnoreUpTo;
import com.android.testutils.DevSdkIgnoreRunner; import com.android.testutils.DevSdkIgnoreRunner;
import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import java.util.ArrayList; import java.util.Map;
import java.util.List;
@IgnoreUpTo(Build.VERSION_CODES.R) @IgnoreUpTo(Build.VERSION_CODES.R)
@RunWith(DevSdkIgnoreRunner.class) @RunWith(DevSdkIgnoreRunner.class)
@@ -45,51 +43,51 @@ public class OemNetworkPreferencesTest {
private static final int TEST_PREF = OemNetworkPreferences.OEM_NETWORK_PREFERENCE_DEFAULT; private static final int TEST_PREF = OemNetworkPreferences.OEM_NETWORK_PREFERENCE_DEFAULT;
private static final String TEST_PACKAGE = "com.google.apps.contacts"; private static final String TEST_PACKAGE = "com.google.apps.contacts";
private final List<String> mPackages = new ArrayList<>();
private final OemNetworkPreferences.Builder mBuilder = new OemNetworkPreferences.Builder(); private final OemNetworkPreferences.Builder mBuilder = new OemNetworkPreferences.Builder();
@Before
public void beforeEachTestMethod() {
mPackages.add(TEST_PACKAGE);
}
@Test @Test
public void builderAddNetworkPreferenceRequiresNonNullPackages() { public void testBuilderAddNetworkPreferenceRequiresNonNullPackageName() {
assertThrows(NullPointerException.class, assertThrows(NullPointerException.class,
() -> mBuilder.addNetworkPreference(TEST_PREF, null)); () -> mBuilder.addNetworkPreference(null, TEST_PREF));
} }
@Test @Test
public void getNetworkPreferencesReturnsCorrectValue() { public void testBuilderRemoveNetworkPreferenceRequiresNonNullPackageName() {
final int expectedNumberOfMappings = 1; assertThrows(NullPointerException.class,
mBuilder.addNetworkPreference(TEST_PREF, mPackages); () -> mBuilder.removeNetworkPreference(null));
}
final SparseArray<List<String>> networkPreferences = @Test
public void testGetNetworkPreferenceReturnsCorrectValue() {
final int expectedNumberOfMappings = 1;
mBuilder.addNetworkPreference(TEST_PACKAGE, TEST_PREF);
final Map<String, Integer> networkPreferences =
mBuilder.build().getNetworkPreferences(); mBuilder.build().getNetworkPreferences();
assertEquals(expectedNumberOfMappings, networkPreferences.size()); assertEquals(expectedNumberOfMappings, networkPreferences.size());
assertEquals(mPackages.size(), networkPreferences.get(TEST_PREF).size()); assertTrue(networkPreferences.containsKey(TEST_PACKAGE));
assertEquals(mPackages.get(0), networkPreferences.get(TEST_PREF).get(0));
} }
@Test @Test
public void getNetworkPreferencesReturnsUnmodifiableValue() { public void testGetNetworkPreferenceReturnsUnmodifiableValue() {
final String newPackage = "new.com.google.apps.contacts"; final String newPackage = "new.com.google.apps.contacts";
mBuilder.addNetworkPreference(TEST_PREF, mPackages); mBuilder.addNetworkPreference(TEST_PACKAGE, TEST_PREF);
final SparseArray<List<String>> networkPreferences = final Map<String, Integer> networkPreferences =
mBuilder.build().getNetworkPreferences(); mBuilder.build().getNetworkPreferences();
assertThrows(UnsupportedOperationException.class, assertThrows(UnsupportedOperationException.class,
() -> networkPreferences.get(TEST_PREF).set(mPackages.size() - 1, newPackage)); () -> networkPreferences.put(newPackage, TEST_PREF));
assertThrows(UnsupportedOperationException.class, assertThrows(UnsupportedOperationException.class,
() -> networkPreferences.get(TEST_PREF).add(newPackage)); () -> networkPreferences.remove(TEST_PACKAGE));
} }
@Test @Test
public void toStringReturnsCorrectValue() { public void testToStringReturnsCorrectValue() {
mBuilder.addNetworkPreference(TEST_PREF, mPackages); mBuilder.addNetworkPreference(TEST_PACKAGE, TEST_PREF);
final String networkPreferencesString = mBuilder.build().getNetworkPreferences().toString(); final String networkPreferencesString = mBuilder.build().getNetworkPreferences().toString();
@@ -99,10 +97,56 @@ public class OemNetworkPreferencesTest {
@Test @Test
public void testOemNetworkPreferencesParcelable() { public void testOemNetworkPreferencesParcelable() {
mBuilder.addNetworkPreference(TEST_PREF, mPackages); mBuilder.addNetworkPreference(TEST_PACKAGE, TEST_PREF);
final OemNetworkPreferences prefs = mBuilder.build(); final OemNetworkPreferences prefs = mBuilder.build();
assertParcelSane(prefs, 1 /* fieldCount */); assertParcelSane(prefs, 1 /* fieldCount */);
} }
@Test
public void testAddNetworkPreferenceOverwritesPriorPreference() {
final int newPref = OemNetworkPreferences.OEM_NETWORK_PREFERENCE_OEM_PAID;
mBuilder.addNetworkPreference(TEST_PACKAGE, TEST_PREF);
Map<String, Integer> networkPreferences =
mBuilder.build().getNetworkPreferences();
assertTrue(networkPreferences.containsKey(TEST_PACKAGE));
assertEquals(networkPreferences.get(TEST_PACKAGE).intValue(), TEST_PREF);
mBuilder.addNetworkPreference(TEST_PACKAGE, newPref);
networkPreferences = mBuilder.build().getNetworkPreferences();
assertTrue(networkPreferences.containsKey(TEST_PACKAGE));
assertEquals(networkPreferences.get(TEST_PACKAGE).intValue(), newPref);
}
@Test
public void testRemoveNetworkPreferenceRemovesValue() {
mBuilder.addNetworkPreference(TEST_PACKAGE, TEST_PREF);
Map<String, Integer> networkPreferences =
mBuilder.build().getNetworkPreferences();
assertTrue(networkPreferences.containsKey(TEST_PACKAGE));
mBuilder.removeNetworkPreference(TEST_PACKAGE);
networkPreferences = mBuilder.build().getNetworkPreferences();
assertFalse(networkPreferences.containsKey(TEST_PACKAGE));
}
@Test
public void testConstructorByOemNetworkPreferencesSetsValue() {
mBuilder.addNetworkPreference(TEST_PACKAGE, TEST_PREF);
OemNetworkPreferences networkPreference = mBuilder.build();
final Map<String, Integer> networkPreferences =
new OemNetworkPreferences
.Builder(networkPreference)
.build()
.getNetworkPreferences();
assertTrue(networkPreferences.containsKey(TEST_PACKAGE));
assertEquals(networkPreferences.get(TEST_PACKAGE).intValue(), TEST_PREF);
}
} }