jdk/test/sun/security/krb5/IPv6.java
author stefank
Mon, 04 Apr 2016 09:15:01 +0200
changeset 37241 b9961c99c356
parent 32427 c22b7e41adf3
child 40975 680639c9b307
permissions -rw-r--r--
8152538: UL doesn't inline the LogTagSet::is_level check Reviewed-by: mlarsson, brutisso
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3864
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
     1
/*
9035
1255eb81cc2f 7033660: Update copyright year to 2011 on any files changed in 2011
ohair
parents: 7977
diff changeset
     2
 * Copyright (c) 2009, 2011, Oracle and/or its affiliates. All rights reserved.
3864
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
     4
 *
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
     7
 * published by the Free Software Foundation.
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
     8
 *
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    13
 * accompanied this code).
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    14
 *
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    18
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 3944
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 3944
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 3944
diff changeset
    21
 * questions.
3864
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    22
 */
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    23
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    24
/*
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    25
 * @test
3944
e098e010b520 6885166: regression test for 6877357 (IPv6 address does not work) error (timed out)
weijun
parents: 3864
diff changeset
    26
 * @bug 6877357 6885166
9008
1c23e333dd76 7031536: test/sun/security/krb5/auto/HttpNegotiateServer.java should not use static ports
weijun
parents: 7977
diff changeset
    27
 * @run main/othervm IPv6
3864
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    28
 * @summary IPv6 address does not work
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    29
 */
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    30
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    31
import com.sun.security.auth.module.Krb5LoginModule;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    32
import java.io.*;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    33
import java.util.HashMap;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    34
import java.util.Map;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    35
import java.util.regex.Matcher;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    36
import java.util.regex.Pattern;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    37
import javax.security.auth.Subject;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    38
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    39
public class IPv6 {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    40
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    41
    public static void main(String[] args) throws Exception {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    42
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    43
        String[][] kdcs = {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    44
                {"simple.host", null},  // These are legal settings
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    45
                {"simple.host", ""},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    46
                {"simple.host", "8080"},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    47
                {"0.0.0.1", null},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    48
                {"0.0.0.1", ""},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    49
                {"0.0.0.1", "8080"},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    50
                {"1::1", null},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    51
                {"[1::1]", null},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    52
                {"[1::1]", ""},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    53
                {"[1::1]", "8080"},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    54
                {"[1::1", null},        // Two illegal settings
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    55
                {"[1::1]abc", null},
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    56
        };
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    57
        // Prepares a krb5.conf with every kind of KDC settings
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    58
        PrintStream out = new PrintStream(new FileOutputStream("ipv6.conf"));
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    59
        out.println("[libdefaults]");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    60
        out.println("default_realm = V6");
3944
e098e010b520 6885166: regression test for 6877357 (IPv6 address does not work) error (timed out)
weijun
parents: 3864
diff changeset
    61
        out.println("kdc_timeout = 1");
3864
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    62
        out.println("[realms]");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    63
        out.println("V6 = {");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    64
        for (String[] hp: kdcs) {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    65
            if (hp[1] != null) out.println("    kdc = "+hp[0]+":"+hp[1]);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    66
            else out.println("    kdc = " + hp[0]);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    67
        }
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    68
        out.println("}");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    69
        out.close();
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    70
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    71
        System.setProperty("sun.security.krb5.debug", "true");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    72
        System.setProperty("java.security.krb5.conf", "ipv6.conf");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    73
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    74
        ByteArrayOutputStream bo = new ByteArrayOutputStream();
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    75
        PrintStream po = new PrintStream(bo);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    76
        PrintStream oldout = System.out;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    77
        System.setOut(po);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    78
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    79
        try {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    80
            Subject subject = new Subject();
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    81
            Krb5LoginModule krb5 = new Krb5LoginModule();
7977
f47f211cd627 7008713: diamond conversion of kerberos5 and security tools
smarks
parents: 5506
diff changeset
    82
            Map<String, String> map = new HashMap<>();
f47f211cd627 7008713: diamond conversion of kerberos5 and security tools
smarks
parents: 5506
diff changeset
    83
            Map<String, Object> shared = new HashMap<>();
3864
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    84
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    85
            map.put("debug", "true");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    86
            map.put("doNotPrompt", "true");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    87
            map.put("useTicketCache", "false");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    88
            map.put("useFirstPass", "true");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    89
            shared.put("javax.security.auth.login.name", "any");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    90
            shared.put("javax.security.auth.login.password", "any".toCharArray());
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    91
            krb5.initialize(subject, null, shared, map);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    92
            krb5.login();
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    93
        } catch (Exception e) {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    94
            // Ignore
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    95
        }
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    96
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    97
        po.flush();
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    98
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
    99
        System.setOut(oldout);
3944
e098e010b520 6885166: regression test for 6877357 (IPv6 address does not work) error (timed out)
weijun
parents: 3864
diff changeset
   100
        BufferedReader br = new BufferedReader(new StringReader(
e098e010b520 6885166: regression test for 6877357 (IPv6 address does not work) error (timed out)
weijun
parents: 3864
diff changeset
   101
                new String(bo.toByteArray())));
3864
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   102
        int cc = 0;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   103
        Pattern r = Pattern.compile(".*KrbKdcReq send: kdc=(.*) UDP:(\\d+),.*");
3944
e098e010b520 6885166: regression test for 6877357 (IPv6 address does not work) error (timed out)
weijun
parents: 3864
diff changeset
   104
        String line;
e098e010b520 6885166: regression test for 6877357 (IPv6 address does not work) error (timed out)
weijun
parents: 3864
diff changeset
   105
        while ((line = br.readLine()) != null) {
3864
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   106
            Matcher m = r.matcher(line.subSequence(0, line.length()));
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   107
            if (m.matches()) {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   108
                System.out.println("------------------");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   109
                System.out.println(line);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   110
                String h = m.group(1), p = m.group(2);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   111
                String eh = kdcs[cc][0], ep = kdcs[cc][1];
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   112
                if (eh.charAt(0) == '[') {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   113
                    eh = eh.substring(1, eh.length()-1);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   114
                }
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   115
                System.out.println("Expected: " + eh + " : " + ep);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   116
                System.out.println("Actual: " + h + " : " + p);
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   117
                if (!eh.equals(h) ||
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   118
                        (ep == null || ep.length() == 0) && !p.equals("88") ||
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   119
                        (ep != null && ep.length() > 0) && !p.equals(ep)) {
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   120
                    throw new Exception("Mismatch");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   121
                }
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   122
                cc++;
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   123
            }
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   124
        }
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   125
        if (cc != kdcs.length - 2) {    // 2 illegal settings at the end
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   126
            throw new Exception("Not traversed");
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   127
        }
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   128
    }
21eb0b487d1f 6877357: IPv6 address does not work
weijun
parents:
diff changeset
   129
}