Merge "Fix a race condition where the extra view may not update timely."

This commit is contained in:
Daniel Nishi
2017-02-16 17:39:40 +00:00
committed by Android (Google) Code Review
3 changed files with 32 additions and 9 deletions

View File

@@ -329,7 +329,8 @@ public class ManageApplications extends InstrumentedPreferenceFragment
mApplications.setExtraViewController(new MusicViewHolderController( mApplications.setExtraViewController(new MusicViewHolderController(
context, context,
new StorageStatsSource(context), new StorageStatsSource(context),
mVolumeUuid)); mVolumeUuid,
UserHandle.of(UserHandle.getUserId(mCurrentUid))));
} }
mListView.setAdapter(mApplications); mListView.setAdapter(mApplications);
mListView.setRecyclerListener(mApplications); mListView.setRecyclerListener(mApplications);
@@ -870,6 +871,12 @@ public class ManageApplications extends InstrumentedPreferenceFragment
public void setExtraViewController(FileViewHolderController extraViewController) { public void setExtraViewController(FileViewHolderController extraViewController) {
mExtraViewController = extraViewController; mExtraViewController = extraViewController;
mBgHandler.post(() -> {
mExtraViewController.queryStats();
mFgHandler.post(() -> {
onExtraViewCompleted();
});
});
} }
public void resume(int sort) { public void resume(int sort) {
@@ -957,10 +964,6 @@ public class ManageApplications extends InstrumentedPreferenceFragment
break; break;
} }
if (mExtraViewController != null) {
mExtraViewController.queryStats();
}
filterObj = new CompoundFilter(filterObj, ApplicationsState.FILTER_NOT_HIDE); filterObj = new CompoundFilter(filterObj, ApplicationsState.FILTER_NOT_HIDE);
AppFilter finalFilterObj = filterObj; AppFilter finalFilterObj = filterObj;
mBgHandler.post(() -> { mBgHandler.post(() -> {
@@ -1178,6 +1181,23 @@ public class ManageApplications extends InstrumentedPreferenceFragment
} }
} }
public void onExtraViewCompleted() {
int size = mActive.size();
// If we have no elements, don't do anything.
if (size < 1) {
return;
}
AppViewHolder holder = (AppViewHolder) mActive.get(size - 1).getTag();
// HACK: The extra view has no AppEntry -- and should be the only element without one.
// Thus, if the last active element has no AppEntry, it is the extra view.
if (holder == null || holder.entry != null) {
return;
}
mExtraViewController.setupView(holder);
}
public int getCount() { public int getCount() {
if (mEntries == null) { if (mEntries == null) {
return 0; return 0;

View File

@@ -38,18 +38,20 @@ public class MusicViewHolderController implements FileViewHolderController {
private StorageStatsSource mSource; private StorageStatsSource mSource;
private String mVolumeUuid; private String mVolumeUuid;
private long mMusicSize; private long mMusicSize;
private UserHandle mUser;
public MusicViewHolderController( public MusicViewHolderController(
Context context, StorageStatsSource source, String volumeUuid) { Context context, StorageStatsSource source, String volumeUuid, UserHandle user) {
mContext = context; mContext = context;
mSource = source; mSource = source;
mVolumeUuid = volumeUuid; mVolumeUuid = volumeUuid;
mUser = user;
} }
@Override @Override
@WorkerThread @WorkerThread
public void queryStats() { public void queryStats() {
mMusicSize = mSource.getExternalStorageStats(mVolumeUuid, UserHandle.CURRENT).audioBytes; mMusicSize = mSource.getExternalStorageStats(mVolumeUuid, mUser).audioBytes;
} }
@Override @Override
@@ -69,7 +71,7 @@ public class MusicViewHolderController implements FileViewHolderController {
Intent intent = new Intent(DocumentsContract.ACTION_BROWSE); Intent intent = new Intent(DocumentsContract.ACTION_BROWSE);
intent.setData(DocumentsContract.buildRootUri(AUTHORITY_MEDIA, "audio_root")); intent.setData(DocumentsContract.buildRootUri(AUTHORITY_MEDIA, "audio_root"));
intent.addCategory(Intent.CATEGORY_DEFAULT); intent.addCategory(Intent.CATEGORY_DEFAULT);
intent.putExtra(Intent.EXTRA_USER_ID, UserHandle.CURRENT); intent.putExtra(Intent.EXTRA_USER_ID, mUser);
Utils.launchIntent(fragment, intent); Utils.launchIntent(fragment, intent);
} }
} }

View File

@@ -66,7 +66,8 @@ public class MusicViewHolderControllerTest {
MockitoAnnotations.initMocks(this); MockitoAnnotations.initMocks(this);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mVolume = new VolumeInfo("id", 0, null, "id"); mVolume = new VolumeInfo("id", 0, null, "id");
mController = new MusicViewHolderController(mContext, mSource, mVolume.fsUuid); mController = new MusicViewHolderController(mContext, mSource, mVolume.fsUuid,
new UserHandle(0));
LayoutInflater inflater = LayoutInflater.from(mContext); LayoutInflater inflater = LayoutInflater.from(mContext);
mHolder = AppViewHolder.createOrRecycle(inflater, null); mHolder = AppViewHolder.createOrRecycle(inflater, null);