Merge "Fix android.net.SSLTest" am: ef43ea3238

am: 60b828ca86

Change-Id: I482bd9734f62ba1554e0d7e0bf889b23450303ee
This commit is contained in:
Remi NGUYEN VAN
2018-05-09 19:31:38 -07:00
committed by android-build-merger
2 changed files with 20 additions and 32 deletions

View File

@@ -19,11 +19,13 @@ package android.net;
import android.os.SystemProperties;
import android.util.Log;
import com.android.internal.annotations.VisibleForTesting;
import com.android.internal.os.RoSystemProperties;
import com.android.org.conscrypt.Conscrypt;
import com.android.org.conscrypt.OpenSSLContextImpl;
import com.android.org.conscrypt.OpenSSLSocketImpl;
import com.android.org.conscrypt.SSLClientSessionCache;
import java.io.IOException;
import java.net.InetAddress;
import java.net.Socket;
@@ -31,6 +33,7 @@ import java.net.SocketException;
import java.security.KeyManagementException;
import java.security.PrivateKey;
import java.security.cert.X509Certificate;
import javax.net.SocketFactory;
import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
@@ -311,8 +314,10 @@ public class SSLCertificateSocketFactory extends SSLSocketFactory {
/**
* Returns an array containing the concatenation of length-prefixed byte
* strings.
* @hide
*/
static byte[] toLengthPrefixedList(byte[]... items) {
@VisibleForTesting
public static byte[] toLengthPrefixedList(byte[]... items) {
if (items.length == 0) {
throw new IllegalArgumentException("items.length == 0");
}

View File

@@ -16,39 +16,19 @@
package android.net;
import android.test.suitebuilder.annotation.Suppress;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import android.support.test.runner.AndroidJUnit4;
import org.junit.Test;
import org.junit.runner.RunWith;
import java.util.Arrays;
import junit.framework.TestCase;
public class SSLTest extends TestCase {
//This test relies on network resources.
@Suppress
public void testCertificate() throws Exception {
// test www.fortify.net/sslcheck.html
Socket ssl = SSLCertificateSocketFactory.getDefault().createSocket("www.fortify.net",443);
assertNotNull(ssl);
OutputStream out = ssl.getOutputStream();
assertNotNull(out);
InputStream in = ssl.getInputStream();
assertNotNull(in);
String get = "GET /sslcheck.html HTTP/1.1\r\nHost: 68.178.217.222\r\n\r\n";
// System.out.println("going for write...");
out.write(get.getBytes());
byte[] b = new byte[1024];
// System.out.println("going for read...");
int ret = in.read(b);
// System.out.println(new String(b));
}
@RunWith(AndroidJUnit4.class)
public class SSLCertificateSocketFactoryTest {
@Test
public void testStringsToLengthPrefixedBytes() {
byte[] expected = {
6, 's', 'p', 'd', 'y', '/', '2',
@@ -59,6 +39,7 @@ public class SSLTest extends TestCase {
new byte[] { 'h', 't', 't', 'p', '/', '1', '.', '1' })));
}
@Test
public void testStringsToLengthPrefixedBytesEmptyArray() {
try {
SSLCertificateSocketFactory.toLengthPrefixedList();
@@ -67,6 +48,7 @@ public class SSLTest extends TestCase {
}
}
@Test
public void testStringsToLengthPrefixedBytesEmptyByteArray() {
try {
SSLCertificateSocketFactory.toLengthPrefixedList(new byte[0]);
@@ -75,6 +57,7 @@ public class SSLTest extends TestCase {
}
}
@Test
public void testStringsToLengthPrefixedBytesOversizedInput() {
try {
SSLCertificateSocketFactory.toLengthPrefixedList(new byte[256]);