Merge "Use the new loader to show app data usage summary."
This commit is contained in:
committed by
Android (Google) Code Review
commit
5cb7e3c0ab
@@ -67,6 +67,12 @@
|
|||||||
android:summary="@string/summary_placeholder"
|
android:summary="@string/summary_placeholder"
|
||||||
settings:controller="com.android.settings.applications.appinfo.AppDataUsagePreferenceController" />
|
settings:controller="com.android.settings.applications.appinfo.AppDataUsagePreferenceController" />
|
||||||
|
|
||||||
|
<Preference
|
||||||
|
android:key="data_settings_v2"
|
||||||
|
android:title="@string/data_usage_app_summary_title"
|
||||||
|
android:summary="@string/summary_placeholder"
|
||||||
|
settings:controller="com.android.settings.applications.appinfo.AppDataUsagePreferenceControllerV2" />
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="time_spent_in_app"
|
android:key="time_spent_in_app"
|
||||||
android:title="@string/time_spent_in_app_pref_title"
|
android:title="@string/time_spent_in_app_pref_title"
|
||||||
|
@@ -25,6 +25,7 @@ import android.os.RemoteException;
|
|||||||
import android.os.ServiceManager;
|
import android.os.ServiceManager;
|
||||||
import android.text.format.DateUtils;
|
import android.text.format.DateUtils;
|
||||||
import android.text.format.Formatter;
|
import android.text.format.Formatter;
|
||||||
|
import android.util.FeatureFlagUtils;
|
||||||
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.loader.app.LoaderManager;
|
import androidx.loader.app.LoaderManager;
|
||||||
@@ -35,6 +36,7 @@ import androidx.preference.PreferenceScreen;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsPreferenceFragment;
|
import com.android.settings.SettingsPreferenceFragment;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
|
import com.android.settings.core.FeatureFlags;
|
||||||
import com.android.settings.datausage.AppDataUsage;
|
import com.android.settings.datausage.AppDataUsage;
|
||||||
import com.android.settings.datausage.DataUsageList;
|
import com.android.settings.datausage.DataUsageList;
|
||||||
import com.android.settings.datausage.DataUsageUtils;
|
import com.android.settings.datausage.DataUsageUtils;
|
||||||
@@ -63,6 +65,9 @@ public class AppDataUsagePreferenceController extends AppInfoPreferenceControlle
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
|
if (FeatureFlagUtils.isEnabled(mContext, FeatureFlags.DATA_USAGE_V2)) {
|
||||||
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
|
}
|
||||||
return isBandwidthControlEnabled() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
return isBandwidthControlEnabled() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -99,7 +104,9 @@ public class AppDataUsagePreferenceController extends AppInfoPreferenceControlle
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
mParent.getLoaderManager().destroyLoader(mParent.LOADER_CHART_DATA);
|
if (mStatsSession != null) {
|
||||||
|
mParent.getLoaderManager().destroyLoader(mParent.LOADER_CHART_DATA);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (C) 2017 The Android Open Source Project
|
* Copyright (C) 2018 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.
|
||||||
@@ -17,14 +17,11 @@
|
|||||||
package com.android.settings.applications.appinfo;
|
package com.android.settings.applications.appinfo;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.net.INetworkStatsService;
|
|
||||||
import android.net.INetworkStatsSession;
|
|
||||||
import android.net.NetworkTemplate;
|
import android.net.NetworkTemplate;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.RemoteException;
|
|
||||||
import android.os.ServiceManager;
|
|
||||||
import android.text.format.DateUtils;
|
import android.text.format.DateUtils;
|
||||||
import android.text.format.Formatter;
|
import android.text.format.Formatter;
|
||||||
|
import android.util.FeatureFlagUtils;
|
||||||
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.loader.app.LoaderManager;
|
import androidx.loader.app.LoaderManager;
|
||||||
@@ -35,43 +32,39 @@ import androidx.preference.PreferenceScreen;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsPreferenceFragment;
|
import com.android.settings.SettingsPreferenceFragment;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.datausage.AppDataUsage;
|
import com.android.settings.core.FeatureFlags;
|
||||||
import com.android.settings.datausage.DataUsageList;
|
import com.android.settings.datausage.AppDataUsageV2;
|
||||||
import com.android.settings.datausage.DataUsageUtils;
|
import com.android.settings.datausage.DataUsageUtils;
|
||||||
import com.android.settingslib.AppItem;
|
import com.android.settingslib.AppItem;
|
||||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
import com.android.settingslib.core.lifecycle.events.OnPause;
|
import com.android.settingslib.core.lifecycle.events.OnPause;
|
||||||
import com.android.settingslib.core.lifecycle.events.OnResume;
|
import com.android.settingslib.core.lifecycle.events.OnResume;
|
||||||
import com.android.settingslib.net.ChartData;
|
import com.android.settingslib.net.NetworkCycleDataForUid;
|
||||||
import com.android.settingslib.net.ChartDataLoaderCompat;
|
import com.android.settingslib.net.NetworkCycleDataForUidLoader;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class AppDataUsagePreferenceControllerV2 extends AppInfoPreferenceControllerBase
|
public class AppDataUsagePreferenceControllerV2 extends AppInfoPreferenceControllerBase
|
||||||
implements LoaderManager.LoaderCallbacks<ChartData>, LifecycleObserver, OnResume, OnPause {
|
implements LoaderManager.LoaderCallbacks<List<NetworkCycleDataForUid>>, LifecycleObserver,
|
||||||
|
OnResume, OnPause {
|
||||||
|
|
||||||
private ChartData mChartData;
|
private List<NetworkCycleDataForUid> mAppUsageData;
|
||||||
private INetworkStatsSession mStatsSession;
|
|
||||||
|
|
||||||
public AppDataUsagePreferenceControllerV2(Context context,String key) {
|
public AppDataUsagePreferenceControllerV2(Context context, String key) {
|
||||||
super(context, key);
|
super(context, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
|
if (!FeatureFlagUtils.isEnabled(mContext, FeatureFlags.DATA_USAGE_V2)) {
|
||||||
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
|
}
|
||||||
return isBandwidthControlEnabled() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
return isBandwidthControlEnabled() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void displayPreference(PreferenceScreen screen) {
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
super.displayPreference(screen);
|
super.displayPreference(screen);
|
||||||
if (isAvailable()) {
|
|
||||||
final INetworkStatsService statsService = INetworkStatsService.Stub.asInterface(
|
|
||||||
ServiceManager.getService(Context.NETWORK_STATS_SERVICE));
|
|
||||||
try {
|
|
||||||
mStatsSession = statsService.openSession();
|
|
||||||
} catch (RemoteException e) {
|
|
||||||
throw new RuntimeException(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -81,51 +74,67 @@ public class AppDataUsagePreferenceControllerV2 extends AppInfoPreferenceControl
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onResume() {
|
public void onResume() {
|
||||||
if (mStatsSession != null) {
|
if (isAvailable()) {
|
||||||
final int uid = mParent.getAppEntry().info.uid;
|
final int uid = mParent.getAppEntry().info.uid;
|
||||||
final AppItem app = new AppItem(uid);
|
final AppItem app = new AppItem(uid);
|
||||||
app.addUid(uid);
|
app.addUid(uid);
|
||||||
mParent.getLoaderManager().restartLoader(mParent.LOADER_CHART_DATA,
|
mParent.getLoaderManager().restartLoader(mParent.LOADER_CHART_DATA, null /* args */,
|
||||||
ChartDataLoaderCompat.buildArgs(getTemplate(mContext), app),
|
|
||||||
this);
|
this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
mParent.getLoaderManager().destroyLoader(mParent.LOADER_CHART_DATA);
|
if (isAvailable()) {
|
||||||
|
mParent.getLoaderManager().destroyLoader(mParent.LOADER_CHART_DATA);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Loader<ChartData> onCreateLoader(int id, Bundle args) {
|
public Loader<List<NetworkCycleDataForUid>> onCreateLoader(int id, Bundle args) {
|
||||||
return new ChartDataLoaderCompat(mContext, mStatsSession, args);
|
final NetworkTemplate template = getTemplate(mContext);
|
||||||
|
return NetworkCycleDataForUidLoader.builder(mContext)
|
||||||
|
.setUid(mParent.getAppEntry().info.uid)
|
||||||
|
.setRetrieveDetail(false)
|
||||||
|
.setNetworkTemplate(template)
|
||||||
|
.setSubscriberId(template.getSubscriberId())
|
||||||
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onLoadFinished(Loader<ChartData> loader, ChartData data) {
|
public void onLoadFinished(Loader<List<NetworkCycleDataForUid>> loader,
|
||||||
mChartData = data;
|
List<NetworkCycleDataForUid> data) {
|
||||||
|
mAppUsageData = data;
|
||||||
updateState(mPreference);
|
updateState(mPreference);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onLoaderReset(Loader<ChartData> loader) {
|
public void onLoaderReset(Loader<List<NetworkCycleDataForUid>> loader) {
|
||||||
// Leave last result.
|
// Leave last result.
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Class<? extends SettingsPreferenceFragment> getDetailFragmentClass() {
|
protected Class<? extends SettingsPreferenceFragment> getDetailFragmentClass() {
|
||||||
return AppDataUsage.class;
|
return AppDataUsageV2.class;
|
||||||
}
|
}
|
||||||
|
|
||||||
private CharSequence getDataSummary() {
|
private CharSequence getDataSummary() {
|
||||||
if (mChartData != null) {
|
if (mAppUsageData != null) {
|
||||||
final long totalBytes = mChartData.detail.getTotalBytes();
|
long totalBytes = 0;
|
||||||
|
long startTime = System.currentTimeMillis();
|
||||||
|
for (NetworkCycleDataForUid data : mAppUsageData) {
|
||||||
|
totalBytes += data.getTotalUsage();
|
||||||
|
final long cycleStart = data.getStartTime();
|
||||||
|
if (cycleStart < startTime) {
|
||||||
|
startTime = cycleStart;
|
||||||
|
}
|
||||||
|
}
|
||||||
if (totalBytes == 0) {
|
if (totalBytes == 0) {
|
||||||
return mContext.getString(R.string.no_data_usage);
|
return mContext.getString(R.string.no_data_usage);
|
||||||
}
|
}
|
||||||
return mContext.getString(R.string.data_summary_format,
|
return mContext.getString(R.string.data_summary_format,
|
||||||
Formatter.formatFileSize(mContext, totalBytes),
|
Formatter.formatFileSize(mContext, totalBytes),
|
||||||
DateUtils.formatDateTime(mContext, mChartData.detail.getStart(),
|
DateUtils.formatDateTime(mContext, startTime,
|
||||||
DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_ABBREV_MONTH));
|
DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_ABBREV_MONTH));
|
||||||
}
|
}
|
||||||
return mContext.getString(R.string.computing_size);
|
return mContext.getString(R.string.computing_size);
|
||||||
|
@@ -34,6 +34,7 @@ import android.os.Bundle;
|
|||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
|
import android.util.FeatureFlagUtils;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuInflater;
|
import android.view.MenuInflater;
|
||||||
@@ -48,6 +49,7 @@ import com.android.settings.SettingsPreferenceFragment;
|
|||||||
import com.android.settings.applications.manageapplications.ManageApplications;
|
import com.android.settings.applications.manageapplications.ManageApplications;
|
||||||
import com.android.settings.applications.specialaccess.pictureinpicture
|
import com.android.settings.applications.specialaccess.pictureinpicture
|
||||||
.PictureInPictureDetailPreferenceController;
|
.PictureInPictureDetailPreferenceController;
|
||||||
|
import com.android.settings.core.FeatureFlags;
|
||||||
import com.android.settings.core.SubSettingLauncher;
|
import com.android.settings.core.SubSettingLauncher;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settingslib.RestrictedLockUtilsInternal;
|
import com.android.settingslib.RestrictedLockUtilsInternal;
|
||||||
@@ -139,7 +141,11 @@ public class AppInfoDashboardFragment extends DashboardFragment
|
|||||||
final String packageName = getPackageName();
|
final String packageName = getPackageName();
|
||||||
use(TimeSpentInAppPreferenceController.class).setPackageName(packageName);
|
use(TimeSpentInAppPreferenceController.class).setPackageName(packageName);
|
||||||
|
|
||||||
use(AppDataUsagePreferenceController.class).setParentFragment(this);
|
if (FeatureFlagUtils.isEnabled(context, FeatureFlags.DATA_USAGE_V2)) {
|
||||||
|
use(AppDataUsagePreferenceControllerV2.class).setParentFragment(this);
|
||||||
|
} else {
|
||||||
|
use(AppDataUsagePreferenceController.class).setParentFragment(this);
|
||||||
|
}
|
||||||
final AppInstallerInfoPreferenceController installer =
|
final AppInstallerInfoPreferenceController installer =
|
||||||
use(AppInstallerInfoPreferenceController.class);
|
use(AppInstallerInfoPreferenceController.class);
|
||||||
installer.setPackageName(packageName);
|
installer.setPackageName(packageName);
|
||||||
|
@@ -426,11 +426,11 @@ public class DataUsageListV2 extends DataUsageBaseFragment {
|
|||||||
|
|
||||||
private void startAppDataUsage(AppItem item) {
|
private void startAppDataUsage(AppItem item) {
|
||||||
final Bundle args = new Bundle();
|
final Bundle args = new Bundle();
|
||||||
args.putParcelable(AppDataUsage.ARG_APP_ITEM, item);
|
args.putParcelable(AppDataUsageV2.ARG_APP_ITEM, item);
|
||||||
args.putParcelable(AppDataUsage.ARG_NETWORK_TEMPLATE, mTemplate);
|
args.putParcelable(AppDataUsageV2.ARG_NETWORK_TEMPLATE, mTemplate);
|
||||||
|
|
||||||
new SubSettingLauncher(getContext())
|
new SubSettingLauncher(getContext())
|
||||||
.setDestination(AppDataUsage.class.getName())
|
.setDestination(AppDataUsageV2.class.getName())
|
||||||
.setTitleRes(R.string.app_data_usage)
|
.setTitleRes(R.string.app_data_usage)
|
||||||
.setArguments(args)
|
.setArguments(args)
|
||||||
.setSourceMetricsCategory(getMetricsCategory())
|
.setSourceMetricsCategory(getMetricsCategory())
|
||||||
@@ -490,8 +490,6 @@ public class DataUsageListV2 extends DataUsageBaseFragment {
|
|||||||
@Override
|
@Override
|
||||||
public Loader<List<NetworkCycleChartData>> onCreateLoader(int id, Bundle args) {
|
public Loader<List<NetworkCycleChartData>> onCreateLoader(int id, Bundle args) {
|
||||||
return NetworkCycleChartDataLoader.builder(getContext())
|
return NetworkCycleChartDataLoader.builder(getContext())
|
||||||
.setNetworkPolicy(services.mPolicyEditor.getPolicy(mTemplate))
|
|
||||||
.setNetworkType(mNetworkType)
|
|
||||||
.setNetworkTemplate(mTemplate)
|
.setNetworkTemplate(mTemplate)
|
||||||
.setSubscriberId(mTelephonyManager.getSubscriberId(mSubId))
|
.setSubscriberId(mTelephonyManager.getSubscriberId(mSubId))
|
||||||
.build();
|
.build();
|
||||||
|
@@ -115,6 +115,7 @@ public class AppDataUsagePreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPause_shouldDestroyDataLoader() {
|
public void onPause_shouldDestroyDataLoader() {
|
||||||
|
ReflectionHelpers.setField(mController, "mStatsSession", mock(INetworkStatsSession.class));
|
||||||
doReturn(mLoaderManager).when(mFragment).getLoaderManager();
|
doReturn(mLoaderManager).when(mFragment).getLoaderManager();
|
||||||
|
|
||||||
mController.onPause();
|
mController.onPause();
|
||||||
|
@@ -21,6 +21,7 @@ import static com.google.common.truth.Truth.assertThat;
|
|||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.anyInt;
|
import static org.mockito.ArgumentMatchers.anyInt;
|
||||||
import static org.mockito.ArgumentMatchers.eq;
|
import static org.mockito.ArgumentMatchers.eq;
|
||||||
|
import static org.mockito.ArgumentMatchers.nullable;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.never;
|
import static org.mockito.Mockito.never;
|
||||||
@@ -31,18 +32,20 @@ import static org.mockito.Mockito.when;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.net.INetworkStatsSession;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.datausage.AppDataUsage;
|
import com.android.settings.core.FeatureFlags;
|
||||||
|
import com.android.settings.datausage.AppDataUsageV2;
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settingslib.applications.ApplicationsState.AppEntry;
|
import com.android.settingslib.applications.ApplicationsState.AppEntry;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
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.Mock;import android.net.INetworkStatsSession;
|
||||||
|
import android.util.FeatureFlagUtils;
|
||||||
|
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
import org.robolectric.util.ReflectionHelpers;
|
import org.robolectric.util.ReflectionHelpers;
|
||||||
@@ -67,6 +70,7 @@ public class AppDataUsagePreferenceControllerV2Test {
|
|||||||
mContext = spy(RuntimeEnvironment.application.getApplicationContext());
|
mContext = spy(RuntimeEnvironment.application.getApplicationContext());
|
||||||
mController = spy(new AppDataUsagePreferenceControllerV2(mContext, "test_key"));
|
mController = spy(new AppDataUsagePreferenceControllerV2(mContext, "test_key"));
|
||||||
mController.setParentFragment(mFragment);
|
mController.setParentFragment(mFragment);
|
||||||
|
FeatureFlagUtils.setEnabled(mContext, FeatureFlags.DATA_USAGE_V2, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -86,7 +90,8 @@ public class AppDataUsagePreferenceControllerV2Test {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onResume_noSession_shouldNotRestartDataLoader() {
|
public void onResume_notAvailable_shouldNotRestartDataLoader() {
|
||||||
|
FeatureFlagUtils.setEnabled(mContext, FeatureFlags.DATA_USAGE_V2, false);
|
||||||
doReturn(mLoaderManager).when(mFragment).getLoaderManager();
|
doReturn(mLoaderManager).when(mFragment).getLoaderManager();
|
||||||
|
|
||||||
mController.onResume();
|
mController.onResume();
|
||||||
@@ -96,25 +101,26 @@ public class AppDataUsagePreferenceControllerV2Test {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onResume_hasSession_shouldRestartDataLoader() {
|
public void onResume_isAvailable_shouldRestartDataLoader() {
|
||||||
final ConnectivityManager connectivityManager = mock(ConnectivityManager.class);
|
final ConnectivityManager connectivityManager = mock(ConnectivityManager.class);
|
||||||
when(mContext.getSystemService(Context.CONNECTIVITY_SERVICE))
|
when(mContext.getSystemService(Context.CONNECTIVITY_SERVICE))
|
||||||
.thenReturn(connectivityManager);
|
.thenReturn(connectivityManager);
|
||||||
when(connectivityManager.isNetworkSupported(anyInt())).thenReturn(true);
|
when(connectivityManager.isNetworkSupported(anyInt())).thenReturn(true);
|
||||||
doReturn(mLoaderManager).when(mFragment).getLoaderManager();
|
doReturn(mLoaderManager).when(mFragment).getLoaderManager();
|
||||||
ReflectionHelpers.setField(mController, "mStatsSession", mock(INetworkStatsSession.class));
|
doReturn(BasePreferenceController.AVAILABLE).when(mController).getAvailabilityStatus();
|
||||||
final AppEntry appEntry = mock(AppEntry.class);
|
final AppEntry appEntry = mock(AppEntry.class);
|
||||||
appEntry.info = new ApplicationInfo();
|
appEntry.info = new ApplicationInfo();
|
||||||
when(mFragment.getAppEntry()).thenReturn(appEntry);
|
when(mFragment.getAppEntry()).thenReturn(appEntry);
|
||||||
|
|
||||||
mController.onResume();
|
mController.onResume();
|
||||||
|
|
||||||
verify(mLoaderManager).restartLoader(
|
verify(mLoaderManager).restartLoader(eq(AppInfoDashboardFragment.LOADER_CHART_DATA),
|
||||||
eq(AppInfoDashboardFragment.LOADER_CHART_DATA), any(Bundle.class), eq(mController));
|
nullable(Bundle.class), eq(mController));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPause_shouldDestroyDataLoader() {
|
public void onPause_shouldDestroyDataLoader() {
|
||||||
|
doReturn(BasePreferenceController.AVAILABLE).when(mController).getAvailabilityStatus();
|
||||||
doReturn(mLoaderManager).when(mFragment).getLoaderManager();
|
doReturn(mLoaderManager).when(mFragment).getLoaderManager();
|
||||||
|
|
||||||
mController.onPause();
|
mController.onPause();
|
||||||
@@ -124,7 +130,7 @@ public class AppDataUsagePreferenceControllerV2Test {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getDetailFragmentClass_shouldReturnAppDataUsage() {
|
public void getDetailFragmentClass_shouldReturnAppDataUsage() {
|
||||||
assertThat(mController.getDetailFragmentClass()).isEqualTo(AppDataUsage.class);
|
assertThat(mController.getDetailFragmentClass()).isEqualTo(AppDataUsageV2.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Reference in New Issue
Block a user