test/jdk/sun/security/krb5/config/Duplicates.java
author jboes
Fri, 08 Nov 2019 11:15:16 +0000
changeset 59029 3786a0962570
parent 47216 71c04702a3d5
permissions -rw-r--r--
8232853: AuthenticationFilter.Cache::remove may throw ConcurrentModificationException Summary: Change implementation to use iterator instead of plain LinkedList Reviewed-by: dfuchs, vtewari

/*
 * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */
/*
 * @test
 * @bug 7184246
 * @modules java.security.jgss/sun.security.krb5
 * @compile -XDignore.symbol.file Duplicates.java
 * @run main/othervm Duplicates
 * @summary Simplify Config.get() of krb5
 */

import sun.security.krb5.Config;

public class Duplicates {
    public static void main(String[] args) throws Exception {
        System.setProperty("java.security.krb5.conf",
                System.getProperty("test.src", ".") +"/k1.conf");
        Config config = Config.getInstance();
        config.listTable();
        String s;

        // root section merged
        s = config.get("libdefaults", "default_realm");
        if (!s.equals("R1")) {
            throw new Exception();
        }
        // Former is preferred to latter for strings and sections
        s = config.get("libdefaults", "default_tkt_enctypes");
        if (!s.equals("aes128-cts")) {
            throw new Exception();
        }
        s = config.get("realms", "R1", "kdc");
        if (!s.equals("k1")) {
            throw new Exception(s);
        }
        // Duplicate keys in [realms] are merged, and sections with the same
        // name in between ignored
        s = config.getAll("realms", "R2", "kdc");
        if (!s.equals("k1 k2 k3 k4")) {
            throw new Exception(s);
        }
        // Duplicate keys in [capaths] are merged
        s = config.getAll("capaths", "R1", "R2");
        if (!s.equals("R3 R4 R5 R6")) {
            throw new Exception(s);
        }
        // We can be very deep now
        s = config.get("new", "x", "y", "z", "a", "b", "c");
        if (!s.equals("d")) {
            throw new Exception(s);
        }
    }
}