mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-23 18:05:32 +00:00
9845: Merged V2.2 to V2.9 9733: Merged V2.1 to V2.2 9281: Improvements to index AUTO recovery 9316: Fixed ETWOONE-193: Transactional caches not being cleaned up after rollback (2.1.4 regression) 9317: Fixed ETWOONE-194: Faster void handling during index tracking 9365: Improved performance for finding which snapshots have been indexed 9413: Support to retrieve read/write state of the transaction and ensure Lucene commits are handled last 9414: ACT-3245: Updating node properties and aspects don't bump the alf_node.version value 9415: Code cleanup: Removed unnecessary empty methods 9416: Fixed creation of multiple thread pools 9417: Full index recovery absorbs indexing exceptions by default 9418: Added AUTO index recovery option to sample in line with Wiki docs 9419: ETWOONE-194: Index tracking is too slow 9420: Fixed ETWOONE-201: Better logging and configurability for RetryingTransactionHelper 9421: Fixed ETWOONE-202: SPlit person cleanup doesn't break read-only transactions 9422: Follow up on CHK-3317: Removed use of JDK 1.6 NavigableMap interface 9423: Fixed unit test after CHK-3317 9424: More test fixes after CHK-3317 9425: Ensure that index tracking tests don't run too long. 9426: Made concurrent reindexing optional. It is on by default. 9509: ACT-3539: Mid-transaction locking on Lucene resources 9547: Multithreaded index tracking startup: Handle previously lagging single-threaded rebuilds git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@10592 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
142 lines
5.9 KiB
Java
142 lines
5.9 KiB
Java
/*
|
|
* Copyright (C) 2005-2006 Alfresco, Inc.
|
|
*
|
|
* Licensed under the Mozilla Public License version 1.1
|
|
* with a permitted attribution clause. You may obtain a
|
|
* copy of the License at
|
|
*
|
|
* http://www.alfresco.org/legal/license.txt
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
* either express or implied. See the License for the specific
|
|
* language governing permissions and limitations under the
|
|
* License.
|
|
*/
|
|
package org.alfresco.repo.node.index;
|
|
|
|
import java.util.concurrent.ThreadPoolExecutor;
|
|
|
|
import junit.framework.TestCase;
|
|
|
|
import org.alfresco.model.ContentModel;
|
|
import org.alfresco.repo.content.ContentStore;
|
|
import org.alfresco.repo.node.db.NodeDaoService;
|
|
import org.alfresco.repo.search.Indexer;
|
|
import org.alfresco.repo.search.impl.lucene.fts.FullTextSearchIndexer;
|
|
import org.alfresco.repo.security.authentication.AuthenticationComponent;
|
|
import org.alfresco.repo.transaction.TransactionServiceImpl;
|
|
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
|
import org.alfresco.service.ServiceRegistry;
|
|
import org.alfresco.service.cmr.model.FileFolderService;
|
|
import org.alfresco.service.cmr.repository.ChildAssociationRef;
|
|
import org.alfresco.service.cmr.repository.NodeRef;
|
|
import org.alfresco.service.cmr.repository.NodeService;
|
|
import org.alfresco.service.cmr.repository.StoreRef;
|
|
import org.alfresco.service.cmr.search.SearchService;
|
|
import org.alfresco.service.namespace.NamespaceService;
|
|
import org.alfresco.service.namespace.QName;
|
|
import org.alfresco.service.transaction.TransactionService;
|
|
import org.alfresco.util.ApplicationContextHelper;
|
|
import org.springframework.context.ApplicationContext;
|
|
|
|
/**
|
|
* @see org.alfresco.repo.node.index.IndexRemoteTransactionTracker
|
|
*
|
|
* @author Derek Hulley
|
|
*/
|
|
@SuppressWarnings("unused")
|
|
public class IndexTransactionTrackerTest extends TestCase
|
|
{
|
|
private static ApplicationContext ctx = ApplicationContextHelper.getApplicationContext();
|
|
|
|
private AuthenticationComponent authenticationComponent;
|
|
private SearchService searchService;
|
|
private NodeService nodeService;
|
|
private ThreadPoolExecutor threadPoolExecutor;
|
|
private FileFolderService fileFolderService;
|
|
private ContentStore contentStore;
|
|
private FullTextSearchIndexer ftsIndexer;
|
|
private Indexer indexer;
|
|
private NodeRef rootNodeRef;
|
|
|
|
private IndexTransactionTracker indexTracker;
|
|
|
|
public void setUp() throws Exception
|
|
{
|
|
ServiceRegistry serviceRegistry = (ServiceRegistry) ctx.getBean(ServiceRegistry.SERVICE_REGISTRY);
|
|
searchService = serviceRegistry.getSearchService();
|
|
nodeService = serviceRegistry.getNodeService();
|
|
threadPoolExecutor = (ThreadPoolExecutor) ctx.getBean("indexTrackerThreadPoolExecutor");
|
|
fileFolderService = serviceRegistry.getFileFolderService();
|
|
authenticationComponent = (AuthenticationComponent) ctx.getBean("authenticationComponent");
|
|
contentStore = (ContentStore) ctx.getBean("fileContentStore");
|
|
ftsIndexer = (FullTextSearchIndexer) ctx.getBean("LuceneFullTextSearchIndexer");
|
|
|
|
indexer = (Indexer) ctx.getBean("indexerComponent");
|
|
NodeDaoService nodeDaoService = (NodeDaoService) ctx.getBean("nodeDaoService");
|
|
TransactionService transactionService = serviceRegistry.getTransactionService();
|
|
indexTracker = new IndexTransactionTracker();
|
|
indexTracker.setAuthenticationComponent(authenticationComponent);
|
|
indexTracker.setFtsIndexer(ftsIndexer);
|
|
indexTracker.setIndexer(indexer);
|
|
indexTracker.setNodeDaoService(nodeDaoService);
|
|
indexTracker.setNodeService(nodeService);
|
|
indexTracker.setThreadPoolExecutor(threadPoolExecutor);
|
|
indexTracker.setSearcher(searchService);
|
|
indexTracker.setTransactionService((TransactionServiceImpl)transactionService);
|
|
|
|
// authenticate
|
|
authenticationComponent.setSystemUserAsCurrentUser();
|
|
|
|
// disable indexing
|
|
RetryingTransactionCallback<ChildAssociationRef> createNodeWork = new RetryingTransactionCallback<ChildAssociationRef>()
|
|
{
|
|
public ChildAssociationRef execute() throws Exception
|
|
{
|
|
StoreRef storeRef = new StoreRef("test", getName() + "-" + System.currentTimeMillis());
|
|
NodeRef rootNodeRef = null;
|
|
if (!nodeService.exists(storeRef))
|
|
{
|
|
nodeService.createStore(storeRef.getProtocol(), storeRef.getIdentifier());
|
|
}
|
|
rootNodeRef = nodeService.getRootNode(storeRef);
|
|
// create another node
|
|
ChildAssociationRef childAssocRef = nodeService.createNode(
|
|
rootNodeRef,
|
|
ContentModel.ASSOC_CHILDREN,
|
|
QName.createQName(NamespaceService.ALFRESCO_URI, "xyz"),
|
|
ContentModel.TYPE_FOLDER);
|
|
// remove the node from the index
|
|
indexer.deleteNode(childAssocRef);
|
|
return childAssocRef;
|
|
}
|
|
};
|
|
ChildAssociationRef childAssocRef = transactionService.getRetryingTransactionHelper().doInTransaction(createNodeWork, false);
|
|
}
|
|
|
|
public void testSetup() throws Exception
|
|
{
|
|
|
|
}
|
|
|
|
public synchronized void testStartup() throws Exception
|
|
{
|
|
Thread reindexThread = new Thread()
|
|
{
|
|
public void run()
|
|
{
|
|
indexTracker.reindex();
|
|
indexTracker.reindex();
|
|
}
|
|
};
|
|
reindexThread.setDaemon(true);
|
|
reindexThread.start();
|
|
// wait a bit and then terminate
|
|
wait(20000);
|
|
indexTracker.setShutdown(true);
|
|
wait(20000);
|
|
}
|
|
}
|