/* * Copyright (c) 2014, 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. */ package test.rowset.spi; import java.security.AccessControlException; import java.security.Policy; import java.util.logging.Level; import java.util.logging.Logger; import javax.naming.Context; import javax.naming.InitialContext; import javax.naming.NamingException; import javax.sql.rowset.spi.SyncFactory; import org.testng.annotations.AfterClass; import org.testng.annotations.BeforeClass; import org.testng.annotations.Test; import util.BaseTest; import util.TestPolicy; public class SyncFactoryPermissionsTests extends BaseTest { Context ctx; private static Policy policy; private static SecurityManager sm; /* * Install a SeeurityManager along with a base Policy to allow testNG to run */ @BeforeClass public static void setUpClass() throws Exception { setPolicy(new TestPolicy()); System.setSecurityManager(new SecurityManager()); } /* * Install the original Policy and SecurityManager */ @AfterClass public static void tearDownClass() throws Exception { System.setSecurityManager(sm); setPolicy(policy); } /* * Initialize a Context to be used in our tests. * Save off the original Policy and SecurityManager */ public SyncFactoryPermissionsTests() { policy = Policy.getPolicy(); sm = System.getSecurityManager(); try { ctx = new InitialContext(); } catch (NamingException ex) { Logger.getLogger(SyncFactoryPermissionsTests.class.getName()). log(Level.SEVERE, null, ex); } } /* * Validate that AccessControlException is thrown if * SQLPermission("setSyncFactory") has not been granted */ @Test(expectedExceptions = AccessControlException.class) public void test() throws Exception { setPolicy(new TestPolicy()); SyncFactory.setJNDIContext(ctx); } /* * Validate that setJNDIContext succeeds if SQLPermission("setSyncFactory") * has been granted */ @Test public void test1() throws Exception { Policy.setPolicy(new TestPolicy("setSyncFactory")); SyncFactory.setJNDIContext(ctx); } /* * Validate that setJNDIContext succeeds if AllPermissions has been granted */ @Test public void test2() throws Exception { setPolicy(new TestPolicy("all")); SyncFactory.setJNDIContext(ctx); } }