/* * 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 . */ package org.alfresco.repo.domain.solr; import java.util.ArrayList; import java.util.Collections; import java.util.HashSet; import java.util.Iterator; import java.util.List; import java.util.Set; import junit.framework.TestCase; import org.alfresco.repo.domain.node.Node; import org.alfresco.repo.security.authentication.AuthenticationComponent; import org.alfresco.repo.solr.Acl; import org.alfresco.repo.solr.AclChangeSet; import org.alfresco.repo.solr.NodeParameters; import org.alfresco.repo.solr.Transaction; import org.alfresco.service.cmr.repository.StoreRef; import org.alfresco.util.ApplicationContextHelper; import org.springframework.context.ConfigurableApplicationContext; /** * Tests for the SOLR DAO * * @since 4.0 */ public class SOLRDAOTest extends TestCase { private ConfigurableApplicationContext ctx = (ConfigurableApplicationContext) ApplicationContextHelper.getApplicationContext(); private AuthenticationComponent authenticationComponent; private SOLRDAO solrDAO; @Override public void setUp() throws Exception { solrDAO = (SOLRDAO)ctx.getBean("solrDAO"); authenticationComponent = (AuthenticationComponent)ctx.getBean("authenticationComponent"); authenticationComponent.setSystemUserAsCurrentUser(); } public void testQueryChangeSets_NoLimit() { long startTime = System.currentTimeMillis() - (5 * 60000L); try { solrDAO.getAclChangeSets(null, startTime, null, null, 0); fail("Must have result limit"); } catch (IllegalArgumentException e) { // Expected } } public void testQueryChangeSets_Time() { long startTime = System.currentTimeMillis() + (5 * 60000L); // The future List results = solrDAO.getAclChangeSets(null, startTime, null, null, 50); assertTrue("ChangeSet count not limited", results.size() == 0); } public void testQueryChangeSets_Limit() { List results = solrDAO.getAclChangeSets(null, 0L, null, null, 50); assertTrue("Transaction count not limited", results.size() <= 50); } /** * Argument checks. */ public void testQueryAcls_Arguments() { try { // No IDs solrDAO.getAcls(Collections.emptyList(), null, 50); fail("Expected IllegalArgumentException"); } catch (IllegalArgumentException e) { // Expected } try { // No limit on results solrDAO.getAcls(Collections.singletonList(1L), null, 0); fail("Expected IllegalArgumentException"); } catch (IllegalArgumentException e) { // Expected } } public void testQueryAcls_All() { // Do a query for some changesets List aclChangeSets = solrDAO.getAclChangeSets(null, 0L, null, null, 50); // Choose some changesets with changes int aclTotal = 0; Iterator aclChangeSetsIterator = aclChangeSets.iterator(); while (aclChangeSetsIterator.hasNext()) { AclChangeSet aclChangeSet = aclChangeSetsIterator.next(); if (aclChangeSet.getAclCount() == 0) { aclChangeSetsIterator.remove(); } else { aclTotal += aclChangeSet.getAclCount(); } } // Stop if we don't have ACLs if (aclTotal == 0) { return; } List aclChangeSetIds = toIds(aclChangeSets); // Now use those to query for details List acls = solrDAO.getAcls(aclChangeSetIds, null, 1000); // Check that the ACL ChangeSet IDs are correct Set aclChangeSetIdsSet = new HashSet(aclChangeSetIds); for (Acl acl : acls) { Long aclChangeSetId = acl.getAclChangeSetId(); assertTrue("ACL ChangeSet ID not in original list", aclChangeSetIdsSet.contains(aclChangeSetId)); } } public void testQueryAcls_Single() { List aclChangeSets = solrDAO.getAclChangeSets(null, 0L, null, null, 1000); // Find one with multiple ALCs AclChangeSet aclChangeSet = null; for (AclChangeSet aclChangeSetLoop : aclChangeSets) { if (aclChangeSetLoop.getAclCount() > 1) { aclChangeSet = aclChangeSetLoop; break; } } if (aclChangeSet == null) { // Nothing to test: Very unlikely return; } // Loop a few times and check that the count is correct Long aclChangeSetId = aclChangeSet.getId(); List aclChangeSetIds = Collections.singletonList(aclChangeSetId); int aclCount = aclChangeSet.getAclCount(); int totalAclCount = 0; Long minAclId = null; while (true) { List acls = solrDAO.getAcls(aclChangeSetIds, minAclId, 1); if (acls.size() == 0) { break; } assertEquals("Expected exactly one result", 1, acls.size()); totalAclCount++; minAclId = acls.get(0).getId() + 1; } assertEquals("Expected to page to exact number of results", aclCount, totalAclCount); } private List toIds(List aclChangeSets) { List ids = new ArrayList(aclChangeSets.size()); for (AclChangeSet aclChangeSet : aclChangeSets) { ids.add(aclChangeSet.getId()); } return ids; } public void testQueryTransactions_NoLimit() { long startTime = System.currentTimeMillis() - (5 * 60000L); try { solrDAO.getTransactions(null, startTime, null, null, 0); fail("Must have result limit"); } catch (IllegalArgumentException e) { // Expected } } public void testQueryTransactions_Time() { long startTime = System.currentTimeMillis() + (5 * 60000L); // The future List results = solrDAO.getTransactions(null, startTime, null, null, 50); assertTrue("Transaction count not limited", results.size() == 0); } public void testQueryTransactions_Limit() { List results = solrDAO.getTransactions(null, 0L, null, null, 50); assertTrue("Transaction count not limited", results.size() <= 50); } public void testGetNodesSimple() { long startTime = 0L; List txns = solrDAO.getTransactions(null, startTime, null, null, 500); List txnIds = toTxnIds(txns); NodeParameters nodeParameters = new NodeParameters(); nodeParameters.setTransactionIds(txnIds); nodeParameters.setStoreProtocol(StoreRef.PROTOCOL_WORKSPACE); nodeParameters.setStoreIdentifier(StoreRef.STORE_REF_WORKSPACE_SPACESSTORE.getIdentifier()); List nodes = solrDAO.getNodes(nodeParameters); assertTrue("Expect 'some' nodes associated with txns", nodes.size() > 0); } public void testGetNodesForStore() { List txns = solrDAO.getTransactions(null, null, null, null, 500); List txnIds = toTxnIds(txns); NodeParameters nodeParameters = new NodeParameters(); nodeParameters.setTransactionIds(txnIds); List nodes = solrDAO.getNodes(nodeParameters); assertTrue("Expect 'some' nodes associated with txns", nodes.size() > 0); } public void testGetNodesForTxnRange() { List txns = solrDAO.getTransactions(null, null, null, null, 500); List txnIds = toTxnIds(txns); // Only works if there are transactions if (txnIds.size() < 2) { // Nothing to test return; } NodeParameters nodeParameters = new NodeParameters(); nodeParameters.setFromTxnId(txnIds.get(0)); nodeParameters.setToTxnId(txnIds.get(1)); List nodes = solrDAO.getNodes(nodeParameters); assertTrue("Expect 'some' nodes associated with txns", nodes.size() > 0); } private List toTxnIds(List txns) { List txnIds = new ArrayList(txns.size()); for(Transaction txn : txns) { txnIds.add(txn.getId()); } return txnIds; } }