1 /* 2 * Copyright (c) 2000, 2018, 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 8200151 27 * @summary Tests that we can get the attributes of DNS entries 28 * authoritative data but not nonauthoritative data when 29 * java.naming.authoritative is set to true. 30 * @modules java.base/sun.security.util 31 * @library ../lib/ 32 * @run main AuthTrue 33 */ 34 35 import javax.naming.Context; 36 import javax.naming.NameNotFoundException; 37 import javax.naming.NamingException; 38 import javax.naming.directory.Attributes; 39 import javax.naming.directory.InitialDirContext; 40 import java.util.Hashtable; 41 42 public class AuthTrue extends AuthRecursiveBase { 43 44 public static void main(String[] args) throws Exception { 45 new AuthTrue().run(args); 46 } 47 48 /* 49 * Tests that we can get the attributes of DNS entries 50 * authoritative data but not nonauthoritative data when 51 * java.naming.authoritative is set to true. 52 */ 53 @Override public void runTest() throws Exception { 54 initContext(); 55 retrieveAndVerifyAuthData(); 56 retrieveNonAuthData(); 57 } 58 59 @Override public void initContext() throws Exception { 60 Hashtable<Object, Object> env = new Hashtable<>(); 61 // java.naming.authoritative is set to true 62 env.put(Context.AUTHORITATIVE, "true"); 63 setContext(new InitialDirContext(env)); 64 } 65 66 private void retrieveAndVerifyAuthData() throws NamingException { 67 // Ensure that auth data retrieval is OK 68 retrieveAndVerifyData(getFqdnUrl(), new String[] { "*" }); 69 } 70 71 private void retrieveNonAuthData() throws NamingException { 72 try { 73 // Ensure that nonauth data retrieval cannot be retrieved 74 Attributes retAttrs = context() 75 .getAttributes(getForeignFqdnUrl(), new String[] { "*" }); 76 DNSTestUtils.debug(retAttrs); 77 throw new RuntimeException( 78 "Failed: Expecting nonauth entry not found " 79 + getForeignFqdnUrl()); 80 81 } catch (NameNotFoundException e) { 82 System.out.println("Got exception as expected : " + e); 83 } 84 } 85 }