Add Downloader.getCounters method

PiperOrigin-RevId: 241636860
This commit is contained in:
eguven 2019-04-03 01:24:07 +01:00 committed by Oliver Woodman
parent ee7bf4b0ee
commit 8480a4b44d
4 changed files with 20 additions and 0 deletions

View File

@ -16,6 +16,7 @@
package com.google.android.exoplayer2.offline;
import com.google.android.exoplayer2.C;
import com.google.android.exoplayer2.upstream.cache.CacheUtil.CachingCounters;
import java.io.IOException;
/**
@ -47,6 +48,9 @@ public interface Downloader {
*/
float getDownloadPercentage();
/** Returns a {@link CachingCounters} which holds download counters. */
CachingCounters getCounters();
/**
* Removes the media.
*

View File

@ -106,6 +106,11 @@ public final class ProgressiveDownloader implements Downloader {
return cachingCounters.percentage;
}
@Override
public CachingCounters getCounters() {
return cachingCounters;
}
@Override
public void remove() {
CacheUtil.remove(dataSpec, cache, cacheKeyFactory);

View File

@ -158,6 +158,11 @@ public abstract class SegmentDownloader<M extends FilterableManifest<M>> impleme
return counters.percentage;
}
@Override
public CachingCounters getCounters() {
return counters;
}
@Override
public final void remove() throws InterruptedException {
try {

View File

@ -28,6 +28,7 @@ import com.google.android.exoplayer2.testutil.DummyMainThread.TestRunnable;
import com.google.android.exoplayer2.testutil.RobolectricUtil;
import com.google.android.exoplayer2.testutil.TestDownloadManagerListener;
import com.google.android.exoplayer2.testutil.TestUtil;
import com.google.android.exoplayer2.upstream.cache.CacheUtil.CachingCounters;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
@ -747,6 +748,11 @@ public class DownloadManagerTest {
return C.PERCENTAGE_UNSET;
}
@Override
public CachingCounters getCounters() {
return null;
}
private void assertDoesNotStart() throws InterruptedException {
Thread.sleep(ASSERT_FALSE_TIME);
assertThat(started.getCount()).isEqualTo(1);