CertificateMessageTest.java revision 561ee011997c6c2f1befbfaa9d5f0a99771c1d63
1561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes/*
2561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  Licensed to the Apache Software Foundation (ASF) under one or more
3561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  contributor license agreements.  See the NOTICE file distributed with
4561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  this work for additional information regarding copyright ownership.
5561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  The ASF licenses this file to You under the Apache License, Version 2.0
6561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  (the "License"); you may not use this file except in compliance with
7561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  the License.  You may obtain a copy of the License at
8561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *
9561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *     http://www.apache.org/licenses/LICENSE-2.0
10561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *
11561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  Unless required by applicable law or agreed to in writing, software
12561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  distributed under the License is distributed on an "AS IS" BASIS,
13561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  See the License for the specific language governing permissions and
15561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *  limitations under the License.
16561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes */
17561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
18561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughespackage org.apache.harmony.xnet.provider.jsse;
19561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
20561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.io.ByteArrayInputStream;
21561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.io.IOException;
22561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.security.cert.CertificateEncodingException;
23561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.security.cert.CertificateException;
24561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.security.cert.CertificateFactory;
25561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.security.cert.X509Certificate;
26561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.util.Arrays;
27561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
28561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport junit.framework.TestCase;
29561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
30561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes/**
31561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * Tests for <code>CertificateMessage</code> constructor and methods
32561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *
33561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes */
34561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughespublic class CertificateMessageTest extends TestCase {
35561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
36561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	private static String base64certEncoding = "-----BEGIN CERTIFICATE-----\n"
37561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "MIIC+jCCAragAwIBAgICAiswDAYHKoZIzjgEAwEBADAdMRswGQYDVQQKExJDZXJ0a"
38561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "WZpY2F0ZSBJc3N1ZXIwIhgPMTk3MDAxMTIxMzQ2NDBaGA8xOTcwMDEyNDAzMzMyMF"
39561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "owHzEdMBsGA1UEChMUU3ViamVjdCBPcmdhbml6YXRpb24wGTAMBgcqhkjOOAQDAQE"
40561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "AAwkAAQIDBAUGBwiBAgCqggIAVaOCAhQwggIQMA8GA1UdDwEB/wQFAwMBqoAwEgYD"
41561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "VR0TAQH/BAgwBgEB/wIBBTAUBgNVHSABAf8ECjAIMAYGBFUdIAAwZwYDVR0RAQH/B"
42561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "F0wW4EMcmZjQDgyMi5OYW1lggdkTlNOYW1lpBcxFTATBgNVBAoTDE9yZ2FuaXphdG"
43561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "lvboYaaHR0cDovL3VuaWZvcm0uUmVzb3VyY2UuSWSHBP///wCIByoDolyDsgMwDAY"
44561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "DVR0eAQH/BAIwADAMBgNVHSQBAf8EAjAAMIGZBgNVHSUBAf8EgY4wgYsGBFUdJQAG"
45561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "CCsGAQUFBwMBBggrBgEFBQcDAQYIKwYBBQUHAwIGCCsGAQUFBwMDBggrBgEFBQcDB"
46561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "AYIKwYBBQUHAwUGCCsGAQUFBwMGBggrBgEFBQcDBwYIKwYBBQUHAwgGCCsGAQUFBw"
47561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "MJBggrBgEFBQgCAgYKKwYBBAGCNwoDAwYJYIZIAYb4QgQBMA0GA1UdNgEB/wQDAgE"
48561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "BMA4GBCpNhgkBAf8EAwEBATBkBgNVHRIEXTBbgQxyZmNAODIyLk5hbWWCB2ROU05h"
49561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "bWWkFzEVMBMGA1UEChMMT3JnYW5pemF0aW9uhhpodHRwOi8vdW5pZm9ybS5SZXNvd"
50561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "XJjZS5JZIcE////AIgHKgOiXIOyAzAJBgNVHR8EAjAAMAoGA1UdIwQDAQEBMAoGA1"
51561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "UdDgQDAQEBMAoGA1UdIQQDAQEBMAwGByqGSM44BAMBAQADMAAwLQIUAL4QvoazNWP"
52561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "7jrj84/GZlhm09DsCFQCBKGKCGbrP64VtUt4JPmLjW1VxQA==\n"
53561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			+ "-----END CERTIFICATE-----\n";
54561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
55561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	/*
56561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	 * Test for CertificateMessage(null) and
57561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	 * CertificateMessage(HandshakeIODataStream, int)
58561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	 */
59561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	public void testCertificateMessage1() throws Exception {
60561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
61561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		CertificateMessage message = new CertificateMessage(null);
62561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("incorrect type", Handshake.CERTIFICATE, message.getType());
63561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("incorrect message", 3, message.length());
64561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("incorrect message", 0, message.certs.length);
65561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
66561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		HandshakeIODataStream out = new HandshakeIODataStream();
67561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		message.send(out);
68561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		byte[] encoded = out.getData(1000);
69561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("incorrect out data length", message.length(), encoded.length);
70561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
71561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		HandshakeIODataStream in = new HandshakeIODataStream();
72561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		in.append(encoded);
73561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
74561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		CertificateMessage message_2 = new CertificateMessage(in, message.length());
75561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("incorrect message_2", 3, message_2.length());
76561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("incorrect message_2", 0, message_2.certs.length);
77561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	}
78561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
79561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	/*
80561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	 * Test for void CertificateMessage(X509Certificate[]),
81561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	 * CertificateMessage(HandshakeIODataStream, int)
82561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	 */
83561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	public void testCertificateMessage2() throws Exception {
84561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		CertificateFactory certFactory = CertificateFactory.getInstance("X509");
85561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
86561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		ByteArrayInputStream bais = new ByteArrayInputStream(base64certEncoding
87561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes				.getBytes("UTF-8"));
88561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		X509Certificate cert = (X509Certificate) certFactory.generateCertificate(bais);
89561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		CertificateMessage message = new CertificateMessage(
90561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes				new X509Certificate[] { cert });
91561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("incorrect type", Handshake.CERTIFICATE, message.getType());
92561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
93561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertTrue("incorrect cert encoding", Arrays.equals(message.certs[0]
94561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                .getEncoded(), cert.getEncoded()));
95561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
96561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		HandshakeIODataStream out = new HandshakeIODataStream();
97561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		message.send(out);
98561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		byte[] encoded = out.getData(1000);
99561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("incorrect out data length", message.length(), encoded.length);
100561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
101561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		HandshakeIODataStream in = new HandshakeIODataStream();
102561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		in.append(encoded);
103561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		CertificateMessage message_2 = new CertificateMessage(in, message.length());
104561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertEquals("Incorrect message decoding", message.certs.length, message_2.certs.length);
105561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        assertTrue("incorrect cert encoding", Arrays.equals(message.certs[0]
106561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                .getEncoded(), message_2.certs[0].getEncoded()));
107561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
108561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		in.append(encoded);
109561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		try {
110561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			message_2 = new CertificateMessage(in, message.length() - 1);
111561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			fail("Small length: No expected AlertException");
112561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		} catch (AlertException e) {
113561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		}
114561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
115561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		in.append(encoded);
116561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		in.append(new byte[] { 1, 2, 3 });
117561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		try {
118561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			message_2 = new CertificateMessage(in, message.length() + 3);
119561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes			fail("Extra bytes: No expected AlertException ");
120561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		} catch (AlertException e) {
121561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes		}
122561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes	}
123561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
124561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes}
125