diff options
author | Neil Fuller <nfuller@google.com> | 2015-08-04 09:54:38 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2015-08-04 09:54:38 +0000 |
commit | c1c9f15edfbc1f86b679c90f963e9eb852ad9c53 (patch) | |
tree | be66077ab77eae8561eabffc0ba4c78c2b288739 /luni | |
parent | d7e7b6265a82c3cb859bd2e1d4c3c8eb1a80216b (diff) | |
parent | 3a6966a3b9ed3152fe8a684b63c38a432b5cdfd3 (diff) | |
download | libcore-c1c9f15edfbc1f86b679c90f963e9eb852ad9c53.zip libcore-c1c9f15edfbc1f86b679c90f963e9eb852ad9c53.tar.gz libcore-c1c9f15edfbc1f86b679c90f963e9eb852ad9c53.tar.bz2 |
am 3a6966a3: am 8426987b: Merge "Revert "Changes associated with an OkHttp bad proxy response fix"" into lollipop-cts-dev automerge: 34d183b
* commit '3a6966a3b9ed3152fe8a684b63c38a432b5cdfd3':
Revert "Changes associated with an OkHttp bad proxy response fix"
Diffstat (limited to 'luni')
-rw-r--r-- | luni/src/test/java/libcore/java/net/URLConnectionTest.java | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/luni/src/test/java/libcore/java/net/URLConnectionTest.java b/luni/src/test/java/libcore/java/net/URLConnectionTest.java index c09939f..f664b08 100644 --- a/luni/src/test/java/libcore/java/net/URLConnectionTest.java +++ b/luni/src/test/java/libcore/java/net/URLConnectionTest.java @@ -642,32 +642,42 @@ public final class URLConnectionTest extends AbstractResourceLeakageDetectorTest * Tolerate bad https proxy response when using HttpResponseCache. http://b/6754912 */ public void testConnectViaHttpProxyToHttpsUsingBadProxyAndHttpResponseCache() throws Exception { + ProxyConfig proxyConfig = ProxyConfig.PROXY_SYSTEM_PROPERTY; + TestSSLContext testSSLContext = TestSSLContext.create(); initResponseCache(); server.useHttps(testSSLContext.serverContext.getSocketFactory(), true); - - // The inclusion of a body in the response to the CONNECT is key to reproducing b/6754912. MockResponse badProxyResponse = new MockResponse() .setSocketPolicy(SocketPolicy.UPGRADE_TO_SSL_AT_END) .clearHeaders() - .setBody("bogus proxy connect response content"); + .setBody("bogus proxy connect response content"); // Key to reproducing b/6754912 + // We enqueue the bad response twice because the connection will + // be retried with TLS_MODE_COMPATIBLE after the first connection + // fails. + server.enqueue(badProxyResponse); server.enqueue(badProxyResponse); - server.enqueue(new MockResponse().setBody("response")); server.play(); URL url = new URL("https://android.com/foo"); - ProxyConfig proxyConfig = ProxyConfig.PROXY_SYSTEM_PROPERTY; HttpsURLConnection connection = (HttpsURLConnection) proxyConfig.connect(server, url); connection.setSSLSocketFactory(testSSLContext.clientContext.getSocketFactory()); - connection.setHostnameVerifier(new RecordingHostnameVerifier()); - assertContent("response", connection); + + try { + connection.connect(); + fail(); + } catch (SSLHandshakeException expected) { + // Thrown when the connect causes SSLSocket.startHandshake() to throw + // when it sees the "bogus proxy connect response content" + // instead of a ServerHello handshake message. + } RecordedRequest connect = server.takeRequest(); - assertEquals("CONNECT android.com:443 HTTP/1.1", connect.getRequestLine()); + assertEquals("Connect line failure on proxy", + "CONNECT android.com:443 HTTP/1.1", connect.getRequestLine()); assertContains(connect.getHeaders(), "Host: android.com"); } |