mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-07 18:25:23 +00:00
27908: ALF-8706: RSOLR 023: Locale is persisted for all nodes - Part of ALF-7991: RSOLR 023: Locale support for query: Repository - Added alf_node.locale_id mandatory column - sys:localizable is now spoofed and mandatory on sys:base - sys:locale property is always available - The locale set is the I18NUtil.getLocale() (thread then server) - TODO: Upgrade scripts, so drop database to take this change 27909: ALF-8706: RSOLR 023: Locale is persisted for all nodes - Part of ALF-7991: RSOLR 023: Locale support for query: Repository - Extended locale test to ensure that sys:locale can be set using properties during create 27910: ALF-8707: RSOLR 023: Upgrade to give nodes their default locales - Part of ALF-7991:RSOLR 023: Locale support for query: Repository - Upgrade scripts for PostgreSQL and MySQL: patch.db-V4.0-Node-Locale 27912: WCM QS ML Support for creating missing intermediate directories when adding an "orphan" translation, plus tests 27913: Fixed failing JbpmEngineUnitTest. 27914: Build fix. Fixes failing test DiscussionServiceTest.testDeleteTopLevelPost 27916: WCM QS ML forms config for overrideable name, and passing the initially orphaned flag through to the behaviour 27917: Enable the WCM QS ML Manage Translations action in the folder details page, as well as the document details page as before 27919: Quick build fix. Introduction of new property sys:locale on all nodes means that FormService is seeing some off-by-one errors. 27921: WCM QS ML - Support copying parts of the section collections to the new folder when translating a section, plus tests 27925: ALF-8707: RSOLR 023: Upgrade to give nodes their default locales - Part of ALF-7991: RSOLR 023: Locale support for query: Repository - Upgrade scripts for DB2, Oracle and SQLServer 27927: Update FileFolderService list/paging (RINF 09) & CQ permission checking (RINF 11) - also added additional unit tests and update FileFolderPerformanceTester utility (for read / list testing) 27930: Corrected bean reference: "ServiceRegistry" 27931: Partially implemented EnvironmentImpl.getPublishingEvents(). This currently only supports searching on publishing event ids. 27933: Implemented PublishService.getPublishingEvent(String) method. 27934: WCM QS ML Pull over the locale resolver from Ian, and delegate much of the work to the main class 27941: ALF-7874 - Mime Type entries for detection and display for some Apple and Adobe formats 27947: ALF-2707 - Largely fix custom site properties that have multiple values, and custom site properties without a full definition, plus tests. 27964: ALF-7339:RSOLR 009: Index track and build from SOLR - complete ALF-7475: RSOLR 010: Index integrity check - check ACL info 27966: RINF 09: FileFolderService list - if skipCount > number of items then return empty list - related to ALF-7884 when using CMIS getChildren (via OpenCMIS - eg. http://localhost:8080/alfresco/cmisatom/...) 27968: ALF-7884 - getChildren() returns an error if skipCount > number of children 27970: WCM QS Fix issue in the webapp for sites where no port has been given yet 27972: WPUB: F150: Foundation API: Request that a node be removed from the live environment - Initial support for "unpublish" 27975: ALF-8790:RSOLR 033: Automated build produces SOLR artifacts - add configuration per core based on properties files 27976: ALF-8790: RSOLR 033: Automated build produces SOLR artifacts - restructure, added properties files for config, track archived store 27977: ALF-8790: RSOLR 033: Automated build produces SOLR artifacts - Solr zip included in continuous build 27978: Fixed missing policy event when sys:locale is changed. 27979: Fixed tests and checks after sys:locale became a mandatory property. 27982: ALF-8547: WPUB: F163: Foundation API: Create/update/remove a delivery channel - Code and tests for channel update and delete 28007: Implemented starting publishing workflow on schedulePublishingEvent method. Added tests for PublishingEventHelper. 28008: Updated web-publishing-context.xml to include WorkflowService and workflowEngineId for PublishingEventHelper. 28009: Added more PublishingEventHelper tests. 28012: Support for ALF-8792: RSOLR 036: SOLR APIs to support index integrity checking 28013: Fix failing Web Publishing tests. 28015: Adding a DoNotCopy CopyBehaviourCallback for the fm:commentsRollup aspect. Part of ALF-8498. 28016: Bring over the WCM QS ML RootNavInterceptor from Ian, and productise it 28019: CMIS browser: close invalid connections 28025: Update the WCM QS ML behaviour, webscript and test to handle more things having locales by default 28026: ML-WQS: - Wired up the RootNavInterceptor to detect locale based on path - Wired up the replacement locale resolver to respect the locale determined by the RootNavInterceptor - Adjusted "Manage Translations" page to render the data table correctly - Adjusted site search box to restrict search to selected site localisation - Adjusted top nav component to select menu items only from appropriate site localisation 28029: Added more tests for PublishingEventHelper and PublishingQueueImpl. Also added WebPublishingTestSuite. 28034: Support for ALF-8792: RSOLR 036: SOLR APIs to support index integrity checking - ACL and ACLTX support 28036: WCM QS ML UI tweaks for marking something as the initial translation 28038: ALF-8548: WPUB: F165: Foundation API: Cancel a scheduled publishing event - Code and initial test cases 28043: Added missing JCR mapping for property type d:locale - This property type is not new, btw. 28312: RepoBM: minor cleanup - remove hardcoded JMeter install dir - add configurable user.dir (for default import of test data) - check that default zip exists - update readme - default threadfolder should be null (in case of absolute folder paths) git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@28320 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
628 lines
24 KiB
Java
628 lines
24 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.model.filefolder;
|
|
|
|
import java.io.File;
|
|
import java.io.IOException;
|
|
import java.io.Serializable;
|
|
import java.net.URL;
|
|
import java.text.Collator;
|
|
import java.util.ArrayList;
|
|
import java.util.Date;
|
|
import java.util.HashMap;
|
|
import java.util.HashSet;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
import java.util.Set;
|
|
|
|
import junit.framework.TestCase;
|
|
|
|
import org.alfresco.error.AlfrescoRuntimeException;
|
|
import org.alfresco.model.ContentModel;
|
|
import org.alfresco.query.CannedQueryFactory;
|
|
import org.alfresco.query.CannedQueryResults;
|
|
import org.alfresco.query.PagingRequest;
|
|
import org.alfresco.query.PagingResults;
|
|
import org.alfresco.repo.domain.contentdata.ContentDataDAO;
|
|
import org.alfresco.repo.domain.locale.LocaleDAO;
|
|
import org.alfresco.repo.domain.node.NodeDAO;
|
|
import org.alfresco.repo.domain.qname.QNameDAO;
|
|
import org.alfresco.repo.domain.query.CannedQueryDAO;
|
|
import org.alfresco.repo.model.Repository;
|
|
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
|
import org.alfresco.repo.security.permissions.impl.acegi.MethodSecurityInterceptor;
|
|
import org.alfresco.service.cmr.dictionary.DictionaryService;
|
|
import org.alfresco.service.cmr.repository.ContentData;
|
|
import org.alfresco.service.cmr.repository.ContentService;
|
|
import org.alfresco.service.cmr.repository.ContentWriter;
|
|
import org.alfresco.service.cmr.repository.MimetypeService;
|
|
import org.alfresco.service.cmr.repository.NodeRef;
|
|
import org.alfresco.service.cmr.repository.NodeService;
|
|
import org.alfresco.service.cmr.security.AccessStatus;
|
|
import org.alfresco.service.cmr.security.MutableAuthenticationService;
|
|
import org.alfresco.service.cmr.security.PermissionService;
|
|
import org.alfresco.service.cmr.security.PersonService;
|
|
import org.alfresco.service.namespace.QName;
|
|
import org.alfresco.util.ApplicationContextHelper;
|
|
import org.alfresco.util.Pair;
|
|
import org.alfresco.util.PropertyMap;
|
|
import org.alfresco.util.registry.NamedObjectRegistry;
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
import org.springframework.context.ApplicationContext;
|
|
|
|
/**
|
|
* GetChildren canned query - simple unit tests
|
|
*
|
|
* @author janv
|
|
* @since 4.0
|
|
*/
|
|
public class GetChildrenCannedQueryTest extends TestCase
|
|
{
|
|
private Log logger = LogFactory.getLog(getClass());
|
|
|
|
private static final ApplicationContext ctx = ApplicationContextHelper.getApplicationContext();
|
|
|
|
private Repository repositoryHelper;
|
|
private NodeService nodeService;
|
|
private ContentService contentService;
|
|
private MimetypeService mimetypeService;
|
|
|
|
private PersonService personService;
|
|
private MutableAuthenticationService authenticationService;
|
|
private PermissionService permissionService;
|
|
|
|
private boolean setupOnce = false;
|
|
|
|
private static final String TEST_USER = "GC-CQ-User-"+System.currentTimeMillis();
|
|
|
|
private Set<NodeRef> hits = new HashSet<NodeRef>(100);
|
|
private Set<NodeRef> misses = new HashSet<NodeRef>(100);
|
|
|
|
@SuppressWarnings("unchecked")
|
|
private NamedObjectRegistry<CannedQueryFactory> cannedQueryRegistry;
|
|
|
|
@SuppressWarnings("unchecked")
|
|
@Override
|
|
public void setUp() throws Exception
|
|
{
|
|
if (! setupOnce)
|
|
{
|
|
repositoryHelper = (Repository)ctx.getBean("repositoryHelper");
|
|
|
|
nodeService = (NodeService)ctx.getBean("NodeService");
|
|
contentService = (ContentService)ctx.getBean("ContentService");
|
|
mimetypeService = (MimetypeService)ctx.getBean("MimetypeService");
|
|
|
|
personService = (PersonService)ctx.getBean("PersonService");
|
|
authenticationService = (MutableAuthenticationService)ctx.getBean("AuthenticationService");
|
|
permissionService = (PermissionService)ctx.getBean("PermissionService");
|
|
|
|
cannedQueryRegistry = new NamedObjectRegistry<CannedQueryFactory>();
|
|
cannedQueryRegistry.setStorageType(CannedQueryFactory.class);
|
|
|
|
GetChildrenCannedQueryFactory getChildrenCannedQueryFactory = new GetChildrenCannedQueryFactory();
|
|
|
|
getChildrenCannedQueryFactory.setBeanName("getChildrenCannedQueryFactory");
|
|
getChildrenCannedQueryFactory.setRegistry(cannedQueryRegistry);
|
|
|
|
getChildrenCannedQueryFactory.setCannedQueryDAO((CannedQueryDAO)ctx.getBean("cannedQueryDAO"));
|
|
getChildrenCannedQueryFactory.setContentDataDAO((ContentDataDAO)ctx.getBean("contentDataDAO"));
|
|
getChildrenCannedQueryFactory.setDictionaryService((DictionaryService)ctx.getBean("dictionaryService"));
|
|
getChildrenCannedQueryFactory.setLocaleDAO((LocaleDAO)ctx.getBean("localeDAO"));
|
|
getChildrenCannedQueryFactory.setNodeDAO((NodeDAO)ctx.getBean("nodeDAO"));
|
|
getChildrenCannedQueryFactory.setQnameDAO((QNameDAO)ctx.getBean("qnameDAO"));
|
|
|
|
getChildrenCannedQueryFactory.setMethodSecurityInterceptor((MethodSecurityInterceptor)ctx.getBean("FileFolderService_security"));
|
|
getChildrenCannedQueryFactory.setMethodService((Object)ctx.getBean("fileFolderService"));
|
|
getChildrenCannedQueryFactory.setMethodName("list");
|
|
|
|
getChildrenCannedQueryFactory.afterPropertiesSet();
|
|
|
|
AuthenticationUtil.setFullyAuthenticatedUser(AuthenticationUtil.getAdminUserName());
|
|
|
|
createUser(TEST_USER);
|
|
|
|
boolean canRead = true;
|
|
|
|
load(repositoryHelper.getCompanyHome(), "quick.jpg", "", "", canRead, hits);
|
|
load(repositoryHelper.getCompanyHome(), "quick.txt", "ZZ title", "ZZ description 1", canRead, hits);
|
|
load(repositoryHelper.getCompanyHome(), "quick.bmp", null, null, canRead, hits);
|
|
load(repositoryHelper.getCompanyHome(), "quick.doc", "BB title", "BB description", canRead, hits);
|
|
load(repositoryHelper.getCompanyHome(), "quick.pdf", "ZZ title", "ZZ description 2", canRead, hits);
|
|
|
|
canRead = false;
|
|
|
|
load(repositoryHelper.getCompanyHome(), "quick.ppt", "CC title", "CC description", canRead, misses);
|
|
load(repositoryHelper.getCompanyHome(), "quick.xls", "AA title", "AA description", canRead, misses);
|
|
load(repositoryHelper.getCompanyHome(), "quick.gif", "YY title", "BB description", canRead, misses);
|
|
|
|
setupOnce = true;
|
|
|
|
// double-check permissions - see testPermissions
|
|
|
|
AuthenticationUtil.setFullyAuthenticatedUser(TEST_USER);
|
|
|
|
for (NodeRef nodeRef : hits)
|
|
{
|
|
assertTrue(permissionService.hasPermission(nodeRef, PermissionService.READ) == AccessStatus.ALLOWED);
|
|
}
|
|
|
|
for (NodeRef nodeRef : misses)
|
|
{
|
|
// user CANNOT read
|
|
assertFalse(permissionService.hasPermission(nodeRef, PermissionService.READ) == AccessStatus.ALLOWED);
|
|
}
|
|
|
|
// belts-and-braces
|
|
AuthenticationUtil.setFullyAuthenticatedUser(AuthenticationUtil.getAdminUserName());
|
|
|
|
for (NodeRef nodeRef : hits)
|
|
{
|
|
assertTrue(permissionService.hasPermission(nodeRef, PermissionService.READ) == AccessStatus.ALLOWED);
|
|
}
|
|
|
|
for (NodeRef nodeRef : misses)
|
|
{
|
|
// admin CAN read
|
|
assertTrue(permissionService.hasPermission(nodeRef, PermissionService.READ) == AccessStatus.ALLOWED);
|
|
}
|
|
}
|
|
|
|
AuthenticationUtil.setFullyAuthenticatedUser(TEST_USER);
|
|
}
|
|
|
|
public void testSetup() throws Exception
|
|
{
|
|
}
|
|
|
|
public void testMaxItems() throws Exception
|
|
{
|
|
NodeRef parentNodeRef = repositoryHelper.getCompanyHome();
|
|
|
|
PagingResults<NodeRef> results = list(parentNodeRef, -1, -1, 0, null);
|
|
assertFalse(results.hasMoreItems());
|
|
|
|
int totalCnt = results.getPage().size();
|
|
assertTrue(totalCnt > 2);
|
|
|
|
for (int i = 1; i <= totalCnt; i++)
|
|
{
|
|
results = list(parentNodeRef, 0, i, 0, null);
|
|
assertEquals(results.getPage().size(), i);
|
|
|
|
boolean hasMore = results.hasMoreItems();
|
|
assertTrue(hasMore == (i != totalCnt));
|
|
|
|
if (logger.isInfoEnabled())
|
|
{
|
|
logger.info("testSimpleMaxItems: [itemCnt="+i+",hasMore="+hasMore+"]");
|
|
}
|
|
}
|
|
}
|
|
|
|
public void testPaging() throws Exception
|
|
{
|
|
NodeRef parentNodeRef = repositoryHelper.getCompanyHome();
|
|
|
|
PagingResults<NodeRef> results = list(parentNodeRef, -1, -1, 0, null);
|
|
assertFalse(results.hasMoreItems());
|
|
|
|
int totalCnt = results.getPage().size();
|
|
int pageSize = 3;
|
|
assertTrue(totalCnt > pageSize);
|
|
|
|
int pageCnt = new Double(totalCnt / pageSize).intValue(); // round-up
|
|
assertTrue(pageCnt > 1);
|
|
|
|
for (int i = 1; i <= pageCnt; i++)
|
|
{
|
|
int skipCount = ((i - 1)* pageSize);
|
|
int maxItems = pageSize;
|
|
|
|
results = list(parentNodeRef, skipCount, maxItems, 0, null);
|
|
|
|
boolean hasMore = results.hasMoreItems();
|
|
int itemsCnt = results.getPage().size();
|
|
|
|
if (logger.isInfoEnabled())
|
|
{
|
|
logger.info("testSimplePaging: [pageNum="+i+",itemCnt="+itemsCnt+",hasMore="+hasMore+"]");
|
|
}
|
|
|
|
if (i != pageCnt)
|
|
{
|
|
// not last page
|
|
assertEquals(itemsCnt, maxItems);
|
|
assertTrue(hasMore);
|
|
}
|
|
else
|
|
{
|
|
// last page
|
|
assertTrue(itemsCnt <= maxItems);
|
|
assertFalse(hasMore);
|
|
}
|
|
}
|
|
}
|
|
|
|
public void testSorting() throws Exception
|
|
{
|
|
NodeRef parentNodeRef = repositoryHelper.getCompanyHome();
|
|
|
|
PagingResults<NodeRef> results = list(parentNodeRef, -1, -1, 0, null);
|
|
assertTrue(results.getPage().size() > 2);
|
|
|
|
List<QName> sortQNames = new ArrayList<QName>(3);
|
|
|
|
// note: initial test list derived from default Share DocLib ("share-documentlibrary-config.xml")
|
|
|
|
sortQNames.add(ContentModel.PROP_NAME);
|
|
sortQNames.add(ContentModel.PROP_TITLE);
|
|
sortQNames.add(ContentModel.PROP_DESCRIPTION);
|
|
sortQNames.add(ContentModel.PROP_CREATED);
|
|
sortQNames.add(ContentModel.PROP_CREATOR);
|
|
sortQNames.add(ContentModel.PROP_MODIFIED);
|
|
sortQNames.add(ContentModel.PROP_MODIFIER);
|
|
sortQNames.add(GetChildrenCannedQuery.SORT_QNAME_CONTENT_SIZE);
|
|
sortQNames.add(GetChildrenCannedQuery.SORT_QNAME_CONTENT_MIMETYPE);
|
|
sortQNames.add(GetChildrenCannedQuery.SORT_QNAME_NODE_TYPE);
|
|
|
|
// TODO pending merge to HEAD: sortQNames.add(ContentModel... cm:likesRatingSchemeCount ...);
|
|
|
|
for (QName sortQName : sortQNames)
|
|
{
|
|
sortAndCheck(parentNodeRef, sortQName, false); // descending
|
|
sortAndCheck(parentNodeRef, sortQName, true); // ascending
|
|
}
|
|
|
|
// sort with two props
|
|
List<Pair<QName, Boolean>> sortPairs = new ArrayList<Pair<QName, Boolean>>(3);
|
|
sortPairs.add(new Pair<QName, Boolean>(ContentModel.PROP_TITLE, false));
|
|
sortPairs.add(new Pair<QName, Boolean>(ContentModel.PROP_DESCRIPTION, false));
|
|
|
|
results = list(parentNodeRef, -1, -1, 0, sortPairs);
|
|
assertEquals("quick.pdf", nodeService.getProperty(results.getPage().get(0), ContentModel.PROP_NAME)); // ZZ title + YY description
|
|
assertEquals("quick.txt", nodeService.getProperty(results.getPage().get(1), ContentModel.PROP_NAME)); // ZZ title + XX description
|
|
|
|
|
|
sortPairs = new ArrayList<Pair<QName, Boolean>>(3);
|
|
sortPairs.add(new Pair<QName, Boolean>(ContentModel.PROP_NAME, true));
|
|
sortPairs.add(new Pair<QName, Boolean>(ContentModel.PROP_TITLE, true));
|
|
sortPairs.add(new Pair<QName, Boolean>(ContentModel.PROP_DESCRIPTION, true));
|
|
|
|
// try to sort with more than two props
|
|
try
|
|
{
|
|
// -ve test
|
|
results = list(parentNodeRef, -1, -1, 0, sortPairs);
|
|
fail("Unexpected - cannot sort with more than two props");
|
|
}
|
|
catch (AlfrescoRuntimeException are)
|
|
{
|
|
// expected
|
|
}
|
|
}
|
|
|
|
public void testPermissions() throws Exception
|
|
{
|
|
AuthenticationUtil.setFullyAuthenticatedUser(TEST_USER);
|
|
|
|
NodeRef parentNodeRef = repositoryHelper.getCompanyHome();
|
|
|
|
PagingResults<NodeRef> results = list(parentNodeRef, -1, -1, 0, null);
|
|
assertFalse(results.hasMoreItems());
|
|
assertTrue(results.permissionsApplied());
|
|
|
|
List<NodeRef> nodeRefs = results.getPage();
|
|
|
|
for (NodeRef nodeRef : hits)
|
|
{
|
|
assertTrue(nodeRefs.contains(nodeRef));
|
|
}
|
|
|
|
for (NodeRef nodeRef : misses)
|
|
{
|
|
assertFalse(nodeRefs.contains(nodeRef));
|
|
}
|
|
|
|
AuthenticationUtil.setFullyAuthenticatedUser(AuthenticationUtil.getAdminUserName());
|
|
|
|
results = list(parentNodeRef, -1, -1, 0, null);
|
|
assertFalse(results.hasMoreItems());
|
|
assertTrue(results.permissionsApplied());
|
|
|
|
nodeRefs = results.getPage();
|
|
|
|
for (NodeRef nodeRef : hits)
|
|
{
|
|
assertTrue(nodeRefs.contains(nodeRef));
|
|
}
|
|
|
|
for (NodeRef nodeRef : misses)
|
|
{
|
|
assertTrue(nodeRefs.contains(nodeRef));
|
|
}
|
|
}
|
|
|
|
private void sortAndCheck(NodeRef parentNodeRef, QName sortPropQName, boolean sortAscending)
|
|
{
|
|
List<Pair<QName, Boolean>> sortPairs = new ArrayList<Pair<QName, Boolean>>(1);
|
|
sortPairs.add(new Pair<QName, Boolean>(sortPropQName, sortAscending));
|
|
|
|
PagingResults<NodeRef> results = list(parentNodeRef, -1, -1, 0, sortPairs);
|
|
|
|
if (logger.isInfoEnabled())
|
|
{
|
|
logger.info("testSorting: "+sortPropQName+" - "+(sortAscending ? " ascending" : " descending"));
|
|
}
|
|
|
|
Collator collator = Collator.getInstance();
|
|
|
|
// check order
|
|
Serializable prevVal = null;
|
|
|
|
boolean allValsNull = true;
|
|
|
|
for (NodeRef nodeRef : results.getPage())
|
|
{
|
|
Serializable val = null;
|
|
|
|
if (sortPropQName.equals(GetChildrenCannedQuery.SORT_QNAME_CONTENT_SIZE) || sortPropQName.equals(GetChildrenCannedQuery.SORT_QNAME_CONTENT_MIMETYPE))
|
|
{
|
|
// content data properties (size or mimetype)
|
|
ContentData cd = (ContentData)nodeService.getProperty(nodeRef, ContentModel.PROP_CONTENT);
|
|
if (cd != null)
|
|
{
|
|
if (sortPropQName.equals(GetChildrenCannedQuery.SORT_QNAME_CONTENT_SIZE))
|
|
{
|
|
val = cd.getSize();
|
|
}
|
|
else if (sortPropQName.equals(GetChildrenCannedQuery.SORT_QNAME_CONTENT_MIMETYPE))
|
|
{
|
|
val = cd.getMimetype();
|
|
}
|
|
}
|
|
}
|
|
else if (sortPropQName.equals(GetChildrenCannedQuery.SORT_QNAME_NODE_TYPE))
|
|
{
|
|
val = nodeService.getType(nodeRef);
|
|
}
|
|
else
|
|
{
|
|
val = nodeService.getProperty(nodeRef, sortPropQName);
|
|
}
|
|
|
|
if (logger.isInfoEnabled())
|
|
{
|
|
logger.info("testSorting: ["+nodeRef+", "+val+"]");
|
|
}
|
|
|
|
int result = 0;
|
|
|
|
if (val != null)
|
|
{
|
|
allValsNull = false;
|
|
}
|
|
|
|
if (prevVal == null)
|
|
{
|
|
result = (val == null ? 0 : 1);
|
|
}
|
|
else if (val == null)
|
|
{
|
|
result = -1;
|
|
}
|
|
else
|
|
{
|
|
if (val instanceof Date)
|
|
{
|
|
result = ((Date)val).compareTo((Date)prevVal);
|
|
}
|
|
else if (val instanceof String)
|
|
{
|
|
result = collator.compare((String)val, (String)prevVal);
|
|
}
|
|
else if (val instanceof Long)
|
|
{
|
|
result = ((Long)val).compareTo((Long)prevVal);
|
|
}
|
|
else if (val instanceof QName)
|
|
{
|
|
result = ((QName)val).compareTo((QName)prevVal);
|
|
}
|
|
else
|
|
{
|
|
fail("Unsupported sort type: "+val.getClass().getName());
|
|
}
|
|
|
|
if (! sortAscending)
|
|
{
|
|
assertTrue("Not descending", result <= 0);
|
|
}
|
|
else
|
|
{
|
|
assertTrue("Not ascending", result >= 0);
|
|
}
|
|
}
|
|
prevVal = val;
|
|
}
|
|
|
|
assertFalse("All values were null", allValsNull);
|
|
}
|
|
|
|
// test helper method
|
|
private PagingResults<NodeRef> list(NodeRef parentNodeRef, final int skipCount, final int maxItems, final int requestTotalCountMax, List<Pair<QName, Boolean>> sortProps)
|
|
{
|
|
PagingRequest pagingRequest = new PagingRequest()
|
|
{
|
|
public int getSkipCount()
|
|
{
|
|
return skipCount;
|
|
}
|
|
|
|
public int getMaxItems()
|
|
{
|
|
return maxItems;
|
|
}
|
|
|
|
public int getRequestTotalCountMax()
|
|
{
|
|
return requestTotalCountMax;
|
|
}
|
|
|
|
public String getQueryExecutionId()
|
|
{
|
|
return null;
|
|
}
|
|
};
|
|
|
|
// get canned query
|
|
GetChildrenCannedQueryFactory getChildrenCannedQueryFactory = (GetChildrenCannedQueryFactory)cannedQueryRegistry.getNamedObject("getChildrenCannedQueryFactory");
|
|
GetChildrenCannedQuery cq = (GetChildrenCannedQuery)getChildrenCannedQueryFactory.getCannedQuery(parentNodeRef, null, pagingRequest, sortProps);
|
|
|
|
// execute canned query
|
|
CannedQueryResults<NodeRef> results = cq.execute();
|
|
|
|
List<NodeRef> nodeRefs = results.getPages().get(0);
|
|
|
|
Integer totalCount = null;
|
|
if (requestTotalCountMax > 0)
|
|
{
|
|
totalCount = results.getTotalResultCount().getFirst();
|
|
}
|
|
|
|
return new PagingNodeRefResultsImpl(nodeRefs, results.hasMoreItems(), totalCount, false, true);
|
|
}
|
|
|
|
private class PagingNodeRefResultsImpl implements PagingResults<NodeRef>
|
|
{
|
|
private List<NodeRef> nodeRefs;
|
|
|
|
private boolean hasMorePages;
|
|
private boolean permissionsApplied;
|
|
|
|
private Integer totalResultCount; // null => not requested (or unknown)
|
|
private Boolean isTotalResultCountCutoff; // null => unknown
|
|
|
|
public PagingNodeRefResultsImpl(List<NodeRef> nodeRefs, boolean hasMorePages, Integer totalResultCount, Boolean isTotalResultCountCutoff, boolean permissionsApplied)
|
|
{
|
|
this.nodeRefs = nodeRefs;
|
|
this.hasMorePages = hasMorePages;
|
|
this.totalResultCount= totalResultCount;
|
|
this.isTotalResultCountCutoff = isTotalResultCountCutoff;
|
|
this.permissionsApplied = permissionsApplied;
|
|
}
|
|
|
|
public List<NodeRef> getPage()
|
|
{
|
|
return nodeRefs;
|
|
}
|
|
|
|
public boolean hasMoreItems()
|
|
{
|
|
return hasMorePages;
|
|
}
|
|
|
|
public boolean permissionsApplied()
|
|
{
|
|
return permissionsApplied;
|
|
}
|
|
|
|
public Pair<Integer, Integer> getTotalResultCount()
|
|
{
|
|
return new Pair<Integer, Integer>(totalResultCount, (isTotalResultCountCutoff ? null : totalResultCount));
|
|
}
|
|
|
|
public String getQueryExecutionId()
|
|
{
|
|
return "";
|
|
}
|
|
}
|
|
|
|
private void load(NodeRef parentNodeRef, String fileName, String title, String description, boolean readAllowed, Set<NodeRef> results) throws IOException
|
|
{
|
|
// Create the node
|
|
Map<QName,Serializable> properties = new HashMap<QName,Serializable>();
|
|
properties.put(ContentModel.PROP_NAME, fileName);
|
|
properties.put(ContentModel.PROP_TITLE, title);
|
|
properties.put(ContentModel.PROP_DESCRIPTION, description);
|
|
|
|
NodeRef nodeRef = nodeService.getChildByName(parentNodeRef, ContentModel.ASSOC_CONTAINS, fileName);
|
|
if (nodeRef != null)
|
|
{
|
|
nodeService.deleteNode(nodeRef);
|
|
}
|
|
|
|
nodeRef = nodeService.createNode(parentNodeRef,
|
|
ContentModel.ASSOC_CONTAINS,
|
|
QName.createQName(fileName),
|
|
ContentModel.TYPE_CONTENT,
|
|
properties).getChildRef();
|
|
|
|
String classPath = "quick/" + fileName;
|
|
File file = null;
|
|
URL url = getClass().getClassLoader().getResource(classPath);
|
|
if (url != null)
|
|
{
|
|
file = new File(url.getFile());
|
|
if (!file.exists())
|
|
{
|
|
file = null;
|
|
}
|
|
}
|
|
|
|
if (file == null)
|
|
{
|
|
fail("Unable to find test file: " + classPath);
|
|
}
|
|
|
|
ContentWriter writer = contentService.getWriter(nodeRef, ContentModel.PROP_CONTENT, true);
|
|
writer.setMimetype(mimetypeService.guessMimetype(fileName));
|
|
writer.putContent(file);
|
|
|
|
if (! readAllowed)
|
|
{
|
|
// deny read (by explicitly breaking inheritance)
|
|
permissionService.setInheritParentPermissions(nodeRef, false);
|
|
}
|
|
|
|
results.add(nodeRef);
|
|
}
|
|
|
|
private void createUser(String userName)
|
|
{
|
|
if (! authenticationService.authenticationExists(userName))
|
|
{
|
|
authenticationService.createAuthentication(userName, "PWD".toCharArray());
|
|
}
|
|
|
|
if (! personService.personExists(userName))
|
|
{
|
|
PropertyMap ppOne = new PropertyMap(4);
|
|
ppOne.put(ContentModel.PROP_USERNAME, userName);
|
|
ppOne.put(ContentModel.PROP_FIRSTNAME, "firstName");
|
|
ppOne.put(ContentModel.PROP_LASTNAME, "lastName");
|
|
ppOne.put(ContentModel.PROP_EMAIL, "email@email.com");
|
|
ppOne.put(ContentModel.PROP_JOBTITLE, "jobTitle");
|
|
|
|
personService.createPerson(ppOne);
|
|
}
|
|
}
|
|
}
|