Derek Hulley afe709ae54 Merged DEV/SWIFT to HEAD
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
2011-06-09 22:40:27 +00:00

236 lines
8.7 KiB
Java

/*
* Copyright (C) 2005-2010 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.domain.usage;
import java.util.Set;
import junit.framework.TestCase;
import org.alfresco.model.ContentModel;
import org.alfresco.repo.domain.node.ChildAssocEntity;
import org.alfresco.repo.domain.node.NodeDAO;
import org.alfresco.repo.transaction.RetryingTransactionHelper;
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.service.cmr.repository.StoreRef;
import org.alfresco.service.transaction.TransactionService;
import org.alfresco.util.ApplicationContextHelper;
import org.springframework.context.ApplicationContext;
import org.springframework.extensions.surf.util.I18NUtil;
/**
* @see UsageDAO
*
* @author janv
* @since 3.4
*/
public class UsageDAOTest extends TestCase
{
private ApplicationContext ctx = ApplicationContextHelper.getApplicationContext();
private TransactionService transactionService;
private RetryingTransactionHelper txnHelper;
private UsageDAO usageDAO;
private NodeDAO nodeDAO;
private final static StoreRef storeRef = new StoreRef(StoreRef.PROTOCOL_WORKSPACE, "SpacesStore");
@Override
public void setUp() throws Exception
{
transactionService = (TransactionService)ctx.getBean("transactionService");
txnHelper = transactionService.getRetryingTransactionHelper();
usageDAO = (UsageDAO)ctx.getBean("usageDAO");
nodeDAO = (NodeDAO)ctx.getBean("nodeDAO");
}
private NodeRef getRootNodeRef()
{
return nodeDAO.getRootNode(storeRef).getSecond();
}
private long getNodeId(NodeRef nodeRef)
{
return nodeDAO.getNodePair(nodeRef).getFirst();
}
private NodeRef createNode(long parentNodeId)
{
ChildAssocEntity assoc = nodeDAO.newNode(
parentNodeId,
ContentModel.ASSOC_CHILDREN,
ContentModel.ASSOC_CHILDREN,
storeRef,
null,
ContentModel.TYPE_CONTENT,
I18NUtil.getLocale(),
null,
null);
return assoc.getChildNode().getNodeRef();
}
public void testCreateAndDeleteUsageDeltas() throws Exception
{
RetryingTransactionCallback<Void> callback = new RetryingTransactionCallback<Void>()
{
public Void execute() throws Throwable
{
NodeRef rootNodeRef = getRootNodeRef();
long rootNodeId = getNodeId(rootNodeRef);
usageDAO.deleteDeltas(rootNodeId);
// assertEquals(0L, usageDAO.getTotalDeltaSize(rootNodeRef, false));
Set<NodeRef> usageDeltaNodes = usageDAO.getUsageDeltaNodes();
for (NodeRef nodeRef : usageDeltaNodes)
{
long nodeId = getNodeId(nodeRef);
usageDAO.deleteDeltas(nodeId);
}
assertEquals(0, usageDAO.getUsageDeltaNodes().size());
usageDAO.insertDelta(rootNodeRef, 100L);
assertEquals(100L, usageDAO.getTotalDeltaSize(rootNodeRef, false));
assertEquals(1, usageDAO.getUsageDeltaNodes().size());
usageDAO.insertDelta(rootNodeRef, 1000L);
assertEquals(1100L, usageDAO.getTotalDeltaSize(rootNodeRef, false));
assertEquals(1, usageDAO.getUsageDeltaNodes().size());
usageDAO.insertDelta(rootNodeRef, -500L);
assertEquals(600L, usageDAO.getTotalDeltaSize(rootNodeRef, false));
assertEquals(1, usageDAO.getUsageDeltaNodes().size());
NodeRef nodeRef1 = createNode(rootNodeId);
long nodeId1 = getNodeId(nodeRef1);
assertEquals(0L, usageDAO.getTotalDeltaSize(nodeRef1, false));
NodeRef nodeRef2 = createNode(rootNodeId);
long nodeId2 = getNodeId(nodeRef2);
assertEquals(0L, usageDAO.getTotalDeltaSize(nodeRef2, false));
assertEquals(1, usageDAO.getUsageDeltaNodes().size());
usageDAO.insertDelta(nodeRef1, 200L);
assertEquals(200L, usageDAO.getTotalDeltaSize(nodeRef1, false));
assertEquals(2, usageDAO.getUsageDeltaNodes().size());
usageDAO.insertDelta(nodeRef2, -400L);
assertEquals(-400L, usageDAO.getTotalDeltaSize(nodeRef2, false));
assertEquals(3, usageDAO.getUsageDeltaNodes().size());
usageDAO.deleteDeltas(rootNodeId);
assertEquals(0L, usageDAO.getTotalDeltaSize(rootNodeRef, false));
assertEquals(2, usageDAO.getUsageDeltaNodes().size());
usageDAO.deleteDeltas(nodeId1);
assertEquals(0L, usageDAO.getTotalDeltaSize(nodeRef1, false));
assertEquals(1, usageDAO.getUsageDeltaNodes().size());
usageDAO.deleteDeltas(nodeId2);
assertEquals(0L, usageDAO.getTotalDeltaSize(nodeRef2, false));
assertEquals(0, usageDAO.getUsageDeltaNodes().size());
return null;
}
};
txnHelper.doInTransaction(callback);
}
public void testCreateUsageDeltasWithRollback() throws Exception
{
RetryingTransactionCallback<Void> voidCallback = new RetryingTransactionCallback<Void>()
{
public Void execute() throws Throwable
{
NodeRef rootNodeRef = getRootNodeRef();
long rootNodeId = getNodeId(rootNodeRef);
usageDAO.deleteDeltas(rootNodeId);
assertEquals(0L, usageDAO.getTotalDeltaSize(rootNodeRef, false));
Set<NodeRef> usageDeltaNodes = usageDAO.getUsageDeltaNodes();
for (NodeRef nodeRef : usageDeltaNodes)
{
long nodeId = getNodeId(nodeRef);
usageDAO.deleteDeltas(nodeId);
}
assertEquals(0, usageDAO.getUsageDeltaNodes().size());
return null;
}
};
txnHelper.doInTransaction(voidCallback);
voidCallback = new RetryingTransactionCallback<Void>()
{
public Void execute() throws Throwable
{
NodeRef usageNodeRef = getRootNodeRef();
usageDAO.insertDelta(usageNodeRef, 100L);
// Now force a rollback
throw new RuntimeException("Forced");
}
};
try
{
txnHelper.doInTransaction(voidCallback);
fail("Transaction didn't roll back");
}
catch (RuntimeException e)
{
// Expected
}
// Check that it doesn't exist
voidCallback = new RetryingTransactionCallback<Void>()
{
public Void execute() throws Throwable
{
NodeRef usageNodeRef = getRootNodeRef();
assertEquals(0L, usageDAO.getTotalDeltaSize(usageNodeRef, false));
assertEquals(0, usageDAO.getUsageDeltaNodes().size());
return null;
}
};
txnHelper.doInTransaction(voidCallback);
}
}