jdk/test/javax/security/auth/login/Configuration/GetInstanceSecurity.java
changeset 2 90ce3da70b43
child 5506 202f599c92aa
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/jdk/test/javax/security/auth/login/Configuration/GetInstanceSecurity.java	Sat Dec 01 00:00:00 2007 +0000
@@ -0,0 +1,106 @@
+/*
+ * Copyright 2005 Sun Microsystems, Inc.  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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+ * CA 95054 USA or visit www.sun.com if you need additional information or
+ * have any questions.
+ */
+
+/*
+ * @test
+ * @bug 6268315
+ * @summary Configuration should be provider-based
+ * @build GetInstanceConfigSpi GetInstanceProvider
+ * @run main/othervm/policy=GetInstanceSecurity.policy GetInstanceSecurity
+ */
+
+import java.io.File;
+import java.net.URI;
+import java.security.*;
+import javax.security.auth.login.*;
+
+import sun.net.www.ParseUtil;
+
+public class GetInstanceSecurity {
+
+    private static final String JAVA_CONFIG = "JavaLoginConfig";
+
+    public static void main(String[] args) throws Exception {
+        try {
+            Configuration c = Configuration.getInstance(JAVA_CONFIG, null);
+            throw new RuntimeException("did not catch security exception");
+        } catch (SecurityException se) {
+            // good
+        }
+
+        try {
+            Configuration c = Configuration.getInstance
+                        (JAVA_CONFIG, null, "SUN");
+            throw new RuntimeException("did not catch security exception");
+        } catch (SecurityException se) {
+            // good
+        }
+
+        try {
+            Configuration c = Configuration.getInstance
+                        (JAVA_CONFIG, null, Security.getProvider("SUN"));
+            throw new RuntimeException("did not catch security exception");
+        } catch (SecurityException se) {
+            // good
+        }
+
+        // set a new policy that grants the perms, and then re-check perms
+
+        File file = new File(System.getProperty("test.src", "."),
+                                "GetInstanceSecurity.grantedPolicy");
+        URI uri = file.toURI();
+        URIParameter param = new URIParameter(uri);
+        Policy p = Policy.getInstance("JavaPolicy", param, "SUN");
+        Policy.setPolicy(p);
+
+        // retry operations
+
+        file = new File(System.getProperty("test.src", "."),
+                        "GetInstance.config");
+        URIParameter uriParam = new URIParameter(file.toURI());
+
+        try {
+            Configuration c = Configuration.getInstance(JAVA_CONFIG, uriParam);
+        } catch (SecurityException se) {
+            throw new RuntimeException("unexpected SecurityException");
+        }
+
+        try {
+            Configuration c = Configuration.getInstance
+                        (JAVA_CONFIG, uriParam, "SUN");
+            // good
+        } catch (SecurityException se) {
+            throw new RuntimeException("unexpected SecurityException");
+        }
+
+        try {
+            Configuration c = Configuration.getInstance
+                        (JAVA_CONFIG, uriParam, Security.getProvider("SUN"));
+            // good
+        } catch (SecurityException se) {
+            throw new RuntimeException("unexpected SecurityException");
+        }
+
+        System.out.println("test passed");
+    }
+}