Merge "Get app label by launched package" into tm-dev am: bbeed14835
Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/18321386 Change-Id: I3c533a466dcf9ed92774bc8a74f217a05015049d Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
@@ -20,26 +20,30 @@ import android.app.Dialog;
|
|||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.ApplicationInfo;
|
|
||||||
import android.content.pm.PackageManager;
|
|
||||||
import android.net.wifi.WifiManager;
|
import android.net.wifi.WifiManager;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.view.WindowManager;
|
import android.view.WindowManager;
|
||||||
|
|
||||||
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.appcompat.app.AlertDialog;
|
import androidx.appcompat.app.AlertDialog;
|
||||||
import androidx.fragment.app.DialogFragment;
|
import androidx.fragment.app.DialogFragment;
|
||||||
import androidx.fragment.app.FragmentActivity;
|
import androidx.fragment.app.FragmentActivity;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.core.instrumentation.InstrumentedDialogFragment;
|
import com.android.settings.core.instrumentation.InstrumentedDialogFragment;
|
||||||
|
import com.android.settingslib.wifi.WifiPermissionChecker;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This activity requests users permission to allow scanning even when Wi-Fi is turned off
|
* This activity requests users permission to allow scanning even when Wi-Fi is turned off
|
||||||
*/
|
*/
|
||||||
public class WifiScanModeActivity extends FragmentActivity {
|
public class WifiScanModeActivity extends FragmentActivity {
|
||||||
private DialogFragment mDialog;
|
private DialogFragment mDialog;
|
||||||
private String mApp;
|
@VisibleForTesting
|
||||||
|
String mApp;
|
||||||
|
@VisibleForTesting
|
||||||
|
WifiPermissionChecker mWifiPermissionChecker;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
@@ -50,13 +54,7 @@ public class WifiScanModeActivity extends FragmentActivity {
|
|||||||
if (savedInstanceState == null) {
|
if (savedInstanceState == null) {
|
||||||
if (intent != null && WifiManager.ACTION_REQUEST_SCAN_ALWAYS_AVAILABLE
|
if (intent != null && WifiManager.ACTION_REQUEST_SCAN_ALWAYS_AVAILABLE
|
||||||
.equals(intent.getAction())) {
|
.equals(intent.getAction())) {
|
||||||
ApplicationInfo ai;
|
refreshAppLabel();
|
||||||
mApp = getCallingPackage();
|
|
||||||
try {
|
|
||||||
PackageManager pm = getPackageManager();
|
|
||||||
ai = pm.getApplicationInfo(mApp, 0);
|
|
||||||
mApp = (String)pm.getApplicationLabel(ai);
|
|
||||||
} catch (PackageManager.NameNotFoundException e) { }
|
|
||||||
} else {
|
} else {
|
||||||
finish();
|
finish();
|
||||||
return;
|
return;
|
||||||
@@ -67,6 +65,19 @@ public class WifiScanModeActivity extends FragmentActivity {
|
|||||||
createDialog();
|
createDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
void refreshAppLabel() {
|
||||||
|
if (mWifiPermissionChecker == null) {
|
||||||
|
mWifiPermissionChecker = new WifiPermissionChecker(this);
|
||||||
|
}
|
||||||
|
String packageName = mWifiPermissionChecker.getLaunchedPackage();
|
||||||
|
if (TextUtils.isEmpty(packageName)) {
|
||||||
|
mApp = null;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
mApp = Utils.getApplicationLabel(getApplicationContext(), packageName).toString();
|
||||||
|
}
|
||||||
|
|
||||||
private void createDialog() {
|
private void createDialog() {
|
||||||
if (mDialog == null) {
|
if (mDialog == null) {
|
||||||
mDialog = AlertDialogFragment.newInstance(mApp);
|
mDialog = AlertDialogFragment.newInstance(mApp);
|
||||||
|
@@ -16,16 +16,75 @@
|
|||||||
|
|
||||||
package com.android.settings.wifi;
|
package com.android.settings.wifi;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
|
import com.android.settings.testutils.shadow.ShadowUtils;
|
||||||
|
import com.android.settingslib.wifi.WifiPermissionChecker;
|
||||||
|
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.junit.MockitoJUnit;
|
||||||
|
import org.mockito.junit.MockitoRule;
|
||||||
import org.robolectric.Robolectric;
|
import org.robolectric.Robolectric;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
@Config(shadows = {ShadowUtils.class})
|
||||||
public class WifiScanModeActivityTest {
|
public class WifiScanModeActivityTest {
|
||||||
|
|
||||||
|
static final String LAUNCHED_PACKAGE = "launched_package";
|
||||||
|
static final String APP_LABEL = "app_label";
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
|
@Mock
|
||||||
|
WifiPermissionChecker mWifiPermissionChecker;
|
||||||
|
|
||||||
|
WifiScanModeActivity mActivity;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
mActivity = spy(Robolectric.setupActivity(WifiScanModeActivity.class));
|
||||||
|
mActivity.mWifiPermissionChecker = mWifiPermissionChecker;
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void tearDown() {
|
||||||
|
ShadowUtils.reset();
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void launchActivity_noIntentAction_shouldNotFatalException() {
|
public void launchActivity_noIntentAction_shouldNotFatalException() {
|
||||||
WifiScanModeActivity wifiScanModeActivity =
|
WifiScanModeActivity wifiScanModeActivity =
|
||||||
Robolectric.setupActivity(WifiScanModeActivity.class);
|
Robolectric.setupActivity(WifiScanModeActivity.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void refreshAppLabel_noPackageName_shouldNotFatalException() {
|
||||||
|
when(mWifiPermissionChecker.getLaunchedPackage()).thenReturn(null);
|
||||||
|
|
||||||
|
mActivity.refreshAppLabel();
|
||||||
|
|
||||||
|
assertThat(TextUtils.isEmpty(mActivity.mApp)).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void refreshAppLabel_hasPackageName_shouldHasAppLabel() {
|
||||||
|
ShadowUtils.setApplicationLabel(LAUNCHED_PACKAGE, APP_LABEL);
|
||||||
|
when(mWifiPermissionChecker.getLaunchedPackage()).thenReturn(LAUNCHED_PACKAGE);
|
||||||
|
|
||||||
|
mActivity.refreshAppLabel();
|
||||||
|
|
||||||
|
assertThat(mActivity.mApp).isEqualTo(APP_LABEL);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user