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 18e82be46881b2ab9d64b35c0ee53fc359b5cfd18aNarayan Kamathpackage org.apache.harmony.tests.javax.net.ssl; 19adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 20adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.io.ByteArrayInputStream; 211cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grobimport java.io.IOException; 22adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.io.InputStream; 23adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.io.OutputStream; 24adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.net.InetSocketAddress; 25adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.security.KeyStore; 26adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.security.cert.Certificate; 27adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport java.security.cert.CertificateException; 287ff645482d5d10f2c15955ed812de183dead5557Tobias Thiererimport java.util.Base64; 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.xnet.tests.support.mySSLSession; 44adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 45adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/** 46adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Tests for <code>HandshakeCompletedEvent</code> class constructors and methods. 47f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * 48adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 49adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpublic class HandshakeCompletedEventTest extends TestCase { 50f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 51bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private String certificate = "-----BEGIN CERTIFICATE-----\n" 52adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "MIICZTCCAdICBQL3AAC2MA0GCSqGSIb3DQEBAgUAMF8xCzAJBgNVBAYTAlVTMSAw\n" 53adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "HgYDVQQKExdSU0EgRGF0YSBTZWN1cml0eSwgSW5jLjEuMCwGA1UECxMlU2VjdXJl\n" 54adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "IFNlcnZlciBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw05NzAyMjAwMDAwMDBa\n" 55adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "Fw05ODAyMjAyMzU5NTlaMIGWMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv\n" 56adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "cm5pYTESMBAGA1UEBxMJUGFsbyBBbHRvMR8wHQYDVQQKExZTdW4gTWljcm9zeXN0\n" 57adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "ZW1zLCBJbmMuMSEwHwYDVQQLExhUZXN0IGFuZCBFdmFsdWF0aW9uIE9ubHkxGjAY\n" 58adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "BgNVBAMTEWFyZ29uLmVuZy5zdW4uY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB\n" 59adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "iQKBgQCofmdY+PiUWN01FOzEewf+GaG+lFf132UpzATmYJkA4AEA/juW7jSi+LJk\n" 60adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "wJKi5GO4RyZoyimAL/5yIWDV6l1KlvxyKslr0REhMBaD/3Z3EsLTTEf5gVrQS6sT\n" 61adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "WMoSZAyzB39kFfsB6oUXNtV8+UKKxSxKbxvhQn267PeCz5VX2QIDAQABMA0GCSqG\n" 62adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "SIb3DQEBAgUAA34AXl3at6luiV/7I9MN5CXYoPJYI8Bcdc1hBagJvTMcmlqL2uOZ\n" 63adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "H9T5hNMEL9Tk6aI7yZPXcw/xI2K6pOR/FrMp0UwJmdxX7ljV6ZtUZf7pY492UqwC\n" 64adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "1777XQ9UEZyrKJvF5ntleeO0ayBqLGVKCWzWZX9YsXCpv47FNLZbupE=\n" 65adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "-----END CERTIFICATE-----\n"; 66adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 67adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 68adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 69f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 70229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#HandshakeCompletedEvent(SSLSocket sock, SSLSession s) 71adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 725c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_Constructor() throws Exception { 731cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob mySSLSession session = new mySSLSession(); 741cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 755c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 76adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 775c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom new HandshakeCompletedEvent(null, null); 78adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("Any exception wasn't thrown for null parameters"); 795c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (Exception expected) { 80adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 81adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 82f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 83adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 84f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 85229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getCipherSuite() 86adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 875c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getCipherSuite() throws Exception { 88adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 891cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 90adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 915c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals("SuiteName", event.getCipherSuite()); 92adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 93f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 94adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 95f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 96229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getLocalCertificates() 97adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 985c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getLocalCertificates() throws Exception { 99adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1001cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 101adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1025c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getLocalCertificates()); 103adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 104f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 105adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 106f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 107229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getLocalPrincipal() 108adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1095c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getLocalPrincipal() throws Exception { 110adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1111cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 112adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1135c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getLocalPrincipal()); 114adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 115f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 116adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 117f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 118229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerCertificateChain() 119adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1205c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getPeerCertificateChain() throws Exception { 121adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project ByteArrayInputStream bis = new ByteArrayInputStream(certificate.getBytes()); 1221cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob mySSLSession session = new mySSLSession((X509Certificate[]) null); 1231cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 124adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 125adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 1265c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event.getPeerCertificateChain(); 127adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("SSLPeerUnverifiedException wasn't thrown"); 1285c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (SSLPeerUnverifiedException expected) { 129adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 130f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 1315c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate xc = X509Certificate.getInstance(bis); 1325c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate[] xcs = {xc}; 1335c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom session = new mySSLSession(xcs); 1345c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event = new HandshakeCompletedEvent(socket, session); 1355c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 1365c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate[] res = event.getPeerCertificateChain(); 1375c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(1, res.length); 138adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 139f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 140adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 141f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 142229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerCertificates() 143adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1441cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getPeerCertificates() throws IOException { 145adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1461cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 147adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 148adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 1495c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event.getPeerCertificates(); 150adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("SSLPeerUnverifiedException wasn't thrown"); 1515c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (SSLPeerUnverifiedException expected) { 152adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 153f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 1541cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob session = new mySSLSession((X509Certificate[]) null); 155adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project event = new HandshakeCompletedEvent(socket, session); 1565c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Certificate[] res = event.getPeerCertificates(); 1575c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(3, res.length); 158adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 159f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 160adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 161f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 162229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerPrincipal() 163adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1641cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getPeerPrincipal() throws IOException { 165adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1661cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 167adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1685c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getPeerPrincipal()); 169adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 170f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 171adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 172f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 173229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getSession() 174adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1751cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getSession() throws IOException { 176adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1771cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 178adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1795c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom SSLSession ss = event.getSession(); 1805c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNotNull(ss); 1815c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(session, ss); 182adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 183f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 184adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 185f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 186229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getSocket() 187adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1881cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getSocket() throws IOException { 1891cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 1901cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, null); 1915c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom SSLSocket ss = event.getSocket(); 1925c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNotNull(ss); 1935c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(socket, ss); 194adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 195f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 196f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 197adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project // Regression test for CompletedHandshakeEvent not firing with a custom 198adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project // TrustManager 199f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 200adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 201bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private SSLSocket socket; 202bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private SSLServerSocket serverSocket; 203bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private MyHandshakeListener listener; 204bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private String host = "localhost"; 205f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 206adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private String PASSWORD = "android"; 207adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 208f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 209adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the server, BKS version. Holds just a 210adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Server". 211adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 212f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String SERVER_KEYS_BKS = 2135c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "AAAAAQAAABQDkebzoP1XwqyWKRCJEpn/t8dqIQAABDkEAAVteWtleQAAARpYl20nAAAAAQAFWC41" 2145c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJNMIICSTCCAbKgAwIBAgIESEfU1jANBgkqhkiG9w0BAQUFADBpMQswCQYDVQQGEwJVUzET" 2155c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8wDQYDVQQKEwZHb29nbGUxEDAOBgNV" 2165c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgU2VydmVyMB4XDTA4MDYwNTExNTgxNFoXDTA4MDkw" 2175c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MzExNTgxNFowaTELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01U" 2185c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdBbmRyb2lkMRQwEgYDVQQDEwtUZXN0IFNlcnZl" 2195c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "cjCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEA0LIdKaIr9/vsTq8BZlA3R+NFWRaH4lGsTAQy" 2205c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DPMF9ZqEDOaL6DJuu0colSBBBQ85hQTPa9m9nyJoN3pEi1hgamqOvQIWcXBk+SOpUGRZZFXwniJV" 2215c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "zDKU5nE9MYgn2B9AoiH3CSuMz6HRqgVaqtppIe1jhukMc/kHVJvlKRNy9XMCAwEAATANBgkqhkiG" 2225c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "9w0BAQUFAAOBgQC7yBmJ9O/eWDGtSH9BH0R3dh2NdST3W9hNZ8hIa8U8klhNHbUCSSktZmZkvbPU" 2235c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "hse5LI3dh6RyNDuqDrbYwcqzKbFJaq/jX9kCoeb3vgbQElMRX8D2ID1vRjxwlALFISrtaN4VpWzV" 2245c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "yeoHPW4xldeZmoVtjn8zXNzQhLuBqX2MmAAAAqwAAAAUvkUScfw9yCSmALruURNmtBai7kQAAAZx" 2255c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "4Jmijxs/l8EBaleaUru6EOPioWkUAEVWCxjM/TxbGHOi2VMsQWqRr/DZ3wsDmtQgw3QTrUK666sR" 2265c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBnbqdnyCyvM1J2V1xxLXPUeRBmR2CXorYGF9Dye7NkgVdfA+9g9L/0Au6Ugn+2Cj5leoIgkgApN" 2275c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "vuEcZegFlNOUPVEs3SlBgUF1BY6OBM0UBHTPwGGxFBBcetcuMRbUnu65vyDG0pslT59qpaR0TMVs" 2285c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "P+tcheEzhyjbfM32/vwhnL9dBEgM8qMt0sqF6itNOQU/F4WGkK2Cm2v4CYEyKYw325fEhzTXosck" 2295c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MhbqmcyLab8EPceWF3dweoUT76+jEZx8lV2dapR+CmczQI43tV9btsd1xiBbBHAKvymm9Ep9bPzM" 2305c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "J0MQi+OtURL9Lxke/70/MRueqbPeUlOaGvANTmXQD2OnW7PISwJ9lpeLfTG0LcqkoqkbtLKQLYHI" 2315c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rQfV5j0j+wmvmpMxzjN3uvNajLa4zQ8l0Eok9SFaRr2RL0gN8Q2JegfOL4pUiHPsh64WWya2NB7f" 2325c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "V+1s65eA5ospXYsShRjo046QhGTmymwXXzdzuxu8IlnTEont6P4+J+GsWk6cldGbl20hctuUKzyx" 2335c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "OptjEPOKejV60iDCYGmHbCWAzQ8h5MILV82IclzNViZmzAapeeCnexhpXhWTs+xDEYSKEiG/camt" 2345c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "bhmZc3BcyVJrW23PktSfpBQ6D8ZxoMfF0L7V2GQMaUg+3r7ucrx82kpqotjv0xHghNIm95aBr1Qw" 2355c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1gaEjsC/0wGmmBDg1dTDH+F1p9TInzr3EFuYD0YiQ7YlAHq3cPuyGoLXJ5dXYuSBfhDXJSeddUkl" 2365c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "k1ufZyOOcskeInQge7jzaRfmKg3U94r+spMEvb0AzDQVOKvjjo1ivxMSgFRZaDb/4qw="; 237adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 238f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 239adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the server, JKS version. Holds just a 240adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Server". 241adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 242f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String SERVER_KEYS_JKS = 2435c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "/u3+7QAAAAIAAAABAAAAAQAFbXlrZXkAAAEaWFfBeAAAArowggK2MA4GCisGAQQBKgIRAQEFAASC" 2445c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "AqI2kp5XjnF8YZkhcF92YsJNQkvsmH7zqMM87j23zSoV4DwyE3XeC/gZWq1ToScIhoqZkzlbWcu4" 2455c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "T/Zfc/DrfGk/rKbBL1uWKGZ8fMtlZk8KoAhxZk1JSyJvdkyKxqmzUbxk1OFMlN2VJNu97FPVH+du" 2465c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "dvjTvmpdoM81INWBW/1fZJeQeDvn4mMbbe0IxgpiLnI9WSevlaDP/sm1X3iO9yEyzHLL+M5Erspo" 2475c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "Cwa558fOu5DdsICMXhvDQxjWFKFhPHnKtGe+VvwkG9/bAaDgx3kfhk0w5zvdnkKb+8Ed9ylNRzdk" 2485c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ocAa/mxlMTOsTvDKXjjsBupNPIIj7OP4GNnZaxkJjSs98pEO67op1GX2qhy6FSOPNuq8k/65HzUc" 2495c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "PYn6voEeh6vm02U/sjEnzRevQ2+2wXoAdp0EwtQ/DlMe+NvcwPGWKuMgX4A4L93DZGb04N2VmAU3" 2505c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "YLOtZwTO0LbuWrcCM/q99G/7LcczkxIVrO2I/rh8RXVczlf9QzcrFObFv4ATuspWJ8xG7DhsMbnk" 2515c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rT94Pq6TogYeoz8o8ZMykesAqN6mt/9+ToIemmXv+e+KU1hI5oLwWMnUG6dXM6hIvrULY6o+QCPH" 2525c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "172YQJMa+68HAeS+itBTAF4Clm/bLn6reHCGGU6vNdwU0lYldpiOj9cB3t+u2UuLo6tiFWjLf5Zs" 2535c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "EQJETd4g/EK9nHxJn0GAKrWnTw7pEHQJ08elzUuy04C/jEEG+4QXU1InzS4o/kR0Sqz2WTGDoSoq" 2545c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ewuPRU5bzQs/b9daq3mXrnPtRBL6HfSDAdpTK76iHqLCGdqx3avHjVSBm4zFvEuYBCev+3iKOBmg" 2555c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "yh7eQRTjz4UOWfy85omMBr7lK8PtfVBDzOXpasxS0uBgdUyBDX4tO6k9jZ8a1kmQRQAAAAEABVgu" 2565c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NTA5AAACSDCCAkQwggGtAgRIR8SKMA0GCSqGSIb3DQEBBAUAMGkxCzAJBgNVBAYTAlVTMRMwEQYD" 2575c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VQQIEwpDYWxpZm9ybmlhMQwwCgYDVQQHEwNNVFYxDzANBgNVBAoTBkdvb2dsZTEQMA4GA1UECxMH" 2585c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "QW5kcm9pZDEUMBIGA1UEAxMLVGVzdCBTZXJ2ZXIwHhcNMDgwNjA1MTA0ODQyWhcNMDgwOTAzMTA0" 2595c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ODQyWjBpMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8w" 2605c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DQYDVQQKEwZHb29nbGUxEDAOBgNVBAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgU2VydmVyMIGf" 2615c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCwoC6chqCI84rj1PrXuJgbiit4EV909zR6N0jNlYfg" 2625c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "itwB39bP39wH03rFm8T59b3mbSptnGmCIpLZn25KPPFsYD3JJ+wFlmiUdEP9H05flfwtFQJnw9uT" 2635c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "3rRIdYVMPcQ3RoZzwAMliGr882I2thIDbA6xjGU/1nRIdvk0LtxH3QIDAQABMA0GCSqGSIb3DQEB" 2645c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAUAA4GBAJn+6YgUlY18Ie+0+Vt8oEi81DNi/bfPrAUAh63fhhBikx/3R9dl3wh09Z6p7cIdNxjW" 2655c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "n2ll+cRW9eqF7z75F0Omm0C7/KAEPjukVbszmzeU5VqzkpSt0j84YWi+TfcHRrfvhLbrlmGITVpY" 2665c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ol5pHLDyqGmDs53pgwipWqsn/nEXEBgj3EoqPeqHbDf7YaP8h/5BSt0="; 267f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 268f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 269adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the client, JKS version. Holds just a 270adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Client". 271adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 272f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String CLIENT_KEYS_JKS = 2735c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "/u3+7QAAAAIAAAABAAAAAQAFbXlrZXkAAAEaWFhyMAAAArkwggK1MA4GCisGAQQBKgIRAQEFAASC" 2745c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "AqGVSfXolBStZy4nnRNn4fAr+S7kfU2BS23wwW8uB2Ru3GvtLzlK9q08Gvq/LNqBafjyFTVL5FV5" 2755c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "SED/8YomO5a98GpskSeRvytCiTBLJdgGhws5TOGekgIAcBROPGIyOtJPQ0HfOQs+BqgzGDHzHQhw" 2765c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "u/8Tm6yQwiP+W/1I9B1QnaEztZA3mhTyMMJsmsFTYroGgAog885D5Cmzd8sYGfxec3R6I+xcmBAY" 2775c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "eibR5kGpWwt1R+qMvRrtBqh5r6WSKhCBNax+SJVbtUNRiKyjKccdJg6fGqIWWeivwYTy0OhjA6b4" 2785c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NiZ/ZZs5pxFGWUj/Rlp0RYy8fCF6aw5/5s4Bf4MI6dPSqMG8Hf7sJR91GbcELyzPdM0h5lNavgit" 2795c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "QPEzKeuDrGxhY1frJThBsNsS0gxeu+OgfJPEb/H4lpYX5IvuIGbWKcxoO9zq4/fimIZkdA8A+3eY" 2805c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "mfDaowvy65NBVQPJSxaOyFhLHfeLqOeCsVENAea02vA7andZHTZehvcrqyKtm+z8ncHGRC2H9H8O" 2815c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "jKwKHfxxrYY/jMAKLl00+PBb3kspO+BHI2EcQnQuMw/zr83OR9Meq4TJ0TMuNkApZELAeFckIBbS" 2825c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rBr8NNjAIfjuCTuKHhsTFWiHfk9ZIzigxXagfeDRiyVc6khOuF/bGorj23N2o7Rf3uLoU6PyXWi4" 2835c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "uhctR1aL6NzxDoK2PbYCeA9hxbDv8emaVPIzlVwpPK3Ruvv9mkjcOhZ74J8bPK2fQmbplbOljcZi" 2845c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "tZijOfzcO/11JrwhuJZRA6wanTqHoujgChV9EukVrmbWGGAcewFnAsSbFXIik7/+QznXaDIt5NgL" 2855c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "H/Bcz4Z/fdV7Ae1eUaxKXdPbI//4J+8liVT/d8awjW2tldIaDlmGMR3aoc830+3mAAAAAQAFWC41" 2865c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJIMIICRDCCAa0CBEhHxLgwDQYJKoZIhvcNAQEEBQAwaTELMAkGA1UEBhMCVVMxEzARBgNV" 2875c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01UVjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdB" 2885c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "bmRyb2lkMRQwEgYDVQQDEwtUZXN0IENsaWVudDAeFw0wODA2MDUxMDQ5MjhaFw0wODA5MDMxMDQ5" 2895c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MjhaMGkxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMQwwCgYDVQQHEwNNVFYxDzAN" 2905c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BgNVBAoTBkdvb2dsZTEQMA4GA1UECxMHQW5kcm9pZDEUMBIGA1UEAxMLVGVzdCBDbGllbnQwgZ8w" 2915c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAIK3Q+KiFbmCGg422TAo4gggdhMH6FJhiuz8DxRyeMKR" 2925c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "UAfP4MK0wtc8N42waZ6OKvxpBFUy0BRfBsX0GD4Ku99yu9/tavSigTraeJtwV3WWRRjIqk7L3wX5" 2935c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "cmgS2KSD43Y0rNUKrko26lnt9N4qiYRBSj+tcAN3Lx9+ptqk1LApAgMBAAEwDQYJKoZIhvcNAQEE" 2945c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BQADgYEANb7Q1GVSuy1RPJ0FmiXoMYCCtvlRLkmJphwxovK0cAQK12Vll+yAzBhHiQHy/RA11mng" 2955c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "wYudC7u3P8X/tBT8GR1Yk7QW3KgFyPafp3lQBBCraSsfrjKj+dCLig1uBLUr4f68W8VFWZWWTHqp" 2965c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NMGpCX6qmjbkJQLVK/Yfo1ePaUexPSOX0G9m8+DoV3iyNw6at01NRw=="; 297adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 298f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 299adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the client, BKS version. Holds just a 300adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Client". 301adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 302f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String CLIENT_KEYS_BKS = 3035c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "AAAAAQAAABT4Rka6fxbFps98Y5k2VilmbibNkQAABfQEAAVteWtleQAAARpYl+POAAAAAQAFWC41" 3045c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJNMIICSTCCAbKgAwIBAgIESEfU9TANBgkqhkiG9w0BAQUFADBpMQswCQYDVQQGEwJVUzET" 3055c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8wDQYDVQQKEwZHb29nbGUxEDAOBgNV" 3065c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgQ2xpZW50MB4XDTA4MDYwNTExNTg0NVoXDTA4MDkw" 3075c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MzExNTg0NVowaTELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01U" 3085c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdBbmRyb2lkMRQwEgYDVQQDEwtUZXN0IENsaWVu" 3095c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "dDCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEApUvmWsQDHPpbDKK13Yez2/q54tTOmRml/qva" 3105c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "2K6dZjkjSTW0iRuk7ztaVEvdJpfVIDv1oBsCI51ttyLHROy1epjF+GoL74mJb7fkcd0VOoSOTjtD" 3115c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "+3GgZkHPAm5YmUYxiJXqxKKJJqMCTIW46eJaA2nAep9QIwZ14/NFAs4ObV8CAwEAATANBgkqhkiG" 3125c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "9w0BAQUFAAOBgQCJrCr3hZQFDlLIfsSKI1/w+BLvyf4fubOid0pBxfklR8KBNPTiqjSmu7pd/C/F" 3135c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1FR8CdZUDoPflZHCOU+fj5r5KUC1HyigY/tEUvlforBpfB0uCF+tXW4DbUfOWhfMtLV4nCOJOOZg" 3145c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "awfZLJWBJouLKOp427vDftxTSB+Ks8YjlgAAAqwAAAAU+NH6TtrzjyDdCXm5B6Vo7xX5G4YAAAZx" 3155c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "EAUkcZtmykn7YdaYxC1jRFJ+GEJpC8nZVg83QClVuCSIS8a5f8Hl44Bk4oepOZsPzhtz3RdVzDVi" 3165c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "RFfoyZFsrk9F5bDTVJ6sQbb/1nfJkLhZFXokka0vND5AXMSoD5Bj1Fqem3cK7fSUyqKvFoRKC3XD" 3175c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "FQvhqoam29F1rbl8FaYdPvhhZo8TfZQYUyUKwW+RbR44M5iHPx+ykieMe/C/4bcM3z8cwIbYI1aO" 3185c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "gjQKS2MK9bs17xaDzeAh4sBKrskFGrDe+2dgvrSKdoakJhLTNTBSG6m+rzqMSCeQpafLKMSjTSSz" 3195c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "+KoQ9bLyax8cbvViGGju0SlVhquloZmKOfHr8TukIoV64h3uCGFOVFtQjCYDOq6NbfRvMh14UVF5" 3205c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "zgDIGczoD9dMoULWxBmniGSntoNgZM+QP6Id7DBasZGKfrHIAw3lHBqcvB5smemSu7F4itRoa3D8" 3215c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "N7hhUEKAc+xA+8NKmXfiCBoHfPHTwDvt4IR7gWjeP3Xv5vitcKQ/MAfO5RwfzkYCXQ3FfjfzmsE1" 3225c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1IfLRDiBj+lhQSulhRVStKI88Che3M4JUNGKllrc0nt1pWa1vgzmUhhC4LSdm6trTHgyJnB6OcS9" 3235c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "t2furYjK88j1AuB4921oxMxRm8c4Crq8Pyuf+n3YKi8Pl2BzBtw++0gj0ODlgwut8SrVj66/nvIB" 3245c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "jN3kLVahR8nZrEFF6vTTmyXi761pzq9yOVqI57wJGx8o3Ygox1p+pWUPl1hQR7rrhUbgK/Q5wno9" 3255c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "uJk07h3IZnNxE+/IKgeMTP/H4+jmyT4mhsexJ2BFHeiKF1KT/FMcJdSi+ZK5yoNVcYuY8aZbx0Ef" 3265c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "lHorCXAmLFB0W6Cz4KPP01nD9YBB4olxiK1t7m0AU9zscdivNiuUaB5OIEr+JuZ6dNw="; 327adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 328adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 329adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 330adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements the actual test case. Launches a server and a client, requires 331adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * client authentication and checks the certificates afterwards (not in the 332adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * usual sense, we just make sure that we got the expected certificates, 333adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * because our self-signed test certificates are not valid.) 334adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 335f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 3365c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public void testClientAuth() throws Exception { 3371cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob 3381cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob boolean useBKS = true; 3391cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob 340adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project listener = new MyHandshakeListener(); 3415c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom String serverKeys = (useBKS ? SERVER_KEYS_BKS : SERVER_KEYS_JKS); 3425c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom String clientKeys = (useBKS ? CLIENT_KEYS_BKS : CLIENT_KEYS_JKS); 3435c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestServer server = new TestServer(true, 3445c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestServer.CLIENT_AUTH_WANTED, serverKeys); 3455c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestClient client = new TestClient(true, clientKeys); 3465c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3475c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread serverThread = new Thread(server); 3485c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread clientThread = new Thread(client); 3495c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3505c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom serverThread.start(); 3515c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread.currentThread().sleep(3000); 3525c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom clientThread.start(); 3535c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3545c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom serverThread.join(); 3555c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom clientThread.join(); 3565c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3575c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom // The server must have completed without an exception. 3585c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Exception e = server.getException(); 3595c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom if (e != null) { 3605c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e.printStackTrace(); 3615c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } 362adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3635c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom // The client must have completed without an exception. 3645c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e = client.getException(); 3655c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom if (e != null) { 3665c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e.printStackTrace(); 3675c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } 368f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 3695c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(e); 370adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3715c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertTrue(listener.completeDone); 372adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 373f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 374f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 375adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements a test SSL socket server. It wait for a connection on a given 376ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * port, requests client authentication (if specified), reads 256 bytes 377ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * from the socket, and writes 256 bytes to the socket. 378adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 379adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class TestServer implements Runnable { 380adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 381adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_NONE = 0; 382adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 383adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_WANTED = 1; 384adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 385adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_NEEDED = 2; 386f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 387adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private TestTrustManager trustManager; 388adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 389adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private Exception exception; 390adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3911cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob String keys; 392f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 393adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private int clientAuth; 394f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 395adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private boolean provideKeys; 396adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 397bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes public TestServer(boolean provideKeys, int clientAuth, String keys) throws Exception { 3981cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob this.keys = keys; 399adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.clientAuth = clientAuth; 400adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.provideKeys = provideKeys; 401f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 402f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes trustManager = new TestTrustManager(); 403f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 404bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes KeyManager[] keyManagers = provideKeys ? getKeyManagers(keys) : null; 405bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes TrustManager[] trustManagers = new TrustManager[] { trustManager }; 406adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 407bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes SSLContext sslContext = SSLContext.getInstance("TLS"); 408bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes sslContext.init(keyManagers, trustManagers, null); 409f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 410bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket = (SSLServerSocket) sslContext.getServerSocketFactory().createServerSocket(); 411f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 412bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes if (clientAuth == CLIENT_AUTH_WANTED) { 413bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket.setWantClientAuth(true); 414bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes } else if (clientAuth == CLIENT_AUTH_NEEDED) { 415bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket.setNeedClientAuth(true); 416bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes } else { 417bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket.setWantClientAuth(false); 418bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes } 419f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 420bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket.bind(new InetSocketAddress(0)); 421bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes } 422f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 423bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes public void run() { 424bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes try { 425adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLSocket clientSocket = (SSLSocket)serverSocket.accept(); 426adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 427ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu InputStream istream = clientSocket.getInputStream(); 428adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 429adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project for (int i = 0; i < 256; i++) { 430ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu int j = istream.read(); 4315c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(i, j); 432adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 433f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 434ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu istream.close(); 435ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 436ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu OutputStream ostream = clientSocket.getOutputStream(); 437ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 438ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu for (int i = 0; i < 256; i++) { 439ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.write(i); 440ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu } 441ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 442ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.flush(); 443ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.close(); 444ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 445adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project clientSocket.close(); 446adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project serverSocket.close(); 447f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 448adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } catch (Exception ex) { 449adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project exception = ex; 450adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 451adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 452adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 453adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public Exception getException() { 454adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return exception; 455adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 456f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 457adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 458adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return trustManager.getChain(); 459adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 460f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 461adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 462adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 463f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 464adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements a test SSL socket client. It open a connection to localhost on 465ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * a given port, writes 256 bytes to the socket, and reads 256 bytes from the 466ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * socket. 467adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 468adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class TestClient implements Runnable { 469f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 470adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private TestTrustManager trustManager; 471adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 472adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private Exception exception; 473f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 4741cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob private String keys; 475f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 476adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private boolean provideKeys; 477f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 4781cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public TestClient(boolean provideKeys, String keys) { 4791cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob this.keys = keys; 480adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.provideKeys = provideKeys; 481f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 482f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes trustManager = new TestTrustManager(); 483adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 484f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 485adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void run() { 486adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 4871cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob KeyManager[] keyManagers = provideKeys ? getKeyManagers(keys) : null; 488adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project TrustManager[] trustManagers = new TrustManager[] { trustManager }; 489adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 490adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLContext sslContext = SSLContext.getInstance("TLS"); 491adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project sslContext.init(keyManagers, trustManagers, null); 492f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 493adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLSocket socket = (SSLSocket)sslContext.getSocketFactory().createSocket(); 494adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 495bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes socket.connect(serverSocket.getLocalSocketAddress()); 496adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.addHandshakeCompletedListener(listener); 497adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.startHandshake(); 498adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 499ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu OutputStream ostream = socket.getOutputStream(); 500f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 501adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project for (int i = 0; i < 256; i++) { 502ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.write(i); 503adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 504f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 505ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.flush(); 506ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.close(); 507ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 508ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu InputStream istream = socket.getInputStream(); 509ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 510ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu for (int i = 0; i < 256; i++) { 511ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu int j = istream.read(); 5125c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(i, j); 513ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu } 514ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 515ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu istream.close(); 516ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 517adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.close(); 518f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 519adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } catch (Exception ex) { 520adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project exception = ex; 521adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 522adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 523adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 524adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public Exception getException() { 525adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return exception; 526adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 527adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 528adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 529adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return trustManager.getChain(); 530adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 531adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 532f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 533adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 534adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Loads a keystore from a base64-encoded String. Returns the KeyManager[] 535adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * for the result. 536adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 537adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private KeyManager[] getKeyManagers(String keys) throws Exception { 5387ff645482d5d10f2c15955ed812de183dead5557Tobias Thierer byte[] bytes = Base64.getDecoder().decode(keys.getBytes()); 539adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project InputStream inputStream = new ByteArrayInputStream(bytes); 540f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 541adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType()); 542adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project keyStore.load(inputStream, PASSWORD.toCharArray()); 543adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project inputStream.close(); 544ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 545adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project String algorithm = KeyManagerFactory.getDefaultAlgorithm(); 546adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance(algorithm); 547adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project keyManagerFactory.init(keyStore, PASSWORD.toCharArray()); 548f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 549adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return keyManagerFactory.getKeyManagers(); 550adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 551adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 552adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 553f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 554adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements basically a dummy TrustManager. It stores the certificate 555adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * chain it sees, so it can later be queried. 556adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 557051f400949489d012498f575c0a40999ad7a4f54Jorg Pleumann public static class TestTrustManager implements X509TrustManager { 558f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 559adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private X509Certificate[] chain; 560f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 561adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private String authType; 562f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 563adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkClientTrusted(X509Certificate[] chain, String authType) { 564adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.chain = chain; 565adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.authType = authType; 566adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 567adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 568adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkServerTrusted(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 java.security.cert.X509Certificate[] getAcceptedIssuers() { 574adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return new java.security.cert.X509Certificate[0]; 575adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 576adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 577adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 578adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return chain; 579adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 580f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 581adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public String getAuthType() { 582adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return authType; 583adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 584adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 585adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkClientTrusted( 586adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project java.security.cert.X509Certificate[] chain, String authType) 587adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project throws CertificateException { 588f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 589adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 590adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 591adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkServerTrusted( 592adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project java.security.cert.X509Certificate[] chain, String authType) 593adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project throws CertificateException { 594f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 595adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 596f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 597adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 598adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 599adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class MyHandshakeListener implements HandshakeCompletedListener { 600adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 601adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public boolean completeDone; 602adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 603adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project MyHandshakeListener() { 604adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project completeDone = false; 605adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 606adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 607adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void handshakeCompleted(HandshakeCompletedEvent event) { 608adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project if (event != null) completeDone = true; 609adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 610adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 611adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project} 612