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; 4332b2c95c350002f67c8b3e65777161feda766b72Jesse Wilsonimport libcore.io.Base64; 44adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectimport org.apache.harmony.xnet.tests.support.mySSLSession; 45adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 46adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/** 47adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Tests for <code>HandshakeCompletedEvent</code> class constructors and methods. 48f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * 49adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 50adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpublic class HandshakeCompletedEventTest extends TestCase { 51f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 52bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private String certificate = "-----BEGIN CERTIFICATE-----\n" 53adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "MIICZTCCAdICBQL3AAC2MA0GCSqGSIb3DQEBAgUAMF8xCzAJBgNVBAYTAlVTMSAw\n" 54adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "HgYDVQQKExdSU0EgRGF0YSBTZWN1cml0eSwgSW5jLjEuMCwGA1UECxMlU2VjdXJl\n" 55adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "IFNlcnZlciBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw05NzAyMjAwMDAwMDBa\n" 56adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "Fw05ODAyMjAyMzU5NTlaMIGWMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZv\n" 57adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "cm5pYTESMBAGA1UEBxMJUGFsbyBBbHRvMR8wHQYDVQQKExZTdW4gTWljcm9zeXN0\n" 58adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "ZW1zLCBJbmMuMSEwHwYDVQQLExhUZXN0IGFuZCBFdmFsdWF0aW9uIE9ubHkxGjAY\n" 59adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "BgNVBAMTEWFyZ29uLmVuZy5zdW4uY29tMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB\n" 60adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "iQKBgQCofmdY+PiUWN01FOzEewf+GaG+lFf132UpzATmYJkA4AEA/juW7jSi+LJk\n" 61adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "wJKi5GO4RyZoyimAL/5yIWDV6l1KlvxyKslr0REhMBaD/3Z3EsLTTEf5gVrQS6sT\n" 62adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "WMoSZAyzB39kFfsB6oUXNtV8+UKKxSxKbxvhQn267PeCz5VX2QIDAQABMA0GCSqG\n" 63adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "SIb3DQEBAgUAA34AXl3at6luiV/7I9MN5CXYoPJYI8Bcdc1hBagJvTMcmlqL2uOZ\n" 64adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "H9T5hNMEL9Tk6aI7yZPXcw/xI2K6pOR/FrMp0UwJmdxX7ljV6ZtUZf7pY492UqwC\n" 65adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "1777XQ9UEZyrKJvF5ntleeO0ayBqLGVKCWzWZX9YsXCpv47FNLZbupE=\n" 66adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project + "-----END CERTIFICATE-----\n"; 67adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 68adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 69adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 70f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 71229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#HandshakeCompletedEvent(SSLSocket sock, SSLSession s) 72adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 735c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_Constructor() throws Exception { 741cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob mySSLSession session = new mySSLSession(); 751cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 765c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 77adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 785c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom new HandshakeCompletedEvent(null, null); 79adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("Any exception wasn't thrown for null parameters"); 805c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (Exception expected) { 81adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 82adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 83f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 84adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 85f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 86229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getCipherSuite() 87adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 885c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getCipherSuite() throws Exception { 89adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 901cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 91adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 925c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals("SuiteName", event.getCipherSuite()); 93adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 94f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 95adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 96f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 97229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getLocalCertificates() 98adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 995c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getLocalCertificates() throws Exception { 100adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1011cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 102adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1035c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getLocalCertificates()); 104adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 105f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 106adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 107f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 108229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getLocalPrincipal() 109adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1105c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getLocalPrincipal() throws Exception { 111adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1121cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 113adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1145c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getLocalPrincipal()); 115adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 116f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 117adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 118f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 119229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerCertificateChain() 120adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1215c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public final void test_getPeerCertificateChain() throws Exception { 122adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project ByteArrayInputStream bis = new ByteArrayInputStream(certificate.getBytes()); 1231cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob mySSLSession session = new mySSLSession((X509Certificate[]) null); 1241cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 125adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 126adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 1275c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event.getPeerCertificateChain(); 128adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("SSLPeerUnverifiedException wasn't thrown"); 1295c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (SSLPeerUnverifiedException expected) { 130adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 131f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 1325c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate xc = X509Certificate.getInstance(bis); 1335c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate[] xcs = {xc}; 1345c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom session = new mySSLSession(xcs); 1355c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event = new HandshakeCompletedEvent(socket, session); 1365c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 1375c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom X509Certificate[] res = event.getPeerCertificateChain(); 1385c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(1, res.length); 139adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 140f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 141adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 142f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 143229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerCertificates() 144adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1451cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getPeerCertificates() throws IOException { 146adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1471cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 148adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 149adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 1505c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom event.getPeerCertificates(); 151adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project fail("SSLPeerUnverifiedException wasn't thrown"); 1525c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } catch (SSLPeerUnverifiedException expected) { 153adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 154f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 1551cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob session = new mySSLSession((X509Certificate[]) null); 156adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project event = new HandshakeCompletedEvent(socket, session); 1575c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Certificate[] res = event.getPeerCertificates(); 1585c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(3, res.length); 159adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 160f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 161adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 162f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 163229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getPeerPrincipal() 164adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1651cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getPeerPrincipal() throws IOException { 166adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1671cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 168adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1695c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(event.getPeerPrincipal()); 170adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 171f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 172adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 173f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 174229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getSession() 175adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1761cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getSession() throws IOException { 177adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project mySSLSession session = new mySSLSession("localhost", 1080, null); 1781cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 179adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, session); 1805c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom SSLSession ss = event.getSession(); 1815c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNotNull(ss); 1825c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(session, ss); 183adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 184f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 185adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 186f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes * @throws IOException 187229e34b182b98e1dba15d3dc6341954986ae2b7aBrian Carlstrom * javax.net.ssl.HandshakeCompletedEvent#getSocket() 188adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 1891cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public final void test_getSocket() throws IOException { 1901cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob SSLSocket socket = (SSLSocket) SSLSocketFactory.getDefault().createSocket(); 1911cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob HandshakeCompletedEvent event = new HandshakeCompletedEvent(socket, null); 1925c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom SSLSocket ss = event.getSocket(); 1935c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNotNull(ss); 1945c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(socket, ss); 195adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 196f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 197f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 198adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project // Regression test for CompletedHandshakeEvent not firing with a custom 199adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project // TrustManager 200f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 201adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 202bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private SSLSocket socket; 203bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private SSLServerSocket serverSocket; 204bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private MyHandshakeListener listener; 205bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes private String host = "localhost"; 206f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 207adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private String PASSWORD = "android"; 208adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 209f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 210adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the server, BKS version. Holds just a 211adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Server". 212adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 213f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String SERVER_KEYS_BKS = 2145c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "AAAAAQAAABQDkebzoP1XwqyWKRCJEpn/t8dqIQAABDkEAAVteWtleQAAARpYl20nAAAAAQAFWC41" 2155c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJNMIICSTCCAbKgAwIBAgIESEfU1jANBgkqhkiG9w0BAQUFADBpMQswCQYDVQQGEwJVUzET" 2165c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8wDQYDVQQKEwZHb29nbGUxEDAOBgNV" 2175c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgU2VydmVyMB4XDTA4MDYwNTExNTgxNFoXDTA4MDkw" 2185c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MzExNTgxNFowaTELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01U" 2195c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdBbmRyb2lkMRQwEgYDVQQDEwtUZXN0IFNlcnZl" 2205c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "cjCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEA0LIdKaIr9/vsTq8BZlA3R+NFWRaH4lGsTAQy" 2215c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DPMF9ZqEDOaL6DJuu0colSBBBQ85hQTPa9m9nyJoN3pEi1hgamqOvQIWcXBk+SOpUGRZZFXwniJV" 2225c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "zDKU5nE9MYgn2B9AoiH3CSuMz6HRqgVaqtppIe1jhukMc/kHVJvlKRNy9XMCAwEAATANBgkqhkiG" 2235c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "9w0BAQUFAAOBgQC7yBmJ9O/eWDGtSH9BH0R3dh2NdST3W9hNZ8hIa8U8klhNHbUCSSktZmZkvbPU" 2245c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "hse5LI3dh6RyNDuqDrbYwcqzKbFJaq/jX9kCoeb3vgbQElMRX8D2ID1vRjxwlALFISrtaN4VpWzV" 2255c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "yeoHPW4xldeZmoVtjn8zXNzQhLuBqX2MmAAAAqwAAAAUvkUScfw9yCSmALruURNmtBai7kQAAAZx" 2265c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "4Jmijxs/l8EBaleaUru6EOPioWkUAEVWCxjM/TxbGHOi2VMsQWqRr/DZ3wsDmtQgw3QTrUK666sR" 2275c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBnbqdnyCyvM1J2V1xxLXPUeRBmR2CXorYGF9Dye7NkgVdfA+9g9L/0Au6Ugn+2Cj5leoIgkgApN" 2285c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "vuEcZegFlNOUPVEs3SlBgUF1BY6OBM0UBHTPwGGxFBBcetcuMRbUnu65vyDG0pslT59qpaR0TMVs" 2295c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "P+tcheEzhyjbfM32/vwhnL9dBEgM8qMt0sqF6itNOQU/F4WGkK2Cm2v4CYEyKYw325fEhzTXosck" 2305c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MhbqmcyLab8EPceWF3dweoUT76+jEZx8lV2dapR+CmczQI43tV9btsd1xiBbBHAKvymm9Ep9bPzM" 2315c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "J0MQi+OtURL9Lxke/70/MRueqbPeUlOaGvANTmXQD2OnW7PISwJ9lpeLfTG0LcqkoqkbtLKQLYHI" 2325c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rQfV5j0j+wmvmpMxzjN3uvNajLa4zQ8l0Eok9SFaRr2RL0gN8Q2JegfOL4pUiHPsh64WWya2NB7f" 2335c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "V+1s65eA5ospXYsShRjo046QhGTmymwXXzdzuxu8IlnTEont6P4+J+GsWk6cldGbl20hctuUKzyx" 2345c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "OptjEPOKejV60iDCYGmHbCWAzQ8h5MILV82IclzNViZmzAapeeCnexhpXhWTs+xDEYSKEiG/camt" 2355c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "bhmZc3BcyVJrW23PktSfpBQ6D8ZxoMfF0L7V2GQMaUg+3r7ucrx82kpqotjv0xHghNIm95aBr1Qw" 2365c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1gaEjsC/0wGmmBDg1dTDH+F1p9TInzr3EFuYD0YiQ7YlAHq3cPuyGoLXJ5dXYuSBfhDXJSeddUkl" 2375c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "k1ufZyOOcskeInQge7jzaRfmKg3U94r+spMEvb0AzDQVOKvjjo1ivxMSgFRZaDb/4qw="; 238adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 239f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 240adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the server, JKS version. Holds just a 241adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Server". 242adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 243f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String SERVER_KEYS_JKS = 2445c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "/u3+7QAAAAIAAAABAAAAAQAFbXlrZXkAAAEaWFfBeAAAArowggK2MA4GCisGAQQBKgIRAQEFAASC" 2455c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "AqI2kp5XjnF8YZkhcF92YsJNQkvsmH7zqMM87j23zSoV4DwyE3XeC/gZWq1ToScIhoqZkzlbWcu4" 2465c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "T/Zfc/DrfGk/rKbBL1uWKGZ8fMtlZk8KoAhxZk1JSyJvdkyKxqmzUbxk1OFMlN2VJNu97FPVH+du" 2475c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "dvjTvmpdoM81INWBW/1fZJeQeDvn4mMbbe0IxgpiLnI9WSevlaDP/sm1X3iO9yEyzHLL+M5Erspo" 2485c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "Cwa558fOu5DdsICMXhvDQxjWFKFhPHnKtGe+VvwkG9/bAaDgx3kfhk0w5zvdnkKb+8Ed9ylNRzdk" 2495c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ocAa/mxlMTOsTvDKXjjsBupNPIIj7OP4GNnZaxkJjSs98pEO67op1GX2qhy6FSOPNuq8k/65HzUc" 2505c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "PYn6voEeh6vm02U/sjEnzRevQ2+2wXoAdp0EwtQ/DlMe+NvcwPGWKuMgX4A4L93DZGb04N2VmAU3" 2515c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "YLOtZwTO0LbuWrcCM/q99G/7LcczkxIVrO2I/rh8RXVczlf9QzcrFObFv4ATuspWJ8xG7DhsMbnk" 2525c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rT94Pq6TogYeoz8o8ZMykesAqN6mt/9+ToIemmXv+e+KU1hI5oLwWMnUG6dXM6hIvrULY6o+QCPH" 2535c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "172YQJMa+68HAeS+itBTAF4Clm/bLn6reHCGGU6vNdwU0lYldpiOj9cB3t+u2UuLo6tiFWjLf5Zs" 2545c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "EQJETd4g/EK9nHxJn0GAKrWnTw7pEHQJ08elzUuy04C/jEEG+4QXU1InzS4o/kR0Sqz2WTGDoSoq" 2555c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ewuPRU5bzQs/b9daq3mXrnPtRBL6HfSDAdpTK76iHqLCGdqx3avHjVSBm4zFvEuYBCev+3iKOBmg" 2565c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "yh7eQRTjz4UOWfy85omMBr7lK8PtfVBDzOXpasxS0uBgdUyBDX4tO6k9jZ8a1kmQRQAAAAEABVgu" 2575c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NTA5AAACSDCCAkQwggGtAgRIR8SKMA0GCSqGSIb3DQEBBAUAMGkxCzAJBgNVBAYTAlVTMRMwEQYD" 2585c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VQQIEwpDYWxpZm9ybmlhMQwwCgYDVQQHEwNNVFYxDzANBgNVBAoTBkdvb2dsZTEQMA4GA1UECxMH" 2595c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "QW5kcm9pZDEUMBIGA1UEAxMLVGVzdCBTZXJ2ZXIwHhcNMDgwNjA1MTA0ODQyWhcNMDgwOTAzMTA0" 2605c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ODQyWjBpMQswCQYDVQQGEwJVUzETMBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8w" 2615c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DQYDVQQKEwZHb29nbGUxEDAOBgNVBAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgU2VydmVyMIGf" 2625c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCwoC6chqCI84rj1PrXuJgbiit4EV909zR6N0jNlYfg" 2635c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "itwB39bP39wH03rFm8T59b3mbSptnGmCIpLZn25KPPFsYD3JJ+wFlmiUdEP9H05flfwtFQJnw9uT" 2645c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "3rRIdYVMPcQ3RoZzwAMliGr882I2thIDbA6xjGU/1nRIdvk0LtxH3QIDAQABMA0GCSqGSIb3DQEB" 2655c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAUAA4GBAJn+6YgUlY18Ie+0+Vt8oEi81DNi/bfPrAUAh63fhhBikx/3R9dl3wh09Z6p7cIdNxjW" 2665c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "n2ll+cRW9eqF7z75F0Omm0C7/KAEPjukVbszmzeU5VqzkpSt0j84YWi+TfcHRrfvhLbrlmGITVpY" 2675c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "ol5pHLDyqGmDs53pgwipWqsn/nEXEBgj3EoqPeqHbDf7YaP8h/5BSt0="; 268f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 269f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 270adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the client, JKS version. Holds just a 271adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Client". 272adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 273f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String CLIENT_KEYS_JKS = 2745c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "/u3+7QAAAAIAAAABAAAAAQAFbXlrZXkAAAEaWFhyMAAAArkwggK1MA4GCisGAQQBKgIRAQEFAASC" 2755c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "AqGVSfXolBStZy4nnRNn4fAr+S7kfU2BS23wwW8uB2Ru3GvtLzlK9q08Gvq/LNqBafjyFTVL5FV5" 2765c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "SED/8YomO5a98GpskSeRvytCiTBLJdgGhws5TOGekgIAcBROPGIyOtJPQ0HfOQs+BqgzGDHzHQhw" 2775c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "u/8Tm6yQwiP+W/1I9B1QnaEztZA3mhTyMMJsmsFTYroGgAog885D5Cmzd8sYGfxec3R6I+xcmBAY" 2785c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "eibR5kGpWwt1R+qMvRrtBqh5r6WSKhCBNax+SJVbtUNRiKyjKccdJg6fGqIWWeivwYTy0OhjA6b4" 2795c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NiZ/ZZs5pxFGWUj/Rlp0RYy8fCF6aw5/5s4Bf4MI6dPSqMG8Hf7sJR91GbcELyzPdM0h5lNavgit" 2805c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "QPEzKeuDrGxhY1frJThBsNsS0gxeu+OgfJPEb/H4lpYX5IvuIGbWKcxoO9zq4/fimIZkdA8A+3eY" 2815c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "mfDaowvy65NBVQPJSxaOyFhLHfeLqOeCsVENAea02vA7andZHTZehvcrqyKtm+z8ncHGRC2H9H8O" 2825c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "jKwKHfxxrYY/jMAKLl00+PBb3kspO+BHI2EcQnQuMw/zr83OR9Meq4TJ0TMuNkApZELAeFckIBbS" 2835c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "rBr8NNjAIfjuCTuKHhsTFWiHfk9ZIzigxXagfeDRiyVc6khOuF/bGorj23N2o7Rf3uLoU6PyXWi4" 2845c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "uhctR1aL6NzxDoK2PbYCeA9hxbDv8emaVPIzlVwpPK3Ruvv9mkjcOhZ74J8bPK2fQmbplbOljcZi" 2855c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "tZijOfzcO/11JrwhuJZRA6wanTqHoujgChV9EukVrmbWGGAcewFnAsSbFXIik7/+QznXaDIt5NgL" 2865c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "H/Bcz4Z/fdV7Ae1eUaxKXdPbI//4J+8liVT/d8awjW2tldIaDlmGMR3aoc830+3mAAAAAQAFWC41" 2875c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJIMIICRDCCAa0CBEhHxLgwDQYJKoZIhvcNAQEEBQAwaTELMAkGA1UEBhMCVVMxEzARBgNV" 2885c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01UVjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdB" 2895c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "bmRyb2lkMRQwEgYDVQQDEwtUZXN0IENsaWVudDAeFw0wODA2MDUxMDQ5MjhaFw0wODA5MDMxMDQ5" 2905c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MjhaMGkxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpDYWxpZm9ybmlhMQwwCgYDVQQHEwNNVFYxDzAN" 2915c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BgNVBAoTBkdvb2dsZTEQMA4GA1UECxMHQW5kcm9pZDEUMBIGA1UEAxMLVGVzdCBDbGllbnQwgZ8w" 2925c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "DQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAIK3Q+KiFbmCGg422TAo4gggdhMH6FJhiuz8DxRyeMKR" 2935c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "UAfP4MK0wtc8N42waZ6OKvxpBFUy0BRfBsX0GD4Ku99yu9/tavSigTraeJtwV3WWRRjIqk7L3wX5" 2945c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "cmgS2KSD43Y0rNUKrko26lnt9N4qiYRBSj+tcAN3Lx9+ptqk1LApAgMBAAEwDQYJKoZIhvcNAQEE" 2955c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BQADgYEANb7Q1GVSuy1RPJ0FmiXoMYCCtvlRLkmJphwxovK0cAQK12Vll+yAzBhHiQHy/RA11mng" 2965c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "wYudC7u3P8X/tBT8GR1Yk7QW3KgFyPafp3lQBBCraSsfrjKj+dCLig1uBLUr4f68W8VFWZWWTHqp" 2975c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "NMGpCX6qmjbkJQLVK/Yfo1ePaUexPSOX0G9m8+DoV3iyNw6at01NRw=="; 298adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 299f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 300adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Defines the keystore contents for the client, BKS version. Holds just a 301adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * single self-generated key. The subject name is "Test Client". 302adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 303f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes private static final String CLIENT_KEYS_BKS = 3045c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom "AAAAAQAAABT4Rka6fxbFps98Y5k2VilmbibNkQAABfQEAAVteWtleQAAARpYl+POAAAAAQAFWC41" 3055c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MDkAAAJNMIICSTCCAbKgAwIBAgIESEfU9TANBgkqhkiG9w0BAQUFADBpMQswCQYDVQQGEwJVUzET" 3065c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MBEGA1UECBMKQ2FsaWZvcm5pYTEMMAoGA1UEBxMDTVRWMQ8wDQYDVQQKEwZHb29nbGUxEDAOBgNV" 3075c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "BAsTB0FuZHJvaWQxFDASBgNVBAMTC1Rlc3QgQ2xpZW50MB4XDTA4MDYwNTExNTg0NVoXDTA4MDkw" 3085c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "MzExNTg0NVowaTELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExDDAKBgNVBAcTA01U" 3095c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "VjEPMA0GA1UEChMGR29vZ2xlMRAwDgYDVQQLEwdBbmRyb2lkMRQwEgYDVQQDEwtUZXN0IENsaWVu" 3105c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "dDCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEApUvmWsQDHPpbDKK13Yez2/q54tTOmRml/qva" 3115c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "2K6dZjkjSTW0iRuk7ztaVEvdJpfVIDv1oBsCI51ttyLHROy1epjF+GoL74mJb7fkcd0VOoSOTjtD" 3125c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "+3GgZkHPAm5YmUYxiJXqxKKJJqMCTIW46eJaA2nAep9QIwZ14/NFAs4ObV8CAwEAATANBgkqhkiG" 3135c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "9w0BAQUFAAOBgQCJrCr3hZQFDlLIfsSKI1/w+BLvyf4fubOid0pBxfklR8KBNPTiqjSmu7pd/C/F" 3145c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1FR8CdZUDoPflZHCOU+fj5r5KUC1HyigY/tEUvlforBpfB0uCF+tXW4DbUfOWhfMtLV4nCOJOOZg" 3155c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "awfZLJWBJouLKOp427vDftxTSB+Ks8YjlgAAAqwAAAAU+NH6TtrzjyDdCXm5B6Vo7xX5G4YAAAZx" 3165c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "EAUkcZtmykn7YdaYxC1jRFJ+GEJpC8nZVg83QClVuCSIS8a5f8Hl44Bk4oepOZsPzhtz3RdVzDVi" 3175c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "RFfoyZFsrk9F5bDTVJ6sQbb/1nfJkLhZFXokka0vND5AXMSoD5Bj1Fqem3cK7fSUyqKvFoRKC3XD" 3185c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "FQvhqoam29F1rbl8FaYdPvhhZo8TfZQYUyUKwW+RbR44M5iHPx+ykieMe/C/4bcM3z8cwIbYI1aO" 3195c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "gjQKS2MK9bs17xaDzeAh4sBKrskFGrDe+2dgvrSKdoakJhLTNTBSG6m+rzqMSCeQpafLKMSjTSSz" 3205c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "+KoQ9bLyax8cbvViGGju0SlVhquloZmKOfHr8TukIoV64h3uCGFOVFtQjCYDOq6NbfRvMh14UVF5" 3215c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "zgDIGczoD9dMoULWxBmniGSntoNgZM+QP6Id7DBasZGKfrHIAw3lHBqcvB5smemSu7F4itRoa3D8" 3225c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "N7hhUEKAc+xA+8NKmXfiCBoHfPHTwDvt4IR7gWjeP3Xv5vitcKQ/MAfO5RwfzkYCXQ3FfjfzmsE1" 3235c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "1IfLRDiBj+lhQSulhRVStKI88Che3M4JUNGKllrc0nt1pWa1vgzmUhhC4LSdm6trTHgyJnB6OcS9" 3245c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "t2furYjK88j1AuB4921oxMxRm8c4Crq8Pyuf+n3YKi8Pl2BzBtw++0gj0ODlgwut8SrVj66/nvIB" 3255c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "jN3kLVahR8nZrEFF6vTTmyXi761pzq9yOVqI57wJGx8o3Ygox1p+pWUPl1hQR7rrhUbgK/Q5wno9" 3265c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "uJk07h3IZnNxE+/IKgeMTP/H4+jmyT4mhsexJ2BFHeiKF1KT/FMcJdSi+ZK5yoNVcYuY8aZbx0Ef" 3275c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom + "lHorCXAmLFB0W6Cz4KPP01nD9YBB4olxiK1t7m0AU9zscdivNiuUaB5OIEr+JuZ6dNw="; 328adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 329adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 330adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 331adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements the actual test case. Launches a server and a client, requires 332adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * client authentication and checks the certificates afterwards (not in the 333adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * usual sense, we just make sure that we got the expected certificates, 334adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * because our self-signed test certificates are not valid.) 335adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 336f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 3371cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob @AndroidOnly("Uses bks key store. Change useBKS to false to run on the RI") 3385c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom public void testClientAuth() throws Exception { 3391cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob 3401cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob boolean useBKS = true; 3411cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob 342adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project listener = new MyHandshakeListener(); 3435c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom String serverKeys = (useBKS ? SERVER_KEYS_BKS : SERVER_KEYS_JKS); 3445c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom String clientKeys = (useBKS ? CLIENT_KEYS_BKS : CLIENT_KEYS_JKS); 3455c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestServer server = new TestServer(true, 3465c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestServer.CLIENT_AUTH_WANTED, serverKeys); 3475c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom TestClient client = new TestClient(true, clientKeys); 3485c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3495c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread serverThread = new Thread(server); 3505c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread clientThread = new Thread(client); 3515c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3525c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom serverThread.start(); 3535c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Thread.currentThread().sleep(3000); 3545c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom clientThread.start(); 3555c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3565c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom serverThread.join(); 3575c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom clientThread.join(); 3585c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom 3595c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom // The server must have completed without an exception. 3605c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom Exception e = server.getException(); 3615c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom if (e != null) { 3625c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e.printStackTrace(); 3635c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } 364adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3655c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom // The client must have completed without an exception. 3665c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e = client.getException(); 3675c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom if (e != null) { 3685c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom e.printStackTrace(); 3695c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom } 370f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 3715c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertNull(e); 372adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3735c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertTrue(listener.completeDone); 374adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 375f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 376f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 377adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements a test SSL socket server. It wait for a connection on a given 378ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * port, requests client authentication (if specified), reads 256 bytes 379ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * from the socket, and writes 256 bytes to the socket. 380adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 381adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class TestServer implements Runnable { 382adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 383adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_NONE = 0; 384adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 385adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_WANTED = 1; 386adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 387adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public static final int CLIENT_AUTH_NEEDED = 2; 388f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 389adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private TestTrustManager trustManager; 390adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 391adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private Exception exception; 392adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 3931cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob String keys; 394f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 395adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private int clientAuth; 396f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 397adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private boolean provideKeys; 398adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 399bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes public TestServer(boolean provideKeys, int clientAuth, String keys) throws Exception { 4001cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob this.keys = keys; 401adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.clientAuth = clientAuth; 402adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.provideKeys = provideKeys; 403f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 404f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes trustManager = new TestTrustManager(); 405f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 406bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes KeyManager[] keyManagers = provideKeys ? getKeyManagers(keys) : null; 407bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes TrustManager[] trustManagers = new TrustManager[] { trustManager }; 408adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 409bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes SSLContext sslContext = SSLContext.getInstance("TLS"); 410bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes sslContext.init(keyManagers, trustManagers, null); 411f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 412bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket = (SSLServerSocket) sslContext.getServerSocketFactory().createServerSocket(); 413f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 414bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes if (clientAuth == CLIENT_AUTH_WANTED) { 415bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket.setWantClientAuth(true); 416bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes } else if (clientAuth == CLIENT_AUTH_NEEDED) { 417bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket.setNeedClientAuth(true); 418bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes } else { 419bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket.setWantClientAuth(false); 420bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes } 421f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 422bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes serverSocket.bind(new InetSocketAddress(0)); 423bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes } 424f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 425bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes public void run() { 426bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes try { 427adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLSocket clientSocket = (SSLSocket)serverSocket.accept(); 428adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 429ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu InputStream istream = clientSocket.getInputStream(); 430adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 431adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project for (int i = 0; i < 256; i++) { 432ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu int j = istream.read(); 4335c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(i, j); 434adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 435f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 436ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu istream.close(); 437ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 438ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu OutputStream ostream = clientSocket.getOutputStream(); 439ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 440ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu for (int i = 0; i < 256; i++) { 441ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.write(i); 442ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu } 443ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 444ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.flush(); 445ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.close(); 446ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 447adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project clientSocket.close(); 448adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project serverSocket.close(); 449f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 450adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } catch (Exception ex) { 451adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project exception = ex; 452adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 453adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 454adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 455adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public Exception getException() { 456adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return exception; 457adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 458f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 459adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 460adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return trustManager.getChain(); 461adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 462f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 463adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 464adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 465f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 466adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements a test SSL socket client. It open a connection to localhost on 467ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * a given port, writes 256 bytes to the socket, and reads 256 bytes from the 468ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu * socket. 469adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 470adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class TestClient implements Runnable { 471f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 472adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private TestTrustManager trustManager; 473adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 474adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private Exception exception; 475f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 4761cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob private String keys; 477f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 478adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private boolean provideKeys; 479f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 4801cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob public TestClient(boolean provideKeys, String keys) { 4811cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob this.keys = keys; 482adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.provideKeys = provideKeys; 483f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 484f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes trustManager = new TestTrustManager(); 485adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 486f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 487adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void run() { 488adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project try { 4891cd5a5cfeccb2745d54a1c49fc39e4e3537a9adeUrs Grob KeyManager[] keyManagers = provideKeys ? getKeyManagers(keys) : null; 490adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project TrustManager[] trustManagers = new TrustManager[] { trustManager }; 491adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 492adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLContext sslContext = SSLContext.getInstance("TLS"); 493adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project sslContext.init(keyManagers, trustManagers, null); 494f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 495adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project SSLSocket socket = (SSLSocket)sslContext.getSocketFactory().createSocket(); 496adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 497bd8d745469c817f0865237fe4e5ca85b0e75f071Elliott Hughes socket.connect(serverSocket.getLocalSocketAddress()); 498adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.addHandshakeCompletedListener(listener); 499adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.startHandshake(); 500adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 501ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu OutputStream ostream = socket.getOutputStream(); 502f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 503adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project for (int i = 0; i < 256; i++) { 504ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.write(i); 505adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 506f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 507ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.flush(); 508ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu ostream.close(); 509ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 510ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu InputStream istream = socket.getInputStream(); 511ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 512ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu for (int i = 0; i < 256; i++) { 513ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu int j = istream.read(); 5145c42f5792a0ad4159d30e7fd18958a21bf8b327fBrian Carlstrom assertEquals(i, j); 515ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu } 516ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 517ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu istream.close(); 518ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 519adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project socket.close(); 520f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 521adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } catch (Exception ex) { 522adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project exception = ex; 523adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 524adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 525adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 526adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public Exception getException() { 527adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return exception; 528adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 529adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 530adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 531adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return trustManager.getChain(); 532adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 533adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 534f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 535adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project /** 536adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Loads a keystore from a base64-encoded String. Returns the KeyManager[] 537adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * for the result. 538adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 539adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private KeyManager[] getKeyManagers(String keys) throws Exception { 540b1b8fbeeae579e9f49c41166bb5d9b2e60b75438Elliott Hughes byte[] bytes = Base64.decode(keys.getBytes()); 541adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project InputStream inputStream = new ByteArrayInputStream(bytes); 542f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 543adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType()); 544adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project keyStore.load(inputStream, PASSWORD.toCharArray()); 545adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project inputStream.close(); 546ffea1d45f1110e86eff51203aa2827f8d3456631Huahui Wu 547adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project String algorithm = KeyManagerFactory.getDefaultAlgorithm(); 548adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance(algorithm); 549adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project keyManagerFactory.init(keyStore, PASSWORD.toCharArray()); 550f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 551adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return keyManagerFactory.getKeyManagers(); 552adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 553adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 554adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 555f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes /** 556adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Implements basically a dummy TrustManager. It stores the certificate 557adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * chain it sees, so it can later be queried. 558adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */ 559051f400949489d012498f575c0a40999ad7a4f54Jorg Pleumann public static class TestTrustManager implements X509TrustManager { 560f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 561adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private X509Certificate[] chain; 562f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 563adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project private String authType; 564f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 565adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkClientTrusted(X509Certificate[] chain, String authType) { 566adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.chain = chain; 567adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.authType = authType; 568adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 569adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 570adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkServerTrusted(X509Certificate[] chain, String authType) { 571adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.chain = chain; 572adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project this.authType = authType; 573adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 574adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 575adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public java.security.cert.X509Certificate[] getAcceptedIssuers() { 576adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return new java.security.cert.X509Certificate[0]; 577adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 578adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 579adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public X509Certificate[] getChain() { 580adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return chain; 581adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 582f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 583adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public String getAuthType() { 584adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project return authType; 585adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 586adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 587adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkClientTrusted( 588adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project java.security.cert.X509Certificate[] chain, String authType) 589adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project throws CertificateException { 590f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 591adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 592adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 593adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void checkServerTrusted( 594adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project java.security.cert.X509Certificate[] chain, String authType) 595adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project throws CertificateException { 596f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 597adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 598f33eae7e84eb6d3b0f4e86b59605bb3de73009f3Elliott Hughes 599adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 600adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 601adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project class MyHandshakeListener implements HandshakeCompletedListener { 602adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 603adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public boolean completeDone; 604adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 605adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project MyHandshakeListener() { 606adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project completeDone = false; 607adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 608adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project 609adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project public void handshakeCompleted(HandshakeCompletedEvent event) { 610adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project if (event != null) completeDone = true; 611adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 612adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project } 613adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project} 614