Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(140)

Unified Diff: components/cronet/android/test/javatests/src/org/chromium/net/CronetUrlRequestContextTest.java

Issue 2045703003: Enable NQE when Cronet Engine is built (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/cronet/android/test/javatests/src/org/chromium/net/CronetUrlRequestContextTest.java
diff --git a/components/cronet/android/test/javatests/src/org/chromium/net/CronetUrlRequestContextTest.java b/components/cronet/android/test/javatests/src/org/chromium/net/CronetUrlRequestContextTest.java
index 95f35eed336afe712c640f82540cbb353600e2fb..d602045567d43f846c2709e036a1ee1b76ac0e28 100644
--- a/components/cronet/android/test/javatests/src/org/chromium/net/CronetUrlRequestContextTest.java
+++ b/components/cronet/android/test/javatests/src/org/chromium/net/CronetUrlRequestContextTest.java
@@ -12,6 +12,7 @@ import android.os.ConditionVariable;
import android.os.Handler;
import android.os.Looper;
import android.test.suitebuilder.annotation.SmallTest;
+import android.util.SparseIntArray;
import org.chromium.base.PathUtils;
import org.chromium.base.annotations.JNINamespace;
@@ -132,6 +133,8 @@ public class CronetUrlRequestContextTest extends CronetTestBase {
private final ConditionVariable mWaitForThroughput;
private int mRttObservationCount;
private int mThroughputObservationCount;
+ // Holds the RTT observations counts indexed by source.
+ private SparseIntArray mRttObservationCountBySource = new SparseIntArray();
TestNetworkQualityListener(ConditionVariable waitForThroughput) {
mWaitForThroughput = waitForThroughput;
@@ -141,6 +144,8 @@ public class CronetUrlRequestContextTest extends CronetTestBase {
public void onRttObservation(int rttMs, long when, int source) {
synchronized (mLock) {
mRttObservationCount++;
+ mRttObservationCountBySource.put(
+ source, mRttObservationCountBySource.get(source) + 1);
}
}
@@ -160,6 +165,12 @@ public class CronetUrlRequestContextTest extends CronetTestBase {
}
}
+ public int rttObservationCount(int source) {
+ synchronized (mLock) {
+ return mRttObservationCountBySource.get(source);
+ }
+ }
+
public int throughputObservationCount() {
synchronized (mLock) {
return mThroughputObservationCount;
@@ -240,6 +251,35 @@ public class CronetUrlRequestContextTest extends CronetTestBase {
@SmallTest
@Feature({"Cronet"})
public void testRealTimeNetworkQualityObservationsNotEnabled() throws Exception {
+ CronetEngine.Builder mCronetEngineBuilder = new CronetEngine.Builder(getContext());
+ mCronetEngineBuilder.enableHTTP2(true).enableQUIC(false).enableNetworkQualityEstimator(
bengr 2016/06/07 20:53:16 You shouldn't have to call enableNetworkQualityEst
tbansal1 2016/06/07 21:37:17 Done.
+ false, null);
+ mTestFramework =
+ startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCronetEngineBuilder);
+ TestNetworkQualityListener networkQualityListener = new TestNetworkQualityListener(null);
+ try {
+ mTestFramework.mCronetEngine.addRttListener(networkQualityListener);
+ fail("Should throw an exception.");
+ } catch (IllegalStateException e) {
+ }
+ try {
+ mTestFramework.mCronetEngine.addThroughputListener(networkQualityListener);
+ fail("Should throw an exception.");
+ } catch (IllegalStateException e) {
+ }
+ TestUrlRequestCallback callback = new TestUrlRequestCallback();
+ UrlRequest urlRequest =
+ mTestFramework.mCronetEngine.createRequest(mUrl, callback, callback.getExecutor());
+ urlRequest.start();
+ callback.blockForDone();
+ assertEquals(0, networkQualityListener.rttObservationCount());
+ assertEquals(0, networkQualityListener.throughputObservationCount());
+ mTestFramework.mCronetEngine.shutdown();
+ }
+
+ @SmallTest
+ @Feature({"Cronet"})
+ public void testRealTimeNetworkQualityObservationsNotEnabled_LegacyAPI() throws Exception {
mTestFramework = startCronetTestFramework();
TestNetworkQualityListener networkQualityListener = new TestNetworkQualityListener(null);
try {
@@ -265,11 +305,37 @@ public class CronetUrlRequestContextTest extends CronetTestBase {
@SmallTest
@Feature({"Cronet"})
public void testRealTimeNetworkQualityObservationsListenerRemoved() throws Exception {
+ CronetEngine.Builder mCronetEngineBuilder = new CronetEngine.Builder(getContext());
+ TestExecutor mNetworkQualityExecutor = new TestExecutor();
+ mCronetEngineBuilder.enableHTTP2(true).enableQUIC(false).enableNetworkQualityEstimator(
+ true, mNetworkQualityExecutor);
+ mTestFramework =
+ startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCronetEngineBuilder);
+ TestNetworkQualityListener networkQualityListener = new TestNetworkQualityListener(null);
+ mTestFramework.mCronetEngine.configureNetworkQualityEstimatorForTesting(true, true);
+ mTestFramework.mCronetEngine.addRttListener(networkQualityListener);
+ mTestFramework.mCronetEngine.addThroughputListener(networkQualityListener);
+ mTestFramework.mCronetEngine.removeRttListener(networkQualityListener);
+ mTestFramework.mCronetEngine.removeThroughputListener(networkQualityListener);
+ TestUrlRequestCallback callback = new TestUrlRequestCallback();
+ UrlRequest urlRequest =
+ mTestFramework.mCronetEngine.createRequest(mUrl, callback, callback.getExecutor());
+ urlRequest.start();
+ callback.blockForDone();
+ mNetworkQualityExecutor.runAllTasks();
+ assertEquals(0, networkQualityListener.rttObservationCount());
+ assertEquals(0, networkQualityListener.throughputObservationCount());
+ mTestFramework.mCronetEngine.shutdown();
+ }
+
+ @SmallTest
+ @Feature({"Cronet"})
+ public void testRealTimeNetworkQualityObservationsListenerRemoved_LegacyAPI() throws Exception {
mTestFramework = startCronetTestFramework();
TestExecutor testExecutor = new TestExecutor();
TestNetworkQualityListener networkQualityListener = new TestNetworkQualityListener(null);
- mTestFramework.mCronetEngine.enableNetworkQualityEstimatorForTesting(
- true, true, testExecutor);
+ mTestFramework.mCronetEngine.enableNetworkQualityEstimator(testExecutor);
+ mTestFramework.mCronetEngine.configureNetworkQualityEstimatorForTesting(true, true);
mTestFramework.mCronetEngine.addRttListener(networkQualityListener);
mTestFramework.mCronetEngine.addThroughputListener(networkQualityListener);
mTestFramework.mCronetEngine.removeRttListener(networkQualityListener);
@@ -287,13 +353,57 @@ public class CronetUrlRequestContextTest extends CronetTestBase {
@SmallTest
@Feature({"Cronet"})
- public void testRealTimeNetworkQualityObservations() throws Exception {
+ public void testRealTimeNetworkQualityObservationsWithoutQuic() throws Exception {
+ CronetEngine.Builder mCronetEngineBuilder = new CronetEngine.Builder(getContext());
+ Executor networkQualityExecutor = Executors.newSingleThreadExecutor();
+ mCronetEngineBuilder.enableHTTP2(true).enableQUIC(false).enableNetworkQualityEstimator(
+ true, networkQualityExecutor);
+ mTestFramework =
+ startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCronetEngineBuilder);
+ ConditionVariable waitForThroughput = new ConditionVariable();
+ TestNetworkQualityListener networkQualityListener =
+ new TestNetworkQualityListener(waitForThroughput);
+ mTestFramework.mCronetEngine.configureNetworkQualityEstimatorForTesting(true, true);
+ mTestFramework.mCronetEngine.addRttListener(networkQualityListener);
+ mTestFramework.mCronetEngine.addThroughputListener(networkQualityListener);
+ TestUrlRequestCallback callback = new TestUrlRequestCallback();
+ UrlRequest urlRequest =
+ mTestFramework.mCronetEngine.createRequest(mUrl, callback, callback.getExecutor());
+ urlRequest.start();
+ callback.blockForDone();
+
+ // Throughput observation is posted to the network quality estimator on the network thread
+ // after the UrlRequest is completed. The observations are then eventually posted to
+ // throughput listeners on the executor provided to network quality.
+ waitForThroughput.block();
+ assertTrue(networkQualityListener.throughputObservationCount() > 0);
+
+ // Check RTT observation count after throughput observation has been received. This ensures
+ // that executor has finished posting the RTT observation to the RTT listeners.
+ assertTrue(networkQualityListener.rttObservationCount() > 0);
+
+ // NETWORK_QUALITY_OBSERVATION_SOURCE_URL_REQUEST
+ assertTrue(networkQualityListener.rttObservationCount(0) > 0);
+
+ // NETWORK_QUALITY_OBSERVATION_SOURCE_TCP
+ assertTrue(networkQualityListener.rttObservationCount(1) > 0);
+
+ // NETWORK_QUALITY_OBSERVATION_SOURCE_QUIC
+ assertEquals(0, networkQualityListener.rttObservationCount(2));
+
+ mTestFramework.mCronetEngine.shutdown();
+ }
+
+ @SmallTest
+ @Feature({"Cronet"})
+ public void testRealTimeNetworkQualityObservations_LegacyAPI() throws Exception {
mTestFramework = startCronetTestFramework();
Executor executor = Executors.newSingleThreadExecutor();
ConditionVariable waitForThroughput = new ConditionVariable();
TestNetworkQualityListener networkQualityListener =
new TestNetworkQualityListener(waitForThroughput);
- mTestFramework.mCronetEngine.enableNetworkQualityEstimatorForTesting(true, true, executor);
+ mTestFramework.mCronetEngine.enableNetworkQualityEstimator(executor);
+ mTestFramework.mCronetEngine.configureNetworkQualityEstimatorForTesting(true, true);
mTestFramework.mCronetEngine.addRttListener(networkQualityListener);
mTestFramework.mCronetEngine.addThroughputListener(networkQualityListener);
TestUrlRequestCallback callback = new TestUrlRequestCallback();
@@ -331,6 +441,42 @@ public class CronetUrlRequestContextTest extends CronetTestBase {
@Feature({"Cronet"})
@SuppressWarnings("deprecation")
public void testRequestFinishedListener() throws Exception {
+ CronetEngine.Builder mCronetEngineBuilder = new CronetEngine.Builder(getContext());
+ TestExecutor mNetworkQualityExecutor = new TestExecutor();
+ mCronetEngineBuilder.enableHTTP2(true).enableQUIC(false).enableNetworkQualityEstimator(
+ true, mNetworkQualityExecutor);
+ mTestFramework =
+ startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCronetEngineBuilder);
+ TestRequestFinishedListener requestFinishedListener = new TestRequestFinishedListener();
+ mTestFramework.mCronetEngine.addRequestFinishedListener(requestFinishedListener);
+ TestUrlRequestCallback callback = new TestUrlRequestCallback();
+ UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder(
+ mUrl, callback, callback.getExecutor(), mTestFramework.mCronetEngine);
+ urlRequestBuilder.addRequestAnnotation("request annotation")
+ .addRequestAnnotation(this)
+ .build()
+ .start();
+ callback.blockForDone();
+ mNetworkQualityExecutor.runAllTasks();
+
+ CronetEngine.UrlRequestInfo requestInfo = requestFinishedListener.mRequestInfo;
+ assertNotNull("RequestFinishedListener must be called", requestInfo);
+ assertEquals(mUrl, requestInfo.getUrl());
+ assertNotNull(requestInfo.getResponseInfo());
+ assertEquals(newHashSet("request annotation", this), // Use sets for unordered comparison.
+ new HashSet<Object>(requestInfo.getAnnotations()));
+ CronetEngine.UrlRequestMetrics metrics = requestInfo.getMetrics();
+ assertNotNull("UrlRequestInfo.getMetrics() must not be null", metrics);
+ assertTrue(metrics.getTotalTimeMs() > 0);
+ assertTrue(metrics.getTotalTimeMs() >= metrics.getTtfbMs());
+ assertTrue(metrics.getReceivedBytesCount() > 0);
+ mTestFramework.mCronetEngine.shutdown();
+ }
+
+ @SmallTest
+ @Feature({"Cronet"})
+ @SuppressWarnings("deprecation")
+ public void testRequestFinishedListener_LegacyAPI() throws Exception {
mTestFramework = startCronetTestFramework();
TestExecutor testExecutor = new TestExecutor();
TestRequestFinishedListener requestFinishedListener = new TestRequestFinishedListener();
@@ -397,6 +543,31 @@ public class CronetUrlRequestContextTest extends CronetTestBase {
@Feature({"Cronet"})
@SuppressWarnings("deprecation")
public void testRequestFinishedListenerRemoved() throws Exception {
+ CronetEngine.Builder mCronetEngineBuilder = new CronetEngine.Builder(getContext());
+ TestExecutor mNetworkQualityExecutor = new TestExecutor();
+ mCronetEngineBuilder.enableHTTP2(true).enableQUIC(false).enableNetworkQualityEstimator(
+ true, mNetworkQualityExecutor);
+ mTestFramework =
+ startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCronetEngineBuilder);
+ TestRequestFinishedListener requestFinishedListener = new TestRequestFinishedListener();
+ mTestFramework.mCronetEngine.addRequestFinishedListener(requestFinishedListener);
+ mTestFramework.mCronetEngine.removeRequestFinishedListener(requestFinishedListener);
+ TestUrlRequestCallback callback = new TestUrlRequestCallback();
+ UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder(
+ mUrl, callback, callback.getExecutor(), mTestFramework.mCronetEngine);
+ urlRequestBuilder.build().start();
+ callback.blockForDone();
+ mNetworkQualityExecutor.runAllTasks();
+
+ assertNull(
+ "RequestFinishedListener must not be called", requestFinishedListener.mRequestInfo);
+ mTestFramework.mCronetEngine.shutdown();
+ }
+
+ @SmallTest
+ @Feature({"Cronet"})
+ @SuppressWarnings("deprecation")
+ public void testRequestFinishedListenerRemoved_LegacyAPI() throws Exception {
mTestFramework = startCronetTestFramework();
TestExecutor testExecutor = new TestExecutor();
TestRequestFinishedListener requestFinishedListener = new TestRequestFinishedListener();

Powered by Google App Engine
This is Rietveld 408576698