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

Side by Side Diff: components/cronet/android/java/src/org/chromium/net/UrlRequestContext.java

Issue 1273173002: Added Network Quality Estimator Real-time interface to Cronet (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed nit from mef Created 5 years, 2 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 unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 package org.chromium.net; 5 package org.chromium.net;
6 6
7 import android.content.Context; 7 import android.content.Context;
8 import android.util.Log; 8 import android.util.Log;
9 9
10 import java.lang.reflect.Constructor; 10 import java.lang.reflect.Constructor;
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after
87 */ 87 */
88 public abstract void startNetLogToFile(String fileName, boolean logAll); 88 public abstract void startNetLogToFile(String fileName, boolean logAll);
89 89
90 /** 90 /**
91 * Stops NetLog logging and flushes file to disk. If a logging session is 91 * Stops NetLog logging and flushes file to disk. If a logging session is
92 * not in progress, this call is ignored. 92 * not in progress, this call is ignored.
93 */ 93 */
94 public abstract void stopNetLog(); 94 public abstract void stopNetLog();
95 95
96 /** 96 /**
97 * Enables the network quality estimator, which collects and reports
98 * measurements of round trip time (RTT) and downstream throughput at
99 * various layers of the network stack. After enabling the estimator,
100 * listeners of RTT and throughput can be added with
101 * {@link #addRttListener} and {@link #addThroughputListener} and
102 * removed with {@link #removeRttListener} and
103 * {@link #removeThroughputListener}. The estimator uses memory and CPU
104 * only when enabled.
105 * @param executor an executor that will be used to notified all
106 * added RTT and throughput listeners.
107 */
108 public abstract void enableNetworkQualityEstimator(Executor executor);
109
110 /**
111 * Enables the network quality estimator for testing. This must be called
112 * before round trip time and throughput listeners are added. Set both
113 * boolean parameters to false for default behavior.
114 * @param useLocalHostRequests include requests to localhost in estimates.
115 * @param useSmallerResponses include small responses in throughput estimate s.
116 * @param executor an {@link java.util.concurrent.Executor} on which all
117 * listeners will be called.
118 */
119 abstract void enableNetworkQualityEstimator(
120 boolean useLocalHostRequests, boolean useSmallerResponses, Executor executor);
121
122 /**
123 * Registers an listener that gets called whenever the network quality
124 * estimator witnesses a sample round trip time. This must be called
125 * after {@link #enableNetworkQualityEstimator}. Round trip times may be
126 * recorded at various layers of the network stack, including TCP, QUIC,
127 * and at the URL request layer. The listener is called on the
128 * {@link java.util.concurrent.Executor} that is passed to
129 * {@link #enableNetworkQualityEstimator}.
130 * @param listener the listener of round trip times.
131 */
132 public abstract void addRttListener(NetworkQualityRttListener listener);
133
134 /**
135 * Removes an listener of round trip times if on the listener list. This
136 * should be called after a NetworkQualityRttListener is added in order to
137 * stop receiving observations.
138 * @param listener the listener of round trip times.
139 */
140 public abstract void removeRttListener(NetworkQualityRttListener listener);
141
142 /**
143 * Registers an listener that gets called whenever the network quality
mef 2015/10/01 19:02:28 I'm not native speaker, but shouldn't "an listener
bengr 2015/10/01 23:14:35 Damn search and replace. Done.
144 * estimator witnesses a sample throughput measurement. This must be called
145 * after {@link #enableNetworkQualityEstimator}. Throughput observations
146 * are computed by measuring bytes read over the active network interface
147 * at times when at least one URL response is being received. The listener
148 * is called on the {@link java.util.concurrent.Executor} that is passed to
149 * {@link #enableNetworkQualityEstimator}.
150 * @param listener the listener of throughput.
151 */
152 public abstract void addThroughputListener(NetworkQualityThroughputListener listener);
153
154 /**
155 * Removes an listener of throughput. This should be called after a
156 * NetworkQualityThroughputListener is added in order to stop receiving
157 * observations.
158 * @param listener the listener of throughput.
159 */
160 public abstract void removeThroughputListener(NetworkQualityThroughputListen er listener);
161
162 /**
97 * Creates a {@link UrlRequestContext} with the given 163 * Creates a {@link UrlRequestContext} with the given
98 * {@link UrlRequestContextConfig}. 164 * {@link UrlRequestContextConfig}.
99 * @param context Android {@link Context}. 165 * @param context Android {@link Context}.
100 * @param config context configuration. 166 * @param config context configuration.
101 */ 167 */
102 public static UrlRequestContext createContext(Context context, 168 public static UrlRequestContext createContext(Context context,
103 UrlRequestContextConfig config) { 169 UrlRequestContextConfig config) {
104 UrlRequestContext urlRequestContext = null; 170 UrlRequestContext urlRequestContext = null;
105 if (config.userAgent().isEmpty()) { 171 if (config.userAgent().isEmpty()) {
106 config.setUserAgent(UserAgent.from(context)); 172 config.setUserAgent(UserAgent.from(context));
(...skipping 30 matching lines...) Expand all
137 } catch (ClassNotFoundException e) { 203 } catch (ClassNotFoundException e) {
138 // Leave as null. 204 // Leave as null.
139 } catch (Exception e) { 205 } catch (Exception e) {
140 throw new IllegalStateException( 206 throw new IllegalStateException(
141 "Cannot instantiate: " + CRONET_URL_REQUEST_CONTEXT, 207 "Cannot instantiate: " + CRONET_URL_REQUEST_CONTEXT,
142 e); 208 e);
143 } 209 }
144 return urlRequestContext; 210 return urlRequestContext;
145 } 211 }
146 } 212 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698