Merge "Fix crash on "Connection preferences""

This commit is contained in:
Treehugger Robot
2020-11-04 08:14:27 +00:00
committed by Gerrit Code Review
2 changed files with 51 additions and 2 deletions

View File

@@ -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

View File

@@ -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);
}
} }