Merge "Fix crash on "Connection preferences""
This commit is contained in:
@@ -60,6 +60,7 @@ public class PrintSettingPreferenceController extends BasePreferenceController i
|
|||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return mPackageManager.hasSystemFeature(PackageManager.FEATURE_PRINTING)
|
return mPackageManager.hasSystemFeature(PackageManager.FEATURE_PRINTING)
|
||||||
|
&& mPrintManager != null
|
||||||
? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -71,12 +72,16 @@ public class PrintSettingPreferenceController extends BasePreferenceController i
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onStart() {
|
public void onStart() {
|
||||||
mPrintManager.addPrintJobStateChangeListener(this);
|
if (mPrintManager != null) {
|
||||||
|
mPrintManager.addPrintJobStateChangeListener(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onStop() {
|
public void onStop() {
|
||||||
mPrintManager.removePrintJobStateChangeListener(this);
|
if (mPrintManager != null) {
|
||||||
|
mPrintManager.removePrintJobStateChangeListener(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -19,14 +19,19 @@ package com.android.settings.print;
|
|||||||
import static androidx.lifecycle.Lifecycle.Event.ON_START;
|
import static androidx.lifecycle.Lifecycle.Event.ON_START;
|
||||||
import static androidx.lifecycle.Lifecycle.Event.ON_STOP;
|
import static androidx.lifecycle.Lifecycle.Event.ON_STOP;
|
||||||
|
|
||||||
|
import static com.android.settings.core.BasePreferenceController.AVAILABLE;
|
||||||
|
import static com.android.settings.core.BasePreferenceController.UNSUPPORTED_ON_DEVICE;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.never;
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.print.PrintJob;
|
import android.print.PrintJob;
|
||||||
import android.print.PrintJobInfo;
|
import android.print.PrintJobInfo;
|
||||||
@@ -61,6 +66,8 @@ public class PrintSettingsPreferenceControllerTest {
|
|||||||
private UserManager mUserManager;
|
private UserManager mUserManager;
|
||||||
@Mock
|
@Mock
|
||||||
private RestrictedPreference mPreference;
|
private RestrictedPreference mPreference;
|
||||||
|
@Mock
|
||||||
|
private PackageManager mPackageManager;
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private PrintSettingPreferenceController mController;
|
private PrintSettingPreferenceController mController;
|
||||||
@@ -77,6 +84,7 @@ public class PrintSettingsPreferenceControllerTest {
|
|||||||
mLifecycleOwner = () -> mLifecycle;
|
mLifecycleOwner = () -> mLifecycle;
|
||||||
mLifecycle = new Lifecycle(mLifecycleOwner);
|
mLifecycle = new Lifecycle(mLifecycleOwner);
|
||||||
ReflectionHelpers.setField(mController, "mPrintManager", mPrintManager);
|
ReflectionHelpers.setField(mController, "mPrintManager", mPrintManager);
|
||||||
|
ReflectionHelpers.setField(mController, "mPackageManager", mPackageManager);
|
||||||
mLifecycle.addObserver(mController);
|
mLifecycle.addObserver(mController);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -89,6 +97,17 @@ public class PrintSettingsPreferenceControllerTest {
|
|||||||
verify(mPrintManager).removePrintJobStateChangeListener(mController);
|
verify(mPrintManager).removePrintJobStateChangeListener(mController);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onStartStop_printManagerIsNull_doNothing() {
|
||||||
|
ReflectionHelpers.setField(mController, "mPrintManager", null);
|
||||||
|
|
||||||
|
mLifecycle.handleLifecycleEvent(ON_START);
|
||||||
|
mLifecycle.handleLifecycleEvent(ON_STOP);
|
||||||
|
|
||||||
|
verify(mPrintManager, never()).addPrintJobStateChangeListener(mController);
|
||||||
|
verify(mPrintManager, never()).removePrintJobStateChangeListener(mController);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateState_hasActiveJob_shouldSetSummaryToNumberOfJobs() {
|
public void updateState_hasActiveJob_shouldSetSummaryToNumberOfJobs() {
|
||||||
final List<PrintJob> printJobs = new ArrayList<>();
|
final List<PrintJob> printJobs = new ArrayList<>();
|
||||||
@@ -133,4 +152,29 @@ public class PrintSettingsPreferenceControllerTest {
|
|||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
verify(mPreference).checkRestrictionAndSetDisabled(UserManager.DISALLOW_PRINTING);
|
verify(mPreference).checkRestrictionAndSetDisabled(UserManager.DISALLOW_PRINTING);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_hasFeature_returnsAvailable() {
|
||||||
|
when(mPackageManager.hasSystemFeature(PackageManager.FEATURE_PRINTING))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_noFeature_returnsUnsupported() {
|
||||||
|
when(mPackageManager.hasSystemFeature(PackageManager.FEATURE_PRINTING))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_printManagerIsNull_returnsUnsupported() {
|
||||||
|
ReflectionHelpers.setField(mController, "mPrintManager", null);
|
||||||
|
when(mPackageManager.hasSystemFeature(PackageManager.FEATURE_PRINTING))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user