mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-24 17:32:48 +00:00
Added optional user authentication to FileImporterTest
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@2796 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -45,10 +45,12 @@ import org.alfresco.service.cmr.search.ResultSet;
|
|||||||
import org.alfresco.service.cmr.search.SearchParameters;
|
import org.alfresco.service.cmr.search.SearchParameters;
|
||||||
import org.alfresco.service.cmr.search.SearchService;
|
import org.alfresco.service.cmr.search.SearchService;
|
||||||
import org.alfresco.service.cmr.security.AuthenticationService;
|
import org.alfresco.service.cmr.security.AuthenticationService;
|
||||||
|
import org.alfresco.service.cmr.security.PermissionService;
|
||||||
import org.alfresco.service.namespace.NamespaceService;
|
import org.alfresco.service.namespace.NamespaceService;
|
||||||
import org.alfresco.service.transaction.TransactionService;
|
import org.alfresco.service.transaction.TransactionService;
|
||||||
import org.alfresco.util.ApplicationContextHelper;
|
import org.alfresco.util.ApplicationContextHelper;
|
||||||
import org.alfresco.util.TempFileProvider;
|
import org.alfresco.util.TempFileProvider;
|
||||||
|
import org.alfresco.util.TestWithUserUtils;
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
|
|
||||||
public class FileImporterTest extends TestCase
|
public class FileImporterTest extends TestCase
|
||||||
@@ -60,6 +62,7 @@ public class FileImporterTest extends TestCase
|
|||||||
private ContentService contentService;
|
private ContentService contentService;
|
||||||
private AuthenticationService authenticationService;
|
private AuthenticationService authenticationService;
|
||||||
private AuthenticationComponent authenticationComponent;
|
private AuthenticationComponent authenticationComponent;
|
||||||
|
private PermissionService permissionService;
|
||||||
private MimetypeService mimetypeService;
|
private MimetypeService mimetypeService;
|
||||||
private NamespaceService namespaceService;
|
private NamespaceService namespaceService;
|
||||||
|
|
||||||
@@ -86,6 +89,7 @@ public class FileImporterTest extends TestCase
|
|||||||
contentService = serviceRegistry.getContentService();
|
contentService = serviceRegistry.getContentService();
|
||||||
authenticationService = (AuthenticationService) ctx.getBean("authenticationService");
|
authenticationService = (AuthenticationService) ctx.getBean("authenticationService");
|
||||||
authenticationComponent = (AuthenticationComponent) ctx.getBean("authenticationComponent");
|
authenticationComponent = (AuthenticationComponent) ctx.getBean("authenticationComponent");
|
||||||
|
permissionService = serviceRegistry.getPermissionService();
|
||||||
mimetypeService = serviceRegistry.getMimetypeService();
|
mimetypeService = serviceRegistry.getMimetypeService();
|
||||||
namespaceService = serviceRegistry.getNamespaceService();
|
namespaceService = serviceRegistry.getNamespaceService();
|
||||||
|
|
||||||
@@ -170,6 +174,8 @@ public class FileImporterTest extends TestCase
|
|||||||
* <li>String: Directory to use as source (e.g. c:/temp)
|
* <li>String: Directory to use as source (e.g. c:/temp)
|
||||||
* <li>String: New name to give the source. It may have a suffix added (e.g. upload_xxx)
|
* <li>String: New name to give the source. It may have a suffix added (e.g. upload_xxx)
|
||||||
* <li>Integer: Number of times to repeat the load.
|
* <li>Integer: Number of times to repeat the load.
|
||||||
|
* <li>String: (optional) user to authenticate as
|
||||||
|
* <li>String: (optional) password for authentication
|
||||||
* </ol>
|
* </ol>
|
||||||
* @throws SystemException
|
* @throws SystemException
|
||||||
* @throws NotSupportedException
|
* @throws NotSupportedException
|
||||||
@@ -186,6 +192,8 @@ public class FileImporterTest extends TestCase
|
|||||||
File sourceFile = new File(args[2]);
|
File sourceFile = new File(args[2]);
|
||||||
String baseName = args[3];
|
String baseName = args[3];
|
||||||
int target = Integer.parseInt(args[4]);
|
int target = Integer.parseInt(args[4]);
|
||||||
|
String userName = args.length > 5 ? args[5] : null;
|
||||||
|
String userPwd = args.length > 6 ? args[6] : "";
|
||||||
while (count < target)
|
while (count < target)
|
||||||
{
|
{
|
||||||
File directory = TempFileProvider.getTempDir();
|
File directory = TempFileProvider.getTempDir();
|
||||||
@@ -210,13 +218,13 @@ public class FileImporterTest extends TestCase
|
|||||||
}
|
}
|
||||||
|
|
||||||
NodeRef storeRoot = test.nodeService.getRootNode(spacesStore);
|
NodeRef storeRoot = test.nodeService.getRootNode(spacesStore);
|
||||||
List<NodeRef> location = test.searchService.selectNodes(
|
List<NodeRef> importLocations = test.searchService.selectNodes(
|
||||||
storeRoot,
|
storeRoot,
|
||||||
args[1],
|
args[1],
|
||||||
null,
|
null,
|
||||||
test.namespaceService,
|
test.namespaceService,
|
||||||
false);
|
false);
|
||||||
if (location.size() == 0)
|
if (importLocations.size() == 0)
|
||||||
{
|
{
|
||||||
throw new AlfrescoRuntimeException(
|
throw new AlfrescoRuntimeException(
|
||||||
"Root node not found, " +
|
"Root node not found, " +
|
||||||
@@ -224,13 +232,30 @@ public class FileImporterTest extends TestCase
|
|||||||
" not found in store, " +
|
" not found in store, " +
|
||||||
storeRoot);
|
storeRoot);
|
||||||
}
|
}
|
||||||
|
NodeRef importLocation = importLocations.get(0);
|
||||||
|
|
||||||
|
// optionally authenticate as a specific user
|
||||||
|
if (userName != null)
|
||||||
|
{
|
||||||
|
// give the user all necessary permissions on the root
|
||||||
|
test.permissionService.setPermission(importLocation, userName, PermissionService.ALL_PERMISSIONS, true);
|
||||||
|
// authenticate as the designated user
|
||||||
|
TestWithUserUtils.authenticateUser(
|
||||||
|
userName,
|
||||||
|
userPwd,
|
||||||
|
test.authenticationService,
|
||||||
|
test.authenticationComponent);
|
||||||
|
tx.commit();
|
||||||
|
tx = transactionService.getUserTransaction();
|
||||||
|
tx.begin();
|
||||||
|
}
|
||||||
|
|
||||||
long start = System.nanoTime();
|
long start = System.nanoTime();
|
||||||
int importCount = test.createFileImporter().loadNamedFile(
|
int importCount = test.createFileImporter().loadNamedFile(
|
||||||
location.get(0),
|
importLocation,
|
||||||
sourceFile,
|
sourceFile,
|
||||||
true,
|
true,
|
||||||
String.format("%s-%05d", baseName, count));
|
String.format("%s-%05d-%s", baseName, count, System.currentTimeMillis()));
|
||||||
grandTotal += importCount;
|
grandTotal += importCount;
|
||||||
long end = System.nanoTime();
|
long end = System.nanoTime();
|
||||||
long first = end-start;
|
long first = end-start;
|
||||||
|
@@ -20,6 +20,7 @@ import java.io.Serializable;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
import org.alfresco.model.ContentModel;
|
import org.alfresco.model.ContentModel;
|
||||||
|
import org.alfresco.repo.security.authentication.AuthenticationComponent;
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.alfresco.service.cmr.repository.NodeService;
|
import org.alfresco.service.cmr.repository.NodeService;
|
||||||
import org.alfresco.service.cmr.security.AuthenticationService;
|
import org.alfresco.service.cmr.security.AuthenticationService;
|
||||||
@@ -89,6 +90,32 @@ public abstract class TestWithUserUtils extends BaseSpringTest
|
|||||||
authenticationService.authenticate(userName, password.toCharArray());
|
authenticationService.authenticate(userName, password.toCharArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Authenticate as the given user. If the user does not exist, then authenticate as the system user
|
||||||
|
* and create the authentication first.
|
||||||
|
*/
|
||||||
|
public static void authenticateUser(
|
||||||
|
String userName,
|
||||||
|
String password,
|
||||||
|
AuthenticationService authenticationService,
|
||||||
|
AuthenticationComponent authenticationComponent)
|
||||||
|
{
|
||||||
|
// go system
|
||||||
|
try
|
||||||
|
{
|
||||||
|
authenticationComponent.setSystemUserAsCurrentUser();
|
||||||
|
if (!authenticationService.authenticationExists(userName))
|
||||||
|
{
|
||||||
|
authenticationService.createAuthentication(userName, password.toCharArray());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
authenticationComponent.clearCurrentSecurityContext();
|
||||||
|
}
|
||||||
|
authenticationService.authenticate(userName, password.toCharArray());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the current user node reference
|
* Get the current user node reference
|
||||||
*
|
*
|
||||||
|
Reference in New Issue
Block a user