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 for both 28 * authoritative data and nonauthoritative data when 29 * java.naming.authoritative is set to false. 30 * @modules java.base/sun.security.util 31 * @library ../lib/ 32 * @run main AuthFalse 33 */ 34 35 import javax.naming.Context; 36 import javax.naming.NamingException; 37 import javax.naming.directory.Attributes; 38 import javax.naming.directory.InitialDirContext; 39 import java.util.Hashtable; 40 41 public class AuthFalse extends AuthRecursiveBase { 42 43 public static void main(String[] args) throws Exception { 44 new AuthFalse().run(args); 45 } 46 47 /* 48 * Tests that we can get the attributes of DNS entries for both 49 * authoritative data and nonauthoritative data when 50 * java.naming.authoritative is set to false. 51 */ 52 @Override public void runTest() throws Exception { 53 initContext(); 54 retrieveAndVerifyAuthData(); 55 retrieveNonAuthData(); 56 } 57 58 @Override public void initContext() throws Exception { 59 Hashtable<Object, Object> env = new Hashtable<>(); 60 // java.naming.authoritative is set to false 61 env.put(Context.AUTHORITATIVE, "false"); 62 setContext(new InitialDirContext(env)); 63 } 64 65 private void retrieveAndVerifyAuthData() throws NamingException { 66 // Ensure that auth data retrieval is OK 67 retrieveAndVerifyData(getFqdnUrl(), new String[] { "*" }); 68 } 69 70 private void retrieveNonAuthData() throws NamingException { 71 // Ensure that nonauth data retrieval is OK 72 Attributes retAttrs = context() 73 .getAttributes(getForeignFqdnUrl(), new String[] { "*" }); 74 DNSTestUtils.debug(retAttrs); 75 // Skip checking attributes for foreign; just successful operation 76 // is sufficient 77 } 78 }