/*
 * Copyright (c) 2014, 2021, 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.
 */
import java.security.AccessControlException;
import java.security.Policy;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.naming.Context;
import javax.sql.rowset.spi.SyncFactory;
import javax.sql.rowset.spi.SyncFactoryException;
import org.testng.annotations.AfterClass;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test;
import util.BaseTest;
import util.StubContext;
import util.TestPolicy;
/*
 * @test
 * @library /java/sql/testng
 * @library /javax/sql/testng
 * @run testng/othervm -Djava.security.manager=allow SyncFactoryPermissionsTests
 * @summary Tests SyncFactory permissions.
 */
public class SyncFactoryPermissionsTests extends BaseTest {

    Context ctx;
    private static Policy policy;
    private static SecurityManager sm;
    private final Logger alogger = Logger.getLogger(this.getClass().getName());

    /*
     * 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();
        ctx = new StubContext();
    }

    /*
     * 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 a SyncFactoryException is thrown if the Logger is null
     */
    @Test(expectedExceptions = SyncFactoryException.class)
    public void test00() throws SyncFactoryException {
        Logger l = SyncFactory.getLogger();
    }

    /*
     * Validate that setJNDIContext succeeds if SQLPermission("setSyncFactory")
     * has been granted
     */
    @Test
    public void test01() throws Exception {
        setPolicy(new TestPolicy("setSyncFactory"));
        SyncFactory.setJNDIContext(ctx);
    }

    /*
     * Validate that setJNDIContext succeeds if AllPermissions has been granted
     */
    @Test
    public void test02() throws Exception {
        setPolicy(new TestPolicy("all"));
        SyncFactory.setJNDIContext(ctx);
    }

    /*
     * Validate that AccessControlException is thrown if
     * SQLPermission("setSyncFactory") has not been granted
     */
    @Test(expectedExceptions = AccessControlException.class)
    public void test03() throws Exception {
        setPolicy(new TestPolicy());
        SyncFactory.setLogger(alogger);
    }

    /*
     * Validate that setLogger succeeds if SQLPermission("setSyncFactory")
     * has been granted
     */
    @Test
    public void test04() throws Exception {
        setPolicy(new TestPolicy("setSyncFactory"));
        SyncFactory.setLogger(alogger);
    }

    /*
     * Validate that setLogger succeeds if AllPermissions has been granted
     */
    @Test
    public void test05() throws Exception {
        setPolicy(new TestPolicy("all"));
        SyncFactory.setLogger(alogger);
    }

    /*
     * Validate that AccessControlException is thrown if
     * SQLPermission("setSyncFactory") has not been granted
     */
    @Test(expectedExceptions = AccessControlException.class)
    public void test06() throws Exception {
        setPolicy(new TestPolicy());
        SyncFactory.setLogger(alogger, Level.INFO);
    }

    /*
     * Validate that AccessControlException is thrown if
     * SQLPermission("setSyncFactory")  and LoggingPermission("control", null)
     * have not been granted
     */
    @Test(expectedExceptions = AccessControlException.class)
    public void test07() throws Exception {
        setPolicy(new TestPolicy("setSyncFactory"));
        SyncFactory.setLogger(alogger, Level.INFO);
    }

    /*
     * Validate that setLogger succeeds if SQLPermission("setSyncFactory")
     * has been granted
     */
    @Test
    public void test08() throws Exception {
        setPolicy(new TestPolicy("setSyncFactoryLogger"));
        SyncFactory.setLogger(alogger, Level.INFO);
    }

    /*
     * Validate that setLogger succeeds if AllPermissions has been granted
     */
    @Test
    public void test09() throws Exception {
        setPolicy(new TestPolicy("all"));
        SyncFactory.setLogger(alogger, Level.INFO);
    }
}