⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 permissiontest.java

📁 Rapla是一个灵活的多用户资源管理系统。它提供的一些功能有:日历GUI
💻 JAVA
字号:
/*--------------------------------------------------------------------------*
 | Copyright (C) 2006 Christopher Kohlhaas                                  |
 |                                                                          |
 | This program is free software; you can redistribute it and/or modify     |
 | it under the terms of the GNU General Public License as published by the |
 | Free Software Foundation. A copy of the license has been included with   |
 | these distribution in the COPYING file, if not go to www.fsf.org         |
 |                                                                          |
 | As a special exception, you are granted the permissions to link this     |
 | program with every library, which license fulfills the Open Source       |
 | Definition as published by the Open Source Initiative (OSI).             |
 *--------------------------------------------------------------------------*/
package org.rapla;
import java.util.Date;
import java.util.Locale;

import org.rapla.components.util.DateTools;
import org.rapla.entities.Category;
import org.rapla.entities.User;
import org.rapla.entities.domain.Allocatable;
import org.rapla.entities.domain.Appointment;
import org.rapla.entities.domain.Permission;
import org.rapla.entities.domain.Reservation;
import org.rapla.entities.dynamictype.ClassificationFilter;
import org.rapla.facade.ClientFacade;
import org.rapla.server.ServerService;
import org.rapla.storage.RaplaSecurityException;


public class PermissionTest extends ServletTestBase {
    ServerService raplaServer;

    ClientFacade adminFacade;
    ClientFacade testFacade;
    Locale locale;

    public PermissionTest(String name) {
        super(name);
    }

    protected void setUp() throws Exception {
        super.setUp();
        // start the server
        raplaServer = (ServerService)
            getContext().lookup(ServerService.ROLE + "/storage-file");
        // start the client service
        adminFacade = (ClientFacade)
            getContext().lookup(ClientFacade.ROLE + "/remote-facade");
        adminFacade.login("homer","duffs".toCharArray());
        locale = Locale.getDefault();
        try
        {
            Category groups = (Category) adminFacade.edit( adminFacade.getUserGroupsCategory() );
            Category testGroup = adminFacade.newCategory();
            testGroup.setKey("test-group");
            groups.addCategory( testGroup );
            adminFacade.store( groups );
    
            User user = adminFacade.newUser();
            user.setUsername("test");
            user.addGroup( testGroup );
            adminFacade.store( user );
            adminFacade.changePassword( user, new char[]{}, new char[] {});
        }
        catch (Exception ex) {
            adminFacade.logout();
            super.tearDown();
            throw ex;
        }
        // Wait for update;
        testFacade = (ClientFacade)
        	getContext().lookup(ClientFacade.ROLE + "/remote-facade-2");
        boolean canLogin = testFacade.login("test","".toCharArray());
        assertTrue( "Can't login", canLogin );
    }

    protected void tearDown() throws Exception {
        adminFacade.logout();
        testFacade.logout();
        super.tearDown();
    }

    public void testReadPermissions() throws Exception {
        // first create a new resource and set the permissions

        Allocatable allocatable = adminFacade.newResource();
        allocatable.getClassification().setValue("name","test-allocatable");
        //remove default permission.
        allocatable.removePermission( allocatable.getPermissions()[0] );
        Permission permission = allocatable.newPermission();
        Category testGroup = adminFacade.getUserGroupsCategory().getCategory("test-group");
        permission.setGroup ( testGroup );
        permission.setAccessLevel( Permission.READ );
        allocatable.addPermission( permission );
        adminFacade.store( allocatable );
        // Wait for update
        testFacade.refresh();
        // test the permissions in the second facade.
        clientReadPermissions();
    }
    public void testAllocatePermissions() throws Exception {
        // first create a new resource and set the permissions

        Allocatable allocatable = adminFacade.newResource();
        allocatable.getClassification().setValue("name","test-allocatable");
        //remove default permission.
        allocatable.removePermission( allocatable.getPermissions()[0] );
        Permission permission = allocatable.newPermission();
        Category testGroup = adminFacade.getUserGroupsCategory().getCategory("test-group");
        permission.setGroup ( testGroup );
        permission.setAccessLevel( Permission.ALLOCATE );
        allocatable.addPermission( permission );
        adminFacade.store( allocatable );
        // Wait for update
        testFacade.refresh();

        // test the permissions in the second facade.
        clientAllocatePermissions();

        // Uncovers bug 1237332,
        ClassificationFilter filter = testFacade.getDynamicType("event").newClassificationFilter();
        filter.addEqualsRule("name","R1");
        Reservation evt = testFacade.getReservations( null, null, null, new ClassificationFilter[] {filter} )[0];
        evt = (Reservation) testFacade.edit( evt );
        evt.removeAllocatable( allocatable );
        testFacade.store( evt );

        allocatable = (Allocatable)adminFacade.edit( allocatable );
        allocatable.getPermissions()[0].setAccessLevel( Permission.READ);
        adminFacade.store( allocatable );

        testFacade.refresh();


        evt = (Reservation) testFacade.edit( evt );
        evt.addAllocatable( allocatable );
        try {
            testFacade.store( evt );
            fail("RaplaSecurityException expected!");
        } catch (RaplaSecurityException ex) {
        //  System.err.println ( ex.getMessage());
        }

        Allocatable allocatable2 = adminFacade.newResource();
        allocatable2.getClassification().setValue("name","test-allocatable2");
        permission = allocatable.newPermission();
        permission.setUser( testFacade.getUser());
        permission.setAccessLevel( Permission.ADMIN);
        allocatable2.addPermission( permission );
        adminFacade.store( allocatable2 );
        testFacade.refresh();
        evt.addAllocatable( allocatable2 );
        try {
            testFacade.store( evt );
            fail("RaplaSecurityException expected!");
        } catch (RaplaSecurityException ex) {
        }
        Thread.sleep( 100);

    }

    private Allocatable getTestResource() throws Exception {
        Allocatable[] all = testFacade.getAllocatables();
        for ( int i=0;i< all.length; i++ ){
            if ( all[i].getName( locale ).equals("test-allocatable") ) {
                return all [i];
            }
        }
        return null;
    }

    private void clientReadPermissions() throws Exception {
        User user = testFacade.getUser();
        Allocatable a = getTestResource();
        assertNotNull( a );
        assertTrue( a.canRead( user ) );
        assertTrue( !a.canModify( user ) );
        assertTrue( !a.canCreateConflicts( user ) );
        assertTrue( !a.canAllocate( user, null, null, testFacade.today()));
    }

    private void clientAllocatePermissions() throws Exception {
        Allocatable allocatable = getTestResource();
        User user = testFacade.getUser();
        assertNotNull( allocatable );
        assertTrue( allocatable.canRead( user ) );
        Date start1 = testFacade.today();
        Date end1 = new Date(start1.getTime() + DateTools.MILLISECONDS_PER_HOUR * 2);
        Date start2 = new Date(start1.getTime() + DateTools.MILLISECONDS_PER_HOUR * 1);
        Date end2 = new Date(start1.getTime() + DateTools.MILLISECONDS_PER_HOUR * 3);
        assertTrue( allocatable.canAllocate( user, null, null, testFacade.today() ) );

        Reservation r1 = testFacade.newReservation();
        r1.getClassification().setValue("name","R1");
		Appointment a1 = testFacade.newAppointment( start1, end1 );
		r1.addAppointment( a1 );
		r1.addAllocatable( allocatable );

		testFacade.store( r1 );

		Reservation r2 = testFacade.newReservation();
		r2.getClassification().setValue("name","R2");
		Appointment a2 = testFacade.newAppointment( start2, end2 );
		r2.addAppointment( a2 );
		r2.addAllocatable( allocatable );
		try {
			testFacade.store( r2 );
			fail("RaplaSecurityException expected!");
		} catch (RaplaSecurityException ex) {
		//	System.err.println ( ex.getMessage());
		}


    }

}





⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -