testturbinecache.java
来自「jetspeed源代码」· Java 代码 · 共 512 行 · 第 1/2 页
JAVA
512 行
}
/**
* Verify the all object will be flushed from the cache.
*
* This test can take server minutes.
*
* @throws Exception
*/
public void testCacheFlush() throws Exception {
String testString = new String( "This is a test");
Object retrievedObject = null;
CachedObject cacheObject = null;
GlobalCacheService globalCache = (GlobalCacheService)TurbineServices
.getInstance()
.getService( GlobalCacheService.SERVICE_NAME );
// Create and add Object that expires in 1 turbine Refresh + 1 millis
cacheObject = new CachedObject(testString, (TURBINE_CACHE_REFRESH*5) + 1);
assertNotNull( "Failed to create a cachable object", cacheObject);
long addTime = System.currentTimeMillis();
globalCache.addObject(cacheKey, cacheObject);
// 1 Refresh
Thread.sleep(TURBINE_CACHE_REFRESH + 1);
assertTrue("No object in cache before flush", (0 < globalCache.getNumberOfObjects()));
// Flush Cache
globalCache.flushCache();
// Wait 15 seconds, 3 Refresh
Thread.sleep((TURBINE_CACHE_REFRESH * 2) + 1);
assertEquals("After refresh", 0, globalCache.getNumberOfObjects());
// Remove objects
globalCache.removeObject(cacheKey);
}
/**
* Verify the Cache count is correct.
*
* This test can take serveral minutes.
*
* @throws Exception
*/
public void testObjectCount() throws Exception {
GlobalCacheService globalCache = (GlobalCacheService)TurbineServices
.getInstance()
.getService( GlobalCacheService.SERVICE_NAME );
assertNotNull("Could not retrive cache service.", globalCache);
// Create and add Object that expires in 1.5 turbine Refresh
long expireTime = TURBINE_CACHE_REFRESH + TURBINE_CACHE_REFRESH/2;
CachedObject cacheObject = new CachedObject("This is a test", expireTime);
assertNotNull( "Failed to create a cachable object", cacheObject);
globalCache.addObject(cacheKey, cacheObject);
assertEquals("After adding 1 Object", 1, globalCache.getNumberOfObjects());
// Wait until we're passed 1 refresh, but not half way.
Thread.sleep(TURBINE_CACHE_REFRESH + TURBINE_CACHE_REFRESH/3);
assertEquals("After one refresh", 1, globalCache.getNumberOfObjects());
// Wait until we're passed 2 more refreshes
Thread.sleep((TURBINE_CACHE_REFRESH * 2) + TURBINE_CACHE_REFRESH/3);
assertEquals("After three refreshes", 0, globalCache.getNumberOfObjects());
}
/**
* Verfy a refreshable object will refreshed in the following cases:
* o The object is retrieved via getObject an it is stale.
* o The object is determied to be stale during a cache
* refresh
*
* This test can take serveral minutes.
*
* @throws Exception
*/
public void testRefreshableObject() throws Exception {
String testString = new String( "This is a test");
Object retrievedObject = null;
RefreshableCachedObject cacheObject = null;
long addTime = 0;
boolean turbineCachePatchApplied = false; // FIXME: Remove when patch applied
GlobalCacheService globalCache = (GlobalCacheService)TurbineServices
.getInstance()
.getService( GlobalCacheService.SERVICE_NAME );
// Create and add Object that expires in TEST_EXPIRETIME millis.
cacheObject = new RefreshableCachedObject(new RefreshableObject(), TEST_EXPIRETIME);
assertNotNull( "Failed to create a cachable object", cacheObject);
globalCache.addObject(cacheKey, cacheObject);
addTime = System.currentTimeMillis();
// Try to get un-expired object
try {
retrievedObject = null;
retrievedObject = globalCache.getObject(cacheKey);
assertNotNull( "Did not retrieved a cached object", retrievedObject);
assertEquals( "Did not retrieved correct cached object", cacheObject, retrievedObject);
} catch (ObjectExpiredException e) {
assertTrue( "Object expired early ( " + (System.currentTimeMillis() - addTime) + " millis)", false);
} catch (Exception e) {
throw e;
}
// Wait 1 Turbine cache refresh + 1 second.
Thread.sleep(TEST_EXPIRETIME + 1000);
// Try to get expired object
try {
retrievedObject = null;
retrievedObject = globalCache.getObject(cacheKey);
assertNotNull( "Did not retrieved a cached object, after sleep", retrievedObject);
assertNotNull( "Cached object has no contents, after sleep.", ((RefreshableCachedObject)retrievedObject).getContents());
assertTrue( "Object did not refresh.", ( ((RefreshableObject)((RefreshableCachedObject)retrievedObject).getContents()).getRefreshCount() > 0));
} catch (ObjectExpiredException e) {
assertTrue( "Received unexpected ObjectExpiredException exception "
+ "when retrieving refreshable object after ( "
+ (System.currentTimeMillis() - addTime) + " millis)", false);
} catch (Exception e) {
throw e;
}
// See if object will expires (testing every second for 100 seconds. It sould not!
for (int i=0; (i<100); i++) {
Thread.sleep(1000); // Sleep 0.5 seconds
// Try to get expired object
try {
retrievedObject = null;
retrievedObject = globalCache.getObject(cacheKey);
assertNotNull( "Did not retrieved a cached object, after sleep", retrievedObject);
assertNotNull( "Cached object has no contents, after sleep.", ((RefreshableCachedObject)retrievedObject).getContents());
assertTrue( "Object did not refresh.", ( ((RefreshableObject)((RefreshableCachedObject)retrievedObject).getContents()).getRefreshCount() > 0));
} catch (ObjectExpiredException e) {
assertTrue( "Received unexpected ObjectExpiredException exception "
+ "when retrieving refreshable object after ( "
+ (System.currentTimeMillis() - addTime) + " millis)", false);
} catch (Exception e) {
throw e;
}
}
// Remove objects
globalCache.removeObject(cacheKey);
}
/**
* Verify a cached object will be delete after it has been
* untouched beyond it's TimeToLive.
*
* This test can take serveral minutes.
*
* @throws Exception
*/
public void testRefreshableTimeToLive() throws Exception {
String testString = new String( "This is a test");
Object retrievedObject = null;
RefreshableCachedObject cacheObject = null;
long addTime = 0;
GlobalCacheService globalCache = (GlobalCacheService)TurbineServices
.getInstance()
.getService( GlobalCacheService.SERVICE_NAME );
// Create and add Object that expires in TEST_EXPIRETIME millis.
cacheObject = new RefreshableCachedObject(new RefreshableObject(), TEST_EXPIRETIME);
assertNotNull( "Failed to create a cachable object", cacheObject);
cacheObject.setTTL(TEST_TIMETOLIVE);
// Verify TimeToLive was set
assertEquals( "Returned TimeToLive", TEST_TIMETOLIVE, cacheObject.getTTL());
// Add object to Cache
globalCache.addObject(cacheKey, cacheObject);
addTime = System.currentTimeMillis();
// Try to get un-expired object
try {
retrievedObject = null;
retrievedObject = globalCache.getObject(cacheKey);
assertNotNull( "Did not retrieved a cached object", retrievedObject);
assertEquals( "Did not retrieved correct cached object", cacheObject, retrievedObject);
} catch (ObjectExpiredException e) {
assertTrue( "Object expired early ( " + (System.currentTimeMillis() - addTime) + " millis)", false);
} catch (Exception e) {
throw e;
}
// Wait long enough to allow object to expire, but do not exceed TTL
Thread.sleep(TEST_TIMETOLIVE - 2000);
// Try to get expired object
try {
retrievedObject = null;
retrievedObject = globalCache.getObject(cacheKey);
assertNotNull( "Did not retrieved a cached object, after sleep", retrievedObject);
assertNotNull( "Cached object has no contents, after sleep.", ((RefreshableCachedObject)retrievedObject).getContents());
assertTrue( "Object did not refresh.", ( ((RefreshableObject)((RefreshableCachedObject)retrievedObject).getContents()).getRefreshCount() > 0));
} catch (ObjectExpiredException e) {
assertTrue( "Received unexpected ObjectExpiredException exception "
+ "when retrieving refreshable object after ( "
+ (System.currentTimeMillis() - addTime) + " millis)", false);
} catch (Exception e) {
throw e;
}
// Wait long enough to allow object to expire and exceed TTL
Thread.sleep(TEST_TIMETOLIVE +5000);
// Try to get expired object
try {
retrievedObject = null;
retrievedObject = globalCache.getObject(cacheKey);
assertNull( "Retrieved a cached object, after exceeding TimeToLive", retrievedObject);
} catch (ObjectExpiredException e) {
assertNull( "Retrieved the expired cached object, but caught expected ObjectExpiredException exception", retrievedObject);
} catch (Exception e) {
throw e;
}
}
/**
* Simple object that can be refreshed
*/
class RefreshableObject implements Refreshable {
private int refreshCount = 0;
/**
* Increment the refresh counter
*/
public void refresh() {
this.refreshCount++;
}
/**
* Reutrn the number of time this object has been refreshed
*
* @return Number of times refresh() has been called
*/
public int getRefreshCount() {
return this.refreshCount;
}
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?