2009-02-23 02:04:25 +00:00
|
|
|
/*
|
2011-03-28 10:04:10 +00:00
|
|
|
* Copyright (c) 2009, 2011, Oracle and/or its affiliates. All rights reserved.
|
2009-02-23 02:04:25 +00:00
|
|
|
* 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.
|
|
|
|
*
|
2010-05-25 22:58:33 +00:00
|
|
|
* 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.
|
2009-02-23 02:04:25 +00:00
|
|
|
*/
|
|
|
|
/*
|
|
|
|
* @test
|
2013-09-18 10:22:49 +00:00
|
|
|
* @bug 6789935 8012615
|
2015-05-28 17:54:48 +00:00
|
|
|
* @modules java.security.jgss/sun.security.krb5
|
2011-03-28 10:04:10 +00:00
|
|
|
* @run main/othervm ParseCAPaths
|
2009-02-23 02:04:25 +00:00
|
|
|
* @summary cross-realm capath search error
|
|
|
|
*/
|
|
|
|
|
|
|
|
import java.util.Arrays;
|
|
|
|
import sun.security.krb5.Realm;
|
|
|
|
|
|
|
|
public class ParseCAPaths {
|
2011-03-28 10:04:10 +00:00
|
|
|
static Exception failed = null;
|
2009-02-23 02:04:25 +00:00
|
|
|
public static void main(String[] args) throws Exception {
|
2011-03-28 10:04:10 +00:00
|
|
|
System.setProperty("java.security.krb5.conf",
|
|
|
|
System.getProperty("test.src", ".") +"/krb5-capaths.conf");
|
2009-02-23 02:04:25 +00:00
|
|
|
|
2013-09-18 10:22:49 +00:00
|
|
|
// MIT
|
2009-02-23 02:04:25 +00:00
|
|
|
check("ANL.GOV", "TEST.ANL.GOV", "ANL.GOV");
|
|
|
|
check("ANL.GOV", "ES.NET", "ANL.GOV");
|
|
|
|
check("ANL.GOV", "PNL.GOV", "ANL.GOV", "ES.NET");
|
|
|
|
check("ANL.GOV", "NERSC.GOV", "ANL.GOV", "ES.NET");
|
2013-09-18 10:22:49 +00:00
|
|
|
check("NERSC.GOV", "TEST.ANL.GOV", "NERSC.GOV", "ES.NET", "ANL.GOV");
|
|
|
|
|
|
|
|
// RedHat
|
|
|
|
// 3.6.2.1. Configuring a Shared Hierarchy of Names
|
|
|
|
check("AA.EXAMPLE.COM", "BB.EXAMPLE.COM",
|
|
|
|
"AA.EXAMPLE.COM", "EXAMPLE.COM");
|
|
|
|
check("SITE1.SALES.EXAMPLE.COM", "EVERYWHERE.EXAMPLE.COM",
|
|
|
|
"SITE1.SALES.EXAMPLE.COM", "SALES.EXAMPLE.COM",
|
|
|
|
"EXAMPLE.COM");
|
|
|
|
check("DEVEL.EXAMPLE.COM", "PROD.EXAMPLE.ORG",
|
|
|
|
"DEVEL.EXAMPLE.COM", "EXAMPLE.COM", "COM",
|
|
|
|
"ORG", "EXAMPLE.ORG");
|
|
|
|
// 3.6.2.2. Configuring Paths in krb5.conf
|
|
|
|
check("A.EXAMPLE.COM", "B.EXAMPLE.COM", "A.EXAMPLE.COM");
|
|
|
|
check("A.EXAMPLE.COM", "C.EXAMPLE.COM",
|
|
|
|
"A.EXAMPLE.COM", "B.EXAMPLE.COM");
|
|
|
|
check("A.EXAMPLE.COM", "D.EXAMPLE.COM",
|
|
|
|
"A.EXAMPLE.COM", "B.EXAMPLE.COM", "C.EXAMPLE.COM");
|
|
|
|
|
|
|
|
// The original JDK example
|
|
|
|
check("TIVOLI.COM", "IBM.COM", "TIVOLI.COM", "LDAPCENTRAL.NET",
|
|
|
|
"IBM_LDAPCENTRAL.COM", "MOONLITE.ORG");
|
|
|
|
|
2009-02-23 02:04:25 +00:00
|
|
|
// Hierachical
|
2013-09-18 10:22:49 +00:00
|
|
|
check("N1.N.COM", "N2.N.COM", "N1.N.COM", "N.COM");
|
|
|
|
check("N1.N.COM", "N2.N3.COM", "N1.N.COM", "N.COM",
|
2009-02-23 02:04:25 +00:00
|
|
|
"COM", "N3.COM");
|
2013-09-18 10:22:49 +00:00
|
|
|
check("N1.COM", "N2.COM", "N1.COM", "COM");
|
|
|
|
check("N1", "N2", "N1");
|
|
|
|
check("N1.COM", "N2.ORG", "N1.COM", "COM", "ORG");
|
|
|
|
check("N1.N.COM", "N.COM", "N1.N.COM");
|
|
|
|
check("X.N1.N.COM", "N.COM", "X.N1.N.COM", "N1.N.COM");
|
|
|
|
check("N.COM", "N1.N.COM", "N.COM");
|
|
|
|
check("N.COM", "X.N1.N.COM", "N.COM", "N1.N.COM");
|
|
|
|
check("A.B.C", "D.E.F", "A.B.C", "B.C", "C", "F", "E.F");
|
|
|
|
|
|
|
|
// Full path
|
|
|
|
check("A1.COM", "A2.COM", "A1.COM");
|
|
|
|
check("A1.COM", "A3.COM", "A1.COM", "A2.COM");
|
|
|
|
check("A1.COM", "A4.COM", "A1.COM", "A2.COM", "A3.COM");
|
|
|
|
|
|
|
|
// Shortest path
|
|
|
|
check("B1.COM", "B2.COM", "B1.COM");
|
2009-02-23 02:04:25 +00:00
|
|
|
check("B1.COM", "B3.COM", "B1.COM", "B2.COM");
|
2013-09-18 10:22:49 +00:00
|
|
|
check("B1.COM", "B4.COM", "B1.COM", "B2.COM", "B3.COM");
|
|
|
|
|
2009-02-23 02:04:25 +00:00
|
|
|
// Missing is "."
|
2013-09-18 10:22:49 +00:00
|
|
|
check("C1.COM", "C2.COM", "C1.COM", "COM");
|
2009-02-23 02:04:25 +00:00
|
|
|
check("C1.COM", "C3.COM", "C1.COM", "C2.COM");
|
2013-09-18 10:22:49 +00:00
|
|
|
|
|
|
|
// cRealm = .
|
|
|
|
check("D1.COM", "D2.COM", "D1.COM");
|
|
|
|
|
|
|
|
// Bad cases
|
|
|
|
check("E1.COM", "E2.COM", "E1.COM");
|
|
|
|
check("E1.COM", "E3.COM", "E1.COM", "E4.COM");
|
|
|
|
check("G1.COM", "G3.COM", "G1.COM", "G2.COM");
|
2009-02-23 02:04:25 +00:00
|
|
|
check("I1.COM", "I4.COM", "I1.COM", "I5.COM");
|
2013-09-18 10:22:49 +00:00
|
|
|
|
2011-03-28 10:04:10 +00:00
|
|
|
// 7019384
|
|
|
|
check("A9.PRAGUE.XXX.CZ", "SERVIS.XXX.CZ",
|
|
|
|
"A9.PRAGUE.XXX.CZ", "PRAGUE.XXX.CZ", "ROOT.XXX.CZ");
|
2013-09-18 10:22:49 +00:00
|
|
|
|
2011-03-28 10:04:10 +00:00
|
|
|
if (failed != null) {
|
|
|
|
throw failed;
|
2009-02-23 02:04:25 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void check(String from, String to, String... paths) {
|
|
|
|
try {
|
|
|
|
check2(from, to, paths);
|
|
|
|
} catch (Exception e) {
|
2013-09-18 10:22:49 +00:00
|
|
|
System.out.println(" " + e.getMessage());
|
2011-03-28 10:04:10 +00:00
|
|
|
failed = e;
|
2009-02-23 02:04:25 +00:00
|
|
|
}
|
|
|
|
}
|
2011-03-28 10:04:10 +00:00
|
|
|
|
2009-02-23 02:04:25 +00:00
|
|
|
static void check2(String from, String to, String... paths)
|
|
|
|
throws Exception {
|
|
|
|
System.out.println(from + " -> " + to);
|
|
|
|
System.out.println(" expected: " + Arrays.toString(paths));
|
|
|
|
String[] result = Realm.getRealmsList(from, to);
|
2013-09-18 10:22:49 +00:00
|
|
|
if (result == null || result.length == 0) {
|
|
|
|
throw new Exception("There is always a valid path.");
|
2009-02-23 02:04:25 +00:00
|
|
|
} else if(result.length != paths.length) {
|
|
|
|
throw new Exception("Length of path not correct");
|
|
|
|
} else {
|
|
|
|
for (int i=0; i<result.length; i++) {
|
|
|
|
if (!result[i].equals(paths[i])) {
|
2013-09-18 10:22:49 +00:00
|
|
|
System.out.println(" result: " + Arrays.toString(result));
|
2009-02-23 02:04:25 +00:00
|
|
|
throw new Exception("Path not same");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|