mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-07 18:25:23 +00:00
- ALF-9322: RINF 11: AbstractCannedQueryPermissions enhancements - Pulled in logic around hasMore() so that subclasses just have to obey - Added in cut-off size estimates - ALF-9337: RINF 11: Consolidate interceptor wrappers - Permissions respect PermissionCheckedValue - Added last-in-chain "afterAclMarking" to "afterInvocationManager": marks collections as checked - Added 'mixin' interfaces to handle input and output for permission checking of collections git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@28734 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
80 lines
3.0 KiB
Java
80 lines
3.0 KiB
Java
/*
|
|
* Copyright (C) 2005-2011 Alfresco Software Limited.
|
|
*
|
|
* This file is part of Alfresco
|
|
*
|
|
* Alfresco is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco 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 Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
package org.alfresco.repo.security.permissions;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collection;
|
|
import java.util.List;
|
|
|
|
import junit.framework.TestCase;
|
|
|
|
import org.alfresco.repo.security.permissions.PermissionCheckedCollection.PermissionCheckedCollectionMixin;
|
|
|
|
/**
|
|
* Tests {@link PermissionCheckedCollection}
|
|
*
|
|
* @author Derek Hulley
|
|
* @since 4.0
|
|
*/
|
|
public class PermissionCheckedCollectionTest extends TestCase
|
|
{
|
|
@Override
|
|
protected void setUp() throws Exception
|
|
{
|
|
}
|
|
|
|
public void testBasicWrapping() throws Exception
|
|
{
|
|
List<Integer> list = new ArrayList<Integer>();
|
|
list.add(1);
|
|
list.add(2);
|
|
list.add(3);
|
|
|
|
final boolean isCutOff = true;
|
|
final int sizeUnchecked = 100;
|
|
final int sizeOriginal = 900;
|
|
|
|
Collection<Integer> proxiedList = PermissionCheckedCollectionMixin.create(
|
|
list, isCutOff, sizeUnchecked, sizeOriginal);
|
|
|
|
// Check
|
|
assertTrue("Proxied object must still be a List", proxiedList instanceof List);
|
|
assertEquals("List values incorrect", 3, proxiedList.size());
|
|
assertTrue("Proxied object must also be a PermissionCheckedCollection", proxiedList instanceof PermissionCheckedCollection);
|
|
@SuppressWarnings("unchecked")
|
|
PermissionCheckedCollection<String> proxiedPermissionCheckedCollection = (PermissionCheckedCollection<String>) proxiedList;
|
|
assertEquals("cutOff value incorrect", isCutOff, proxiedPermissionCheckedCollection.isCutOff());
|
|
assertEquals("sizeUnchecked value incorrect", sizeUnchecked, proxiedPermissionCheckedCollection.sizeUnchecked());
|
|
assertEquals("sizeOriginal value incorrect", sizeOriginal, proxiedPermissionCheckedCollection.sizeOriginal());
|
|
}
|
|
|
|
public void testVolumeWrapping() throws Exception
|
|
{
|
|
int count = 10000;
|
|
long before = System.nanoTime();
|
|
for (int i = 0; i < count; i++)
|
|
{
|
|
testBasicWrapping();
|
|
}
|
|
long after = System.nanoTime();
|
|
double average = ((double) (after - before) / (double) count) / (double) 1.0E6;
|
|
System.out.println("Average is " + average + "ms per wrap.");
|
|
}
|
|
}
|