mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
Merged HEAD-QA to HEAD (4.2) (including moving test classes into separate folders)
51903 to 54309 git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@54310 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -0,0 +1,260 @@
|
||||
/*
|
||||
* 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.usage;
|
||||
|
||||
import javax.transaction.UserTransaction;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
import org.alfresco.repo.lock.JobLockService;
|
||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
||||
import org.alfresco.service.cmr.admin.RepoUsage;
|
||||
import org.alfresco.service.cmr.admin.RepoUsage.LicenseMode;
|
||||
import org.alfresco.service.cmr.admin.RepoUsage.UsageType;
|
||||
import org.alfresco.service.cmr.admin.RepoUsageStatus;
|
||||
import org.alfresco.service.transaction.TransactionService;
|
||||
import org.alfresco.util.ApplicationContextHelper;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.junit.FixMethodOrder;
|
||||
import org.junit.runners.MethodSorters;
|
||||
import org.springframework.context.ApplicationContext;
|
||||
|
||||
/**
|
||||
* Tests {@link RepoUsageComponent}
|
||||
*
|
||||
* @author Derek Hulley
|
||||
* @since 3.5
|
||||
*/
|
||||
@FixMethodOrder(MethodSorters.NAME_ASCENDING)
|
||||
public class RepoUsageComponentTest extends TestCase
|
||||
{
|
||||
private static ApplicationContext ctx = ApplicationContextHelper.getApplicationContext();
|
||||
|
||||
private static final Log logger = LogFactory.getLog(RepoUsageComponentTest.class);
|
||||
|
||||
private TransactionService transactionService;
|
||||
private RepoUsageComponent repoUsageComponent;
|
||||
private JobLockService jobLockService;
|
||||
private UserTransaction txn;
|
||||
private RepoUsage restrictionsBefore;
|
||||
|
||||
@Override
|
||||
protected void setUp() throws Exception
|
||||
{
|
||||
transactionService = (TransactionService) ctx.getBean("transactionComponent");
|
||||
repoUsageComponent = (RepoUsageComponent) ctx.getBean("repoUsageComponent");
|
||||
jobLockService = (JobLockService) ctx.getBean("jobLockService");
|
||||
|
||||
AuthenticationUtil.setRunAsUserSystem();
|
||||
|
||||
txn = transactionService.getUserTransaction();
|
||||
txn.begin();
|
||||
|
||||
restrictionsBefore = repoUsageComponent.getRestrictions();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void tearDown() throws Exception
|
||||
{
|
||||
// Reset restrictions
|
||||
try
|
||||
{
|
||||
repoUsageComponent.setRestrictions(restrictionsBefore);
|
||||
}
|
||||
catch (Throwable e)
|
||||
{
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
AuthenticationUtil.clearCurrentSecurityContext();
|
||||
if (txn != null)
|
||||
{
|
||||
try { txn.commit(); } catch (Throwable e) {}
|
||||
}
|
||||
}
|
||||
|
||||
public void test1Setup()
|
||||
{
|
||||
}
|
||||
|
||||
/**
|
||||
* Helper to wrap in a txn
|
||||
*/
|
||||
private RepoUsage getUsage()
|
||||
{
|
||||
RetryingTransactionCallback<RepoUsage> getCallback = new RetryingTransactionCallback<RepoUsage>()
|
||||
{
|
||||
@Override
|
||||
public RepoUsage execute() throws Throwable
|
||||
{
|
||||
return repoUsageComponent.getUsage();
|
||||
}
|
||||
};
|
||||
return transactionService.getRetryingTransactionHelper().doInTransaction(getCallback, true);
|
||||
}
|
||||
|
||||
/**
|
||||
* Helper to wrap in a txn
|
||||
*/
|
||||
private boolean updateUsage(final UsageType usageType)
|
||||
{
|
||||
RetryingTransactionCallback<Boolean> getCallback = new RetryingTransactionCallback<Boolean>()
|
||||
{
|
||||
@Override
|
||||
public Boolean execute() throws Throwable
|
||||
{
|
||||
return repoUsageComponent.updateUsage(usageType);
|
||||
}
|
||||
};
|
||||
return transactionService.getRetryingTransactionHelper().doInTransaction(getCallback, false);
|
||||
}
|
||||
|
||||
public void test2NoTxn() throws Throwable
|
||||
{
|
||||
txn.commit();
|
||||
try
|
||||
{
|
||||
repoUsageComponent.getUsage();
|
||||
fail("Txn required for calls to RepoAdminComponent.");
|
||||
}
|
||||
catch (RuntimeException e)
|
||||
{
|
||||
// Expected
|
||||
}
|
||||
}
|
||||
|
||||
public void test3GetUsage()
|
||||
{
|
||||
getUsage();
|
||||
}
|
||||
|
||||
public void test4FullUse() throws Exception
|
||||
{
|
||||
// Set the restrictions
|
||||
RepoUsage restrictions = new RepoUsage(
|
||||
System.currentTimeMillis(),
|
||||
7L,
|
||||
600L,
|
||||
LicenseMode.TEAM,
|
||||
System.currentTimeMillis() + 24*3600000,
|
||||
false);
|
||||
repoUsageComponent.setRestrictions(restrictions);
|
||||
// Get the restrictions (should not need a txn for this)
|
||||
RepoUsage restrictionsCheck = repoUsageComponent.getRestrictions();
|
||||
assertEquals("Restrictions should return without change.", restrictions, restrictionsCheck);
|
||||
|
||||
// Update use
|
||||
updateUsage(UsageType.USAGE_ALL);
|
||||
|
||||
// Get the usage
|
||||
RepoUsage usage = getUsage();
|
||||
// Check
|
||||
assertNotNull("Usage is null", usage);
|
||||
assertNotNull("Invalid user count", usage.getUsers());
|
||||
assertNotNull("Invalid document count", usage.getDocuments());
|
||||
assertEquals("License mode not set", restrictions.getLicenseMode(), usage.getLicenseMode());
|
||||
assertEquals("License expiry not set", restrictions.getLicenseExpiryDate(), usage.getLicenseExpiryDate());
|
||||
assertEquals("Read-only state not set", restrictions.isReadOnly(), usage.isReadOnly());
|
||||
|
||||
RepoUsageStatus status = repoUsageComponent.getUsageStatus();
|
||||
logger.debug(status);
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests license code interaction. This interaction would be done using runAs 'System'.
|
||||
*/
|
||||
public void test5LicenseUse() throws Exception
|
||||
{
|
||||
Long licenseUserLimit = 5L;
|
||||
Long licenseDocumentLimit = 100000L;
|
||||
LicenseMode licenseMode = LicenseMode.TEAM;
|
||||
Long licenseExpiry = System.currentTimeMillis() + 24*3600000;
|
||||
|
||||
// Get actual license details (incl. generating trial license)
|
||||
// Push license restrictions
|
||||
RepoUsage restrictions = new RepoUsage(
|
||||
System.currentTimeMillis(),
|
||||
licenseUserLimit, // From license
|
||||
licenseDocumentLimit, // From license
|
||||
licenseMode, // From license
|
||||
licenseExpiry, // From license
|
||||
transactionService.getAllowWrite() == false);// After license validity has been verified
|
||||
repoUsageComponent.setRestrictions(restrictions);
|
||||
// Trigger a usage update
|
||||
updateUsage(UsageType.USAGE_ALL);
|
||||
// Get the usage
|
||||
@SuppressWarnings("unused")
|
||||
RepoUsage usage = getUsage();
|
||||
}
|
||||
|
||||
/**
|
||||
* Check that concurrent updates are prevented
|
||||
*/
|
||||
public void test6ConcurrentUpdates() throws Exception
|
||||
{
|
||||
// Firstly check that we can get an update
|
||||
assertTrue("Failed to update all usages", updateUsage(UsageType.USAGE_ALL));
|
||||
assertTrue("Failed to update user count", updateUsage(UsageType.USAGE_USERS));
|
||||
assertTrue("Failed to update document count", updateUsage(UsageType.USAGE_DOCUMENTS));
|
||||
|
||||
// Now take a lock of it all and see that they fail
|
||||
String lockToken = jobLockService.getLock(RepoUsageComponent.LOCK_USAGE, RepoUsageComponent.LOCK_TTL);
|
||||
try
|
||||
{
|
||||
// Check
|
||||
assertFalse("Expected usage updates to be kicked out", updateUsage(UsageType.USAGE_ALL));
|
||||
assertFalse("Expected usage updates to be kicked out", updateUsage(UsageType.USAGE_USERS));
|
||||
assertFalse("Expected usage updates to be kicked out", updateUsage(UsageType.USAGE_DOCUMENTS));
|
||||
}
|
||||
finally
|
||||
{
|
||||
jobLockService.releaseLock(lockToken, RepoUsageComponent.LOCK_USAGE);
|
||||
}
|
||||
|
||||
// Lock documents updates only
|
||||
lockToken = jobLockService.getLock(RepoUsageComponent.LOCK_USAGE_DOCUMENTS, RepoUsageComponent.LOCK_TTL);
|
||||
try
|
||||
{
|
||||
// Check
|
||||
assertFalse("Expected usage updates to be kicked out", updateUsage(UsageType.USAGE_ALL));
|
||||
assertTrue("Failed to update user count", updateUsage(UsageType.USAGE_USERS));
|
||||
assertFalse("Expected document usage updates to be kicked out", updateUsage(UsageType.USAGE_DOCUMENTS));
|
||||
}
|
||||
finally
|
||||
{
|
||||
jobLockService.releaseLock(lockToken, RepoUsageComponent.LOCK_USAGE_DOCUMENTS);
|
||||
}
|
||||
|
||||
// Lock user updates only
|
||||
lockToken = jobLockService.getLock(RepoUsageComponent.LOCK_USAGE_USERS, RepoUsageComponent.LOCK_TTL);
|
||||
try
|
||||
{
|
||||
// Check
|
||||
assertFalse("Expected usage updates to be kicked out", updateUsage(UsageType.USAGE_ALL));
|
||||
assertFalse("Expected user usage updates to be kicked out", updateUsage(UsageType.USAGE_USERS));
|
||||
assertTrue("Failed to update document count", updateUsage(UsageType.USAGE_DOCUMENTS));
|
||||
}
|
||||
finally
|
||||
{
|
||||
jobLockService.releaseLock(lockToken, RepoUsageComponent.LOCK_USAGE_USERS);
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user