uk.ac.ox.it.ords.api.audit.resources.AbstractResourceTest.java Source code

Java tutorial

Introduction

Here is the source code for uk.ac.ox.it.ords.api.audit.resources.AbstractResourceTest.java

Source

/*
 * Copyright 2015 University of Oxford
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *     http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package uk.ac.ox.it.ords.api.audit.resources;

import java.util.ArrayList;
import java.util.List;

import org.apache.cxf.endpoint.Server;
import org.apache.cxf.jaxrs.JAXRSServerFactoryBean;
import org.apache.cxf.jaxrs.client.WebClient;
import org.apache.cxf.jaxrs.lifecycle.ResourceProvider;
import org.apache.cxf.jaxrs.lifecycle.SingletonResourceProvider;
import org.apache.cxf.transport.local.LocalConduit;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.config.IniSecurityManagerFactory;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.util.Factory;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.BeforeClass;

import com.fasterxml.jackson.jaxrs.json.JacksonJsonProvider;

import uk.ac.ox.it.ords.api.audit.permissions.AuditPermissions;
import uk.ac.ox.it.ords.api.audit.server.UnrecognizedPropertyExceptionMapper;
import uk.ac.ox.it.ords.api.audit.server.ValidationExceptionMapper;
import uk.ac.ox.it.ords.security.AbstractShiroTest;
import uk.ac.ox.it.ords.security.model.Permission;
import uk.ac.ox.it.ords.security.model.UserRole;
import uk.ac.ox.it.ords.security.services.PermissionsService;
import uk.ac.ox.it.ords.security.services.impl.hibernate.HibernateUtils;

public class AbstractResourceTest extends AbstractShiroTest {

    protected final static String ENDPOINT_ADDRESS = "local://audit-api";
    protected static Server server;

    protected static void startServer() throws Exception {

    }

    public WebClient getClient() {
        List<Object> providers = new ArrayList<Object>();
        providers.add(new JacksonJsonProvider());
        WebClient client = WebClient.create(ENDPOINT_ADDRESS, providers);
        client.type("application/json");
        client.accept("application/json");
        WebClient.getConfig(client).getRequestContext().put(LocalConduit.DIRECT_DISPATCH, Boolean.TRUE);
        return client;
    }

    public static void createTestUsersAndRoles() throws Exception {
        //
        // Set up the database
        //
        //
        // Set up the test users and their permissions
        //
        //
        // Add our test permissions
        //
        Permission permissionObject = new Permission();
        permissionObject.setRole("admin");
        permissionObject.setPermission(AuditPermissions.CREATE_AUDIT_RECORD);
        PermissionsService.Factory.getInstance().createPermission(permissionObject);

        permissionObject = new Permission();
        permissionObject.setRole("admin");
        permissionObject.setPermission(AuditPermissions.VIEW_ALL_AUDIT_RECORDS);
        PermissionsService.Factory.getInstance().createPermission(permissionObject);

        permissionObject = new Permission();
        permissionObject.setRole("user");
        permissionObject.setPermission(AuditPermissions.VIEW_AUDIT_RECORD_FOR_PROJECT(1));
        PermissionsService.Factory.getInstance().createPermission(permissionObject);

        //
        // Add test users to roles
        //
        Session session = HibernateUtils.getSessionFactory().getCurrentSession();
        Transaction transaction = session.beginTransaction();
        UserRole admin = new UserRole();
        admin.setPrincipalName("admin");
        admin.setRole("admin");
        session.save(admin);
        transaction.commit();
        HibernateUtils.closeSession();

        session = HibernateUtils.getSessionFactory().getCurrentSession();
        transaction = session.beginTransaction();
        UserRole user = new UserRole();
        user.setPrincipalName("pingu");
        user.setRole("user");
        session.save(user);
        transaction.commit();
        HibernateUtils.closeSession();

        //
        // Clear the audit trail
        //
        session = HibernateUtils.getSessionFactory().getCurrentSession();
        session.beginTransaction();
        session.createSQLQuery("truncate ordsaudit").executeUpdate();
        session.getTransaction().commit();
        HibernateUtils.closeSession();

    }

    /**
     * Configure Shiro and start the server
     * @throws Exception
     */
    @BeforeClass
    public static void initialize() throws Exception {

        //
        // Set up roles
        //
        createTestUsersAndRoles();

        //
        // This is for unit testing only and uses the test.shiro.ini configuration
        //
        Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:test.shiro.ini");
        SecurityManager securityManager = factory.getInstance();
        SecurityUtils.setSecurityManager(securityManager);

        //
        // Create an embedded server with JSON processing
        //
        JAXRSServerFactoryBean sf = new JAXRSServerFactoryBean();

        ArrayList<Object> providers = new ArrayList<Object>();
        providers.add(new JacksonJsonProvider());
        providers.add(new UnrecognizedPropertyExceptionMapper());
        providers.add(new ValidationExceptionMapper());
        sf.setProviders(providers);

        //
        // Add our REST resources to the server
        //
        ArrayList<ResourceProvider> resources = new ArrayList<ResourceProvider>();
        resources.add(new SingletonResourceProvider(new AuditResource(), true));
        sf.setResourceProviders(resources);

        //
        // Start the server at the endpoint
        //
        sf.setAddress(ENDPOINT_ADDRESS);
        server = sf.create();
        startServer();
    }

    @AfterClass
    public static void destroy() throws Exception {
        server.stop();
        server.destroy();
    }

    @After
    public void logout() {
        SecurityUtils.getSubject().logout();
    }

}