blob: f164b1a02fd748523c7493d6bb27483c1e3721ef [file] [log] [blame]
J. Duke319a3b92007-12-01 00:00:00 +00001/*
2 * Copyright 2007 Sun Microsystems, Inc. All Rights Reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
20 * CA 95054 USA or visit www.sun.com if you need additional information or
21 * have any questions.
22 */
23
24/**
25 * @test
26 * @bug 6511784
27 * @summary Make sure that building a path to a CRL issuer works in the
28 * reverse direction
29 * @library ../../../../../java/security/testlibrary
30 * @build CertUtils
31 * @run main BuildPath
32 */
33import java.security.cert.*;
34import java.util.Collections;
35import sun.security.provider.certpath.SunCertPathBuilderParameters;
36
37public class BuildPath {
38
39 public static void main(String[] args) throws Exception {
40
41 TrustAnchor anchor =
42 new TrustAnchor(CertUtils.getCertFromFile("mgrM2mgrM"), null);
43 X509Certificate target = CertUtils.getCertFromFile("mgrM2leadMA");
44 X509CertSelector xcs = new X509CertSelector();
45 xcs.setSubject("CN=leadMA,CN=mgrM,OU=prjM,OU=divE,OU=Comp,O=sun,C=us");
46 xcs.setCertificate(target);
47 SunCertPathBuilderParameters params =
48 new SunCertPathBuilderParameters(Collections.singleton(anchor),xcs);
49 params.setBuildForward(false);
50 CertStore cs = CertUtils.createStore(new String[]
51 {"mgrM2prjM", "prjM2mgrM", "prjM2divE", "mgrM2leadMA" });
52 params.addCertStore(cs);
53 CertStore cs2 = CertUtils.createCRLStore
54 (new String[] {"mgrMcrl", "prjMcrl"});
55 params.addCertStore(cs2);
56 PKIXCertPathBuilderResult res = CertUtils.build(params);
57 }
58}