1/*
2 * Copyright (c) 2012, 2013, Oracle and/or its affiliates. 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 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.
22 */
23
24/*
25 * @test
26 * @bug 7192202
27 * @summary Make sure keytool prints both unknown and unparseable extensions
28 * @modules java.base/sun.security.tools.keytool
29 *          java.base/sun.security.util
30 *          java.base/sun.security.x509
31 * @compile -XDignore.symbol.file UnknownAndUnparseable.java
32 * @run main UnknownAndUnparseable
33 */
34
35import java.io.ByteArrayOutputStream;
36import java.io.File;
37import java.io.PrintStream;
38import sun.security.x509.PKIXExtensions;
39
40public class UnknownAndUnparseable {
41    public static void main(String[] args) throws Exception {
42
43        String s = "-keystore ks -storepass changeit -keypass changeit -debug ";
44        new File("ks").delete();
45
46        // Create a cert with an unknown extension: 1.2.3.4, and an invalid
47        // KeyUsage extension
48        String genkey = s
49                + "-genkeypair -alias a -dname CN=A -ext 1.2.3.4=1234 -keyalg rsa "
50                + "-ext " + PKIXExtensions.KeyUsage_Id.toString() + "=5678";
51        sun.security.tools.keytool.Main.main(genkey.split(" "));
52
53        // Get the list output to a string
54        String list = s + "-list -v";
55        ByteArrayOutputStream bout = new ByteArrayOutputStream();
56        PrintStream oldOut = System.out;
57        System.setOut(new PrintStream(bout));
58        sun.security.tools.keytool.Main.main(list.split(" "));
59        System.setOut(oldOut);
60        String out = bout.toString();
61        System.out.println(out);
62
63        if (!out.contains("1.2.3.4")) {
64            throw new Exception("Unknown extension 1.2.3.4 is not listed");
65        }
66        if (!out.contains("0000: 12 34")) {
67            throw new Exception("Unknown extension 1.2.3.4 has no content");
68        }
69        if (!out.contains("Unparseable KeyUsage")) {
70            throw new Exception("Unparseable KeyUsage is not listed");
71        }
72        if (!out.contains("0000: 56 78")) {
73            throw new Exception("Unparseable KeyUsage has no content");
74        }
75    }
76}
77