HandshakeCompletedEventTest.java revision 5c42f5792a0ad4159d30e7fd18958a21bf8b327f
1adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/* 2adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Licensed to the Apache Software Foundation (ASF) under one or more 3adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * contributor license agreements. See the NOTICE file distributed with 4adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * this work for additional information regarding copyright ownership. 5adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * The ASF licenses this file to You under the Apache License, Version 2.0 6adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * (the "License"); you may not use this file except in compliance with 7adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * the License. You may obtain a copy of the License at 8adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * 9adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 10adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * 11adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Unless required by applicable law or agreed to in writing, software 12adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 13adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * See the License for the specific language governing permissions and 15adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * limitations under the License. 16adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 17adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 18adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpackage tests.api.javax.net.ssl; 19adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 201cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grobimport dalvik.annotation.AndroidOnly; 21adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.io.ByteArrayInputStream; 221cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grobimport java.io.IOException; 23adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.io.InputStream; 24adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.io.OutputStream; 25adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.net.InetSocketAddress; 26adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.security.KeyStore; 27adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.security.cert.Certificate; 28adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.security.cert.CertificateException; 29adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.HandshakeCompletedEvent; 30adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.HandshakeCompletedListener; 31adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.KeyManager; 32adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.KeyManagerFactory; 33adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.SSLContext; 34adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.SSLPeerUnverifiedException; 35adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.SSLServerSocket; 36adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.SSLSession; 37adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.SSLSocket; 381cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grobimport javax.net.ssl.SSLSocketFactory; 39adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.TrustManager; 40adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.net.ssl.X509TrustManager; 41adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport javax.security.cert.X509Certificate; 42adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport junit.framework.TestCase; 43adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport org.apache.harmony.luni.util.Base64; 44adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport org.apache.harmony.xnet.tests.support.mySSLSession; 451cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grobimport tests.support.Support_PortManager; 46adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 47adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/** 48adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Tests for <code>HandshakeCompletedEvent</code> class constructors and methods. 49f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * 50adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 51adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpublic class HandshakeCompletedEventTest extends TestCase { 52f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 53adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project String certificate = "-----BEGIN CERTIFICATE-----\n" 54adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "MIICZTCCAdICBQL3AAC2MA0GCSqGSIb3DQEBAgUAMF8xCzAJBgNVBAYTAlVTMSAw\n" 55adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "HgYDVQQKExdSU0EgRGF0YSBTZWN1cml0eSwgSW5jLjEuMCwGA1UECxMlU2VjdXJl\n" 56adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "IFNlcnZlciBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw05NzAyMjAwMDAwMDBa\n" 57adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "Fw05ODAyMjAyMzU5NTlaMIGWMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv\n" 58adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "cm5pYTESMBAGA1UEBxMJUGFsbyBBbHRvMR8wHQYDVQQKExZTdW4gTWljcm9zeXN0\n" 59adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "ZW1zLCBJbmMuMSEwHwYDVQQLExhUZXN0IGFuZCBFdmFsdWF0aW9uIE9ubHkxGjAY\n" 60adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "BgNVBAMTEWFyZ29uLmVuZy5zdW4uY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB\n" 61adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "iQKBgQCofmdY+PiUWN01FOzEewf+GaG+lFf132UpzATmYJkA4AEA/juW7jSi+LJk\n" 62adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "wJKi5GO4RyZoyimAL/5yIWDV6l1KlvxyKslr0REhMBaD/3Z3EsLTTEf5gVrQS6sT\n" 63adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "WMoSZAyzB39kFfsB6oUXNtV8+UKKxSxKbxvhQn267PeCz5VX2QIDAQABMA0GCSqG\n" 64adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "SIb3DQEBAgUAA34AXl3at6luiV/7I9MN5CXYoPJYI8Bcdc1hBagJvTMcmlqL2uOZ\n" 65adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "H9T5hNMEL9Tk6aI7yZPXcw/xI2K6pOR/FrMp0UwJmdxX7ljV6ZtUZf7pY492UqwC\n" 66adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "1777XQ9UEZyrKJvF5ntleeO0ayBqLGVKCWzWZX9YsXCpv47FNLZbupE=\n" 67adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "-----END CERTIFICATE-----\n"; 68adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 69adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 70adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 71f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 72229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#HandshakeCompletedEvent(SSLSocket sock, SSLSession s) 73adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 745c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_Constructor() throws Exception { 751cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob mySSLSession session = new mySSLSession(); 761cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 775c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 78adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 795c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom new HandshakeCompletedEvent(null, null); 80adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("Any exception wasn't thrown for null parameters"); 815c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (Exception expected) { 82adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 83adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 84f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 85adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 86f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 87229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getCipherSuite() 88adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 895c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getCipherSuite() throws Exception { 90adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 911cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 92adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 935c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals("SuiteName", event.getCipherSuite()); 94adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 95f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 96adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 97f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 98229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getLocalCertificates() 99adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1005c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getLocalCertificates() throws Exception { 101adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1021cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 103adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1045c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getLocalCertificates()); 105adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 106f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 107adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 108f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 109229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getLocalPrincipal() 110adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1115c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getLocalPrincipal() throws Exception { 112adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1131cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 114adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1155c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getLocalPrincipal()); 116adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 117f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 118adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 119f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 120229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerCertificateChain() 121adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1225c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getPeerCertificateChain() throws Exception { 123adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project ByteArrayInputStream bis = new ByteArrayInputStream(certificate.getBytes()); 1241cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob mySSLSession session = new mySSLSession((X509Certificate[]) null); 1251cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 126adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 127adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 1285c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event.getPeerCertificateChain(); 129adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("SSLPeerUnverifiedException wasn't thrown"); 1305c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (SSLPeerUnverifiedException expected) { 131adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 132f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 1335c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate xc = X509Certificate.getInstance(bis); 1345c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate[] xcs = {xc}; 1355c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom session = new mySSLSession(xcs); 1365c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event = new HandshakeCompletedEvent(socket, session); 1375c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 1385c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate[] res = event.getPeerCertificateChain(); 1395c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(1, res.length); 140adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 141f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 142adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 143f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 144229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerCertificates() 145adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1461cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getPeerCertificates() throws IOException { 147adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1481cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 149adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 150adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 1515c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event.getPeerCertificates(); 152adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("SSLPeerUnverifiedException wasn't thrown"); 1535c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (SSLPeerUnverifiedException expected) { 154adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 155f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 1561cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob session = new mySSLSession((X509Certificate[]) null); 157adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project event = new HandshakeCompletedEvent(socket, session); 1585c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Certificate[] res = event.getPeerCertificates(); 1595c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(3, res.length); 160adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 161f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 162adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 163f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 164229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerPrincipal() 165adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1661cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getPeerPrincipal() throws IOException { 167adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1681cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 169adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1705c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getPeerPrincipal()); 171adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 172f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 173adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 174f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 175229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getSession() 176adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1771cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getSession() throws IOException { 178adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1791cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 180adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1815c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom SSLSession ss = event.getSession(); 1825c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNotNull(ss); 1835c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(session, ss); 184adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 185f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 186adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 187f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 188229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getSocket() 189adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1901cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getSocket() throws IOException { 1911cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 1921cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, null); 1935c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom SSLSocket ss = event.getSocket(); 1945c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNotNull(ss); 1955c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(socket, ss); 196adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 197f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 198f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 199adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project // Regression test for CompletedHandshakeEvent not firing with a custom 200adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project // TrustManager 201f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 202adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 203adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLSocket socket; 204adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLSocket serverSocket; 205adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project MyHandshakeListener listener; 2061cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob int port = Support_PortManager.getNextPort(); 207adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project String host = "localhost"; 208f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 209adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private String PASSWORD = "android"; 210adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 211f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 212adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the server, BKS version. Holds just a 213adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Server". 214adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 215f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String SERVER_KEYS_BKS = 2165c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "AAAAAQAAABQDkebzoP1XwqyWKRCJEpn/t8dqIQAABDkEAAVteWtleQAAARpYl20nAAAAAQAFWC41" 2175c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJNMIICSTCCAbKgAwIBAgIESEfU1jANBgkqhkiG9w0BAQUFADBpMQswCQYDVQQGEwJVUzET" 2185c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8wDQYDVQQKEwZHb29nbGUxEDAOBgNV" 2195c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgU2VydmVyMB4XDTA4MDYwNTExNTgxNFoXDTA4MDkw" 2205c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MzExNTgxNFowaTELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01U" 2215c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdBbmRyb2lkMRQwEgYDVQQDEwtUZXN0IFNlcnZl" 2225c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "cjCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEA0LIdKaIr9/vsTq8BZlA3R+NFWRaH4lGsTAQy" 2235c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DPMF9ZqEDOaL6DJuu0colSBBBQ85hQTPa9m9nyJoN3pEi1hgamqOvQIWcXBk+SOpUGRZZFXwniJV" 2245c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "zDKU5nE9MYgn2B9AoiH3CSuMz6HRqgVaqtppIe1jhukMc/kHVJvlKRNy9XMCAwEAATANBgkqhkiG" 2255c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "9w0BAQUFAAOBgQC7yBmJ9O/eWDGtSH9BH0R3dh2NdST3W9hNZ8hIa8U8klhNHbUCSSktZmZkvbPU" 2265c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "hse5LI3dh6RyNDuqDrbYwcqzKbFJaq/jX9kCoeb3vgbQElMRX8D2ID1vRjxwlALFISrtaN4VpWzV" 2275c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "yeoHPW4xldeZmoVtjn8zXNzQhLuBqX2MmAAAAqwAAAAUvkUScfw9yCSmALruURNmtBai7kQAAAZx" 2285c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "4Jmijxs/l8EBaleaUru6EOPioWkUAEVWCxjM/TxbGHOi2VMsQWqRr/DZ3wsDmtQgw3QTrUK666sR" 2295c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBnbqdnyCyvM1J2V1xxLXPUeRBmR2CXorYGF9Dye7NkgVdfA+9g9L/0Au6Ugn+2Cj5leoIgkgApN" 2305c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "vuEcZegFlNOUPVEs3SlBgUF1BY6OBM0UBHTPwGGxFBBcetcuMRbUnu65vyDG0pslT59qpaR0TMVs" 2315c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "P+tcheEzhyjbfM32/vwhnL9dBEgM8qMt0sqF6itNOQU/F4WGkK2Cm2v4CYEyKYw325fEhzTXosck" 2325c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MhbqmcyLab8EPceWF3dweoUT76+jEZx8lV2dapR+CmczQI43tV9btsd1xiBbBHAKvymm9Ep9bPzM" 2335c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "J0MQi+OtURL9Lxke/70/MRueqbPeUlOaGvANTmXQD2OnW7PISwJ9lpeLfTG0LcqkoqkbtLKQLYHI" 2345c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rQfV5j0j+wmvmpMxzjN3uvNajLa4zQ8l0Eok9SFaRr2RL0gN8Q2JegfOL4pUiHPsh64WWya2NB7f" 2355c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "V+1s65eA5ospXYsShRjo046QhGTmymwXXzdzuxu8IlnTEont6P4+J+GsWk6cldGbl20hctuUKzyx" 2365c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "OptjEPOKejV60iDCYGmHbCWAzQ8h5MILV82IclzNViZmzAapeeCnexhpXhWTs+xDEYSKEiG/camt" 2375c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "bhmZc3BcyVJrW23PktSfpBQ6D8ZxoMfF0L7V2GQMaUg+3r7ucrx82kpqotjv0xHghNIm95aBr1Qw" 2385c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1gaEjsC/0wGmmBDg1dTDH+F1p9TInzr3EFuYD0YiQ7YlAHq3cPuyGoLXJ5dXYuSBfhDXJSeddUkl" 2395c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "k1ufZyOOcskeInQge7jzaRfmKg3U94r+spMEvb0AzDQVOKvjjo1ivxMSgFRZaDb/4qw="; 240adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 241f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 242adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the server, JKS version. Holds just a 243adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Server". 244adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 245f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String SERVER_KEYS_JKS = 2465c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "/u3+7QAAAAIAAAABAAAAAQAFbXlrZXkAAAEaWFfBeAAAArowggK2MA4GCisGAQQBKgIRAQEFAASC" 2475c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "AqI2kp5XjnF8YZkhcF92YsJNQkvsmH7zqMM87j23zSoV4DwyE3XeC/gZWq1ToScIhoqZkzlbWcu4" 2485c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "T/Zfc/DrfGk/rKbBL1uWKGZ8fMtlZk8KoAhxZk1JSyJvdkyKxqmzUbxk1OFMlN2VJNu97FPVH+du" 2495c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "dvjTvmpdoM81INWBW/1fZJeQeDvn4mMbbe0IxgpiLnI9WSevlaDP/sm1X3iO9yEyzHLL+M5Erspo" 2505c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "Cwa558fOu5DdsICMXhvDQxjWFKFhPHnKtGe+VvwkG9/bAaDgx3kfhk0w5zvdnkKb+8Ed9ylNRzdk" 2515c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ocAa/mxlMTOsTvDKXjjsBupNPIIj7OP4GNnZaxkJjSs98pEO67op1GX2qhy6FSOPNuq8k/65HzUc" 2525c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "PYn6voEeh6vm02U/sjEnzRevQ2+2wXoAdp0EwtQ/DlMe+NvcwPGWKuMgX4A4L93DZGb04N2VmAU3" 2535c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "YLOtZwTO0LbuWrcCM/q99G/7LcczkxIVrO2I/rh8RXVczlf9QzcrFObFv4ATuspWJ8xG7DhsMbnk" 2545c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rT94Pq6TogYeoz8o8ZMykesAqN6mt/9+ToIemmXv+e+KU1hI5oLwWMnUG6dXM6hIvrULY6o+QCPH" 2555c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "172YQJMa+68HAeS+itBTAF4Clm/bLn6reHCGGU6vNdwU0lYldpiOj9cB3t+u2UuLo6tiFWjLf5Zs" 2565c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "EQJETd4g/EK9nHxJn0GAKrWnTw7pEHQJ08elzUuy04C/jEEG+4QXU1InzS4o/kR0Sqz2WTGDoSoq" 2575c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ewuPRU5bzQs/b9daq3mXrnPtRBL6HfSDAdpTK76iHqLCGdqx3avHjVSBm4zFvEuYBCev+3iKOBmg" 2585c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "yh7eQRTjz4UOWfy85omMBr7lK8PtfVBDzOXpasxS0uBgdUyBDX4tO6k9jZ8a1kmQRQAAAAEABVgu" 2595c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NTA5AAACSDCCAkQwggGtAgRIR8SKMA0GCSqGSIb3DQEBBAUAMGkxCzAJBgNVBAYTAlVTMRMwEQYD" 2605c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VQQIEwpDYWxpZm9ybmlhMQwwCgYDVQQHEwNNVFYxDzANBgNVBAoTBkdvb2dsZTEQMA4GA1UECxMH" 2615c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "QW5kcm9pZDEUMBIGA1UEAxMLVGVzdCBTZXJ2ZXIwHhcNMDgwNjA1MTA0ODQyWhcNMDgwOTAzMTA0" 2625c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ODQyWjBpMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8w" 2635c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DQYDVQQKEwZHb29nbGUxEDAOBgNVBAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgU2VydmVyMIGf" 2645c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCwoC6chqCI84rj1PrXuJgbiit4EV909zR6N0jNlYfg" 2655c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "itwB39bP39wH03rFm8T59b3mbSptnGmCIpLZn25KPPFsYD3JJ+wFlmiUdEP9H05flfwtFQJnw9uT" 2665c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "3rRIdYVMPcQ3RoZzwAMliGr882I2thIDbA6xjGU/1nRIdvk0LtxH3QIDAQABMA0GCSqGSIb3DQEB" 2675c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAUAA4GBAJn+6YgUlY18Ie+0+Vt8oEi81DNi/bfPrAUAh63fhhBikx/3R9dl3wh09Z6p7cIdNxjW" 2685c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "n2ll+cRW9eqF7z75F0Omm0C7/KAEPjukVbszmzeU5VqzkpSt0j84YWi+TfcHRrfvhLbrlmGITVpY" 2695c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ol5pHLDyqGmDs53pgwipWqsn/nEXEBgj3EoqPeqHbDf7YaP8h/5BSt0="; 270f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 271f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 272adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the client, JKS version. Holds just a 273adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Client". 274adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 275f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String CLIENT_KEYS_JKS = 2765c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "/u3+7QAAAAIAAAABAAAAAQAFbXlrZXkAAAEaWFhyMAAAArkwggK1MA4GCisGAQQBKgIRAQEFAASC" 2775c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "AqGVSfXolBStZy4nnRNn4fAr+S7kfU2BS23wwW8uB2Ru3GvtLzlK9q08Gvq/LNqBafjyFTVL5FV5" 2785c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "SED/8YomO5a98GpskSeRvytCiTBLJdgGhws5TOGekgIAcBROPGIyOtJPQ0HfOQs+BqgzGDHzHQhw" 2795c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "u/8Tm6yQwiP+W/1I9B1QnaEztZA3mhTyMMJsmsFTYroGgAog885D5Cmzd8sYGfxec3R6I+xcmBAY" 2805c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "eibR5kGpWwt1R+qMvRrtBqh5r6WSKhCBNax+SJVbtUNRiKyjKccdJg6fGqIWWeivwYTy0OhjA6b4" 2815c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NiZ/ZZs5pxFGWUj/Rlp0RYy8fCF6aw5/5s4Bf4MI6dPSqMG8Hf7sJR91GbcELyzPdM0h5lNavgit" 2825c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "QPEzKeuDrGxhY1frJThBsNsS0gxeu+OgfJPEb/H4lpYX5IvuIGbWKcxoO9zq4/fimIZkdA8A+3eY" 2835c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "mfDaowvy65NBVQPJSxaOyFhLHfeLqOeCsVENAea02vA7andZHTZehvcrqyKtm+z8ncHGRC2H9H8O" 2845c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "jKwKHfxxrYY/jMAKLl00+PBb3kspO+BHI2EcQnQuMw/zr83OR9Meq4TJ0TMuNkApZELAeFckIBbS" 2855c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rBr8NNjAIfjuCTuKHhsTFWiHfk9ZIzigxXagfeDRiyVc6khOuF/bGorj23N2o7Rf3uLoU6PyXWi4" 2865c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "uhctR1aL6NzxDoK2PbYCeA9hxbDv8emaVPIzlVwpPK3Ruvv9mkjcOhZ74J8bPK2fQmbplbOljcZi" 2875c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "tZijOfzcO/11JrwhuJZRA6wanTqHoujgChV9EukVrmbWGGAcewFnAsSbFXIik7/+QznXaDIt5NgL" 2885c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "H/Bcz4Z/fdV7Ae1eUaxKXdPbI//4J+8liVT/d8awjW2tldIaDlmGMR3aoc830+3mAAAAAQAFWC41" 2895c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJIMIICRDCCAa0CBEhHxLgwDQYJKoZIhvcNAQEEBQAwaTELMAkGA1UEBhMCVVMxEzARBgNV" 2905c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01UVjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdB" 2915c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "bmRyb2lkMRQwEgYDVQQDEwtUZXN0IENsaWVudDAeFw0wODA2MDUxMDQ5MjhaFw0wODA5MDMxMDQ5" 2925c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MjhaMGkxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMQwwCgYDVQQHEwNNVFYxDzAN" 2935c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BgNVBAoTBkdvb2dsZTEQMA4GA1UECxMHQW5kcm9pZDEUMBIGA1UEAxMLVGVzdCBDbGllbnQwgZ8w" 2945c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAIK3Q+KiFbmCGg422TAo4gggdhMH6FJhiuz8DxRyeMKR" 2955c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "UAfP4MK0wtc8N42waZ6OKvxpBFUy0BRfBsX0GD4Ku99yu9/tavSigTraeJtwV3WWRRjIqk7L3wX5" 2965c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "cmgS2KSD43Y0rNUKrko26lnt9N4qiYRBSj+tcAN3Lx9+ptqk1LApAgMBAAEwDQYJKoZIhvcNAQEE" 2975c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BQADgYEANb7Q1GVSuy1RPJ0FmiXoMYCCtvlRLkmJphwxovK0cAQK12Vll+yAzBhHiQHy/RA11mng" 2985c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "wYudC7u3P8X/tBT8GR1Yk7QW3KgFyPafp3lQBBCraSsfrjKj+dCLig1uBLUr4f68W8VFWZWWTHqp" 2995c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NMGpCX6qmjbkJQLVK/Yfo1ePaUexPSOX0G9m8+DoV3iyNw6at01NRw=="; 300adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 301f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 302adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the client, BKS version. Holds just a 303adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Client". 304adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 305f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String CLIENT_KEYS_BKS = 3065c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "AAAAAQAAABT4Rka6fxbFps98Y5k2VilmbibNkQAABfQEAAVteWtleQAAARpYl+POAAAAAQAFWC41" 3075c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJNMIICSTCCAbKgAwIBAgIESEfU9TANBgkqhkiG9w0BAQUFADBpMQswCQYDVQQGEwJVUzET" 3085c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8wDQYDVQQKEwZHb29nbGUxEDAOBgNV" 3095c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgQ2xpZW50MB4XDTA4MDYwNTExNTg0NVoXDTA4MDkw" 3105c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MzExNTg0NVowaTELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01U" 3115c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdBbmRyb2lkMRQwEgYDVQQDEwtUZXN0IENsaWVu" 3125c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "dDCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEApUvmWsQDHPpbDKK13Yez2/q54tTOmRml/qva" 3135c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "2K6dZjkjSTW0iRuk7ztaVEvdJpfVIDv1oBsCI51ttyLHROy1epjF+GoL74mJb7fkcd0VOoSOTjtD" 3145c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "+3GgZkHPAm5YmUYxiJXqxKKJJqMCTIW46eJaA2nAep9QIwZ14/NFAs4ObV8CAwEAATANBgkqhkiG" 3155c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "9w0BAQUFAAOBgQCJrCr3hZQFDlLIfsSKI1/w+BLvyf4fubOid0pBxfklR8KBNPTiqjSmu7pd/C/F" 3165c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1FR8CdZUDoPflZHCOU+fj5r5KUC1HyigY/tEUvlforBpfB0uCF+tXW4DbUfOWhfMtLV4nCOJOOZg" 3175c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "awfZLJWBJouLKOp427vDftxTSB+Ks8YjlgAAAqwAAAAU+NH6TtrzjyDdCXm5B6Vo7xX5G4YAAAZx" 3185c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "EAUkcZtmykn7YdaYxC1jRFJ+GEJpC8nZVg83QClVuCSIS8a5f8Hl44Bk4oepOZsPzhtz3RdVzDVi" 3195c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "RFfoyZFsrk9F5bDTVJ6sQbb/1nfJkLhZFXokka0vND5AXMSoD5Bj1Fqem3cK7fSUyqKvFoRKC3XD" 3205c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "FQvhqoam29F1rbl8FaYdPvhhZo8TfZQYUyUKwW+RbR44M5iHPx+ykieMe/C/4bcM3z8cwIbYI1aO" 3215c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "gjQKS2MK9bs17xaDzeAh4sBKrskFGrDe+2dgvrSKdoakJhLTNTBSG6m+rzqMSCeQpafLKMSjTSSz" 3225c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "+KoQ9bLyax8cbvViGGju0SlVhquloZmKOfHr8TukIoV64h3uCGFOVFtQjCYDOq6NbfRvMh14UVF5" 3235c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "zgDIGczoD9dMoULWxBmniGSntoNgZM+QP6Id7DBasZGKfrHIAw3lHBqcvB5smemSu7F4itRoa3D8" 3245c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "N7hhUEKAc+xA+8NKmXfiCBoHfPHTwDvt4IR7gWjeP3Xv5vitcKQ/MAfO5RwfzkYCXQ3FfjfzmsE1" 3255c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1IfLRDiBj+lhQSulhRVStKI88Che3M4JUNGKllrc0nt1pWa1vgzmUhhC4LSdm6trTHgyJnB6OcS9" 3265c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "t2furYjK88j1AuB4921oxMxRm8c4Crq8Pyuf+n3YKi8Pl2BzBtw++0gj0ODlgwut8SrVj66/nvIB" 3275c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "jN3kLVahR8nZrEFF6vTTmyXi761pzq9yOVqI57wJGx8o3Ygox1p+pWUPl1hQR7rrhUbgK/Q5wno9" 3285c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "uJk07h3IZnNxE+/IKgeMTP/H4+jmyT4mhsexJ2BFHeiKF1KT/FMcJdSi+ZK5yoNVcYuY8aZbx0Ef" 3295c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "lHorCXAmLFB0W6Cz4KPP01nD9YBB4olxiK1t7m0AU9zscdivNiuUaB5OIEr+JuZ6dNw="; 330adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 331adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 332adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 333adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements the actual test case. Launches a server and a client, requires 334adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * client authentication and checks the certificates afterwards (not in the 335adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * usual sense, we just make sure that we got the expected certificates, 336adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * because our self-signed test certificates are not valid.) 337adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 338f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 3391cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob @AndroidOnly("Uses bks key store. Change useBKS to false to run on the RI") 3405c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public void testClientAuth() throws Exception { 3411cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob 3421cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob boolean useBKS = true; 3431cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob 344adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project listener = new MyHandshakeListener(); 3455c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom String serverKeys = (useBKS ? SERVER_KEYS_BKS : SERVER_KEYS_JKS); 3465c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom String clientKeys = (useBKS ? CLIENT_KEYS_BKS : CLIENT_KEYS_JKS); 3475c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestServer server = new TestServer(true, 3485c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestServer.CLIENT_AUTH_WANTED, serverKeys); 3495c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestClient client = new TestClient(true, clientKeys); 3505c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3515c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread serverThread = new Thread(server); 3525c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread clientThread = new Thread(client); 3535c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3545c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom serverThread.start(); 3555c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread.currentThread().sleep(3000); 3565c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom clientThread.start(); 3575c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3585c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom serverThread.join(); 3595c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom clientThread.join(); 3605c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3615c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom // The server must have completed without an exception. 3625c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Exception e = server.getException(); 3635c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom if (e != null) { 3645c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e.printStackTrace(); 3655c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } 366adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3675c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom // The client must have completed without an exception. 3685c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e = client.getException(); 3695c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom if (e != null) { 3705c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e.printStackTrace(); 3715c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } 372f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 3735c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(e); 374adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3755c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertTrue(listener.completeDone); 376adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 377f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 378f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 379adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements a test SSL socket server. It wait for a connection on a given 380ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * port, requests client authentication (if specified), reads 256 bytes 381ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * from the socket, and writes 256 bytes to the socket. 382adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 383adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class TestServer implements Runnable { 384adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 385adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_NONE = 0; 386adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 387adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_WANTED = 1; 388adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 389adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_NEEDED = 2; 390f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 391adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private TestTrustManager trustManager; 392adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 393adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private Exception exception; 394adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3951cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob String keys; 396f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 397adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private int clientAuth; 398f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 399adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private boolean provideKeys; 400adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 4011cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public TestServer(boolean provideKeys, int clientAuth, String keys) { 4021cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob this.keys = keys; 403adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.clientAuth = clientAuth; 404adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.provideKeys = provideKeys; 405f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 406f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes trustManager = new TestTrustManager(); 407adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 408f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 409adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void run() { 410adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 4111cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob KeyManager[] keyManagers = provideKeys ? getKeyManagers(keys) : null; 412adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project TrustManager[] trustManagers = new TrustManager[] { trustManager }; 413adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 414adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLContext sslContext = SSLContext.getInstance("TLS"); 415adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project sslContext.init(keyManagers, trustManagers, null); 416f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 4175c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom SSLServerSocket serverSocket = (SSLServerSocket) 4185c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom sslContext.getServerSocketFactory().createServerSocket(); 419f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 420adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project if (clientAuth == CLIENT_AUTH_WANTED) { 421adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project serverSocket.setWantClientAuth(true); 422adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } else if (clientAuth == CLIENT_AUTH_NEEDED) { 423adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project serverSocket.setNeedClientAuth(true); 424adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } else { 425adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project serverSocket.setWantClientAuth(false); 426adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 427f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 428adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project serverSocket.bind(new InetSocketAddress(port)); 429f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 430adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLSocket clientSocket = (SSLSocket)serverSocket.accept(); 431adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 432ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu InputStream istream = clientSocket.getInputStream(); 433adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 434adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project for (int i = 0; i < 256; i++) { 435ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu int j = istream.read(); 4365c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(i, j); 437adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 438f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 439ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu istream.close(); 440ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 441ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu OutputStream ostream = clientSocket.getOutputStream(); 442ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 443ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu for (int i = 0; i < 256; i++) { 444ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.write(i); 445ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu } 446ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 447ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.flush(); 448ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.close(); 449ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 450adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project clientSocket.close(); 451adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project serverSocket.close(); 452f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 453adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } catch (Exception ex) { 454adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project exception = ex; 455adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 456adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 457adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 458adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public Exception getException() { 459adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return exception; 460adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 461f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 462adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 463adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return trustManager.getChain(); 464adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 465f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 466adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 467adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 468f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 469adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements a test SSL socket client. It open a connection to localhost on 470ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * a given port, writes 256 bytes to the socket, and reads 256 bytes from the 471ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * socket. 472adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 473adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class TestClient implements Runnable { 474f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 475adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private TestTrustManager trustManager; 476adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 477adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private Exception exception; 478f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 4791cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob private String keys; 480f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 481adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private boolean provideKeys; 482f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 4831cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public TestClient(boolean provideKeys, String keys) { 4841cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob this.keys = keys; 485adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.provideKeys = provideKeys; 486f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 487f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes trustManager = new TestTrustManager(); 488adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 489f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 490adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void run() { 491adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 4921cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob KeyManager[] keyManagers = provideKeys ? getKeyManagers(keys) : null; 493adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project TrustManager[] trustManagers = new TrustManager[] { trustManager }; 494adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 495adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLContext sslContext = SSLContext.getInstance("TLS"); 496adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project sslContext.init(keyManagers, trustManagers, null); 497f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 498adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLSocket socket = (SSLSocket)sslContext.getSocketFactory().createSocket(); 499adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 500adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.connect(new InetSocketAddress(port)); 501adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.addHandshakeCompletedListener(listener); 502adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.startHandshake(); 503adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 504ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu OutputStream ostream = socket.getOutputStream(); 505f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 506adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project for (int i = 0; i < 256; i++) { 507ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.write(i); 508adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 509f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 510ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.flush(); 511ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.close(); 512ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 513ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu InputStream istream = socket.getInputStream(); 514ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 515ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu for (int i = 0; i < 256; i++) { 516ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu int j = istream.read(); 5175c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(i, j); 518ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu } 519ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 520ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu istream.close(); 521ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 522adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.close(); 523f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 524adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } catch (Exception ex) { 525adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project exception = ex; 526adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 527adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 528adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 529adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public Exception getException() { 530adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return exception; 531adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 532adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 533adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 534adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return trustManager.getChain(); 535adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 536adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 537f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 538adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 539adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Loads a keystore from a base64-encoded String. Returns the KeyManager[] 540adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * for the result. 541adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 542adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private KeyManager[] getKeyManagers(String keys) throws Exception { 543b1b8fbeeae579e9f49c41166bb5d9b2e60b75438Elliott Hughes byte[] bytes = Base64.decode(keys.getBytes()); 544adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project InputStream inputStream = new ByteArrayInputStream(bytes); 545f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 546adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType()); 547adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project keyStore.load(inputStream, PASSWORD.toCharArray()); 548adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project inputStream.close(); 549ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 550adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project String algorithm = KeyManagerFactory.getDefaultAlgorithm(); 551adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance(algorithm); 552adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project keyManagerFactory.init(keyStore, PASSWORD.toCharArray()); 553f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 554adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return keyManagerFactory.getKeyManagers(); 555adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 556adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 557adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 558f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 559adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements basically a dummy TrustManager. It stores the certificate 560adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * chain it sees, so it can later be queried. 561adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 562051f400949489d012498f575c0a40999ad7a4f54Jorg Pleumann public static class TestTrustManager implements X509TrustManager { 563f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 564adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private X509Certificate[] chain; 565f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 566adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private String authType; 567f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 568adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkClientTrusted(X509Certificate[] chain, String authType) { 569adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.chain = chain; 570adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.authType = authType; 571adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 572adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 573adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkServerTrusted(X509Certificate[] chain, String authType) { 574adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.chain = chain; 575adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.authType = authType; 576adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 577adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 578adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public java.security.cert.X509Certificate[] getAcceptedIssuers() { 579adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return new java.security.cert.X509Certificate[0]; 580adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 581adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 582adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 583adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return chain; 584adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 585f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 586adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public String getAuthType() { 587adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return authType; 588adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 589adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 590adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkClientTrusted( 591adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project java.security.cert.X509Certificate[] chain, String authType) 592adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project throws CertificateException { 593f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 594adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 595adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 596adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkServerTrusted( 597adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project java.security.cert.X509Certificate[] chain, String authType) 598adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project throws CertificateException { 599f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 600adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 601f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 602adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 603adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 604adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class MyHandshakeListener implements HandshakeCompletedListener { 605adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 606adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public boolean completeDone; 607adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 608adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project MyHandshakeListener() { 609adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project completeDone = false; 610adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 611adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 612adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void handshakeCompleted(HandshakeCompletedEvent event) { 613adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project if (event != null) completeDone = true; 614adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 615adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 616adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project} 617