alfresco-community-repo/source/java/org/alfresco/repo/usage/RepoUsageComponentTest.java

261 lines
9.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.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);
}
}
}