author | prr |
Fri, 25 May 2018 12:12:24 -0700 | |
changeset 50347 | b2f046ae8eb6 |
parent 47216 | 71c04702a3d5 |
permissions | -rw-r--r-- |
2 | 1 |
/* |
5506 | 2 |
* Copyright (c) 2001, 2008, Oracle and/or its affiliates. All rights reserved. |
2 | 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 |
* |
|
5506 | 19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
20 |
* or visit www.oracle.com if you need additional information or have any |
|
21 |
* questions. |
|
2 | 22 |
*/ |
23 |
||
24 |
/** |
|
25 |
* @test |
|
26 |
* @bug 4414263 |
|
27 |
* @summary Make sure PolicyNode.getPolicyQualifiers() returns |
|
28 |
* Set of PolicyQualifierInfos. |
|
29 |
*/ |
|
30 |
import java.io.File; |
|
31 |
import java.io.FileInputStream; |
|
32 |
import java.security.cert.*; |
|
33 |
import java.util.Collections; |
|
34 |
import java.util.Iterator; |
|
35 |
import java.util.List; |
|
36 |
import java.util.Set; |
|
37 |
||
38 |
public class GetPolicyQualifiers { |
|
39 |
||
40 |
public static void main(String[] args) throws Exception { |
|
41 |
||
42 |
CertificateFactory cf = CertificateFactory.getInstance("X.509", "SUN"); |
|
43 |
File f = new File(System.getProperty("test.src", "."), "speech2speech"); |
|
44 |
X509Certificate mostTrustedCaCert = (X509Certificate) |
|
45 |
cf.generateCertificate(new FileInputStream(f)); |
|
46 |
Set trustAnchors = Collections.singleton( |
|
47 |
new TrustAnchor(mostTrustedCaCert, null)); |
|
48 |
f = new File(System.getProperty("test.src", "."), "speech2eve"); |
|
49 |
X509Certificate eeCert = (X509Certificate) |
|
50 |
cf.generateCertificate(new FileInputStream(f)); |
|
51 |
CertPathValidator cpv = CertPathValidator.getInstance("PKIX", "SUN"); |
|
52 |
PKIXParameters params = new PKIXParameters(trustAnchors); |
|
53 |
params.setPolicyQualifiersRejected(false); |
|
54 |
params.setRevocationEnabled(false); |
|
55 |
List certList = Collections.singletonList(eeCert); |
|
56 |
CertPath cp = cf.generateCertPath(certList); |
|
57 |
PKIXCertPathValidatorResult result = |
|
58 |
(PKIXCertPathValidatorResult) cpv.validate(cp, params); |
|
59 |
||
60 |
PolicyNode policyTree = result.getPolicyTree(); |
|
61 |
Iterator children = policyTree.getChildren(); |
|
62 |
PolicyNode child = (PolicyNode) children.next(); |
|
63 |
Set policyQualifiers = child.getPolicyQualifiers(); |
|
64 |
Iterator i = policyQualifiers.iterator(); |
|
65 |
while (i.hasNext()) { |
|
66 |
Object next = i.next(); |
|
67 |
if (!(next instanceof PolicyQualifierInfo)) |
|
68 |
throw new Exception("not a PolicyQualifierInfo"); |
|
69 |
} |
|
70 |
||
71 |
params.setPolicyQualifiersRejected(true); |
|
72 |
try { |
|
73 |
result = (PKIXCertPathValidatorResult) cpv.validate(cp, params); |
|
74 |
throw new Exception("Validation of CertPath containing critical " + |
|
75 |
"qualifiers should have failed when policyQualifiersRejected " + |
|
76 |
"flag is true"); |
|
1238
6d1f4b722acd
6465942: Add problem identification facility to the CertPathValidator framework
mullan
parents:
2
diff
changeset
|
77 |
} catch (CertPathValidatorException cpve) { |
6d1f4b722acd
6465942: Add problem identification facility to the CertPathValidator framework
mullan
parents:
2
diff
changeset
|
78 |
if (cpve.getReason() != PKIXReason.INVALID_POLICY) { |
6d1f4b722acd
6465942: Add problem identification facility to the CertPathValidator framework
mullan
parents:
2
diff
changeset
|
79 |
throw new Exception("unexpected reason: " + cpve.getReason()); |
6d1f4b722acd
6465942: Add problem identification facility to the CertPathValidator framework
mullan
parents:
2
diff
changeset
|
80 |
} |
6d1f4b722acd
6465942: Add problem identification facility to the CertPathValidator framework
mullan
parents:
2
diff
changeset
|
81 |
} |
2 | 82 |
} |
83 |
} |