use of com.adaptris.core.cache.ExpiringMapCache in project interlok by adaptris.
the class GetAndCacheOauthTokenTest method testService_WithError.
@Test(expected = ServiceException.class)
public void testService_WithError() throws Exception {
ExpiringMapCache cache = new ExpiringMapCache().withExpiration(new TimeInterval(5L, TimeUnit.SECONDS));
AccessToken t = new AccessToken(getName());
GetAndCacheOauthToken service = new GetAndCacheOauthToken().withCacheKey("OauthToken").withConnection(new CacheConnection(cache)).withAccessTokenBuilder(new DummyAccessTokenBuilder(t, true));
AdaptrisMessage msg = new DefaultMessageFactory().newMessage(TEXT);
execute(service, msg);
}
use of com.adaptris.core.cache.ExpiringMapCache in project interlok by adaptris.
the class AddValueToCacheTest method testDoService_NoExpiryMetadata.
@Test
public void testDoService_NoExpiryMetadata() throws Exception {
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage("Hello World");
ExpiringMapCache cache = createCacheInstanceForTests().withExpiration(new TimeInterval(1L, TimeUnit.SECONDS));
MyCacheEventListener listener = new MyCacheEventListener();
cache.getEventListener().addEventListener(listener);
AddValueToCache service = new AddValueToCache().withExpiry("%message{expiry}").withValueTranslator(new StringPayloadCacheTranslator()).withKey("%message{%uniqueId}").withConnection(new CacheConnection().withCacheInstance(cache));
try {
start(service);
// msg.addMetadata("expiry", "a"); // empty expiry should not expire.
service.doService(msg);
Object value = cache.get(msg.getUniqueId());
assertEquals("Hello World", value);
await().atMost(Duration.ofSeconds(5)).with().pollInterval(Duration.ofMillis(100)).until(listener::expiredCount, greaterThanOrEqualTo(1));
assertEquals(0, cache.size());
} finally {
stop(service);
}
}
use of com.adaptris.core.cache.ExpiringMapCache in project interlok by adaptris.
the class AddValueToCacheTest method testDoService_AbsoluteExpiry_Millis.
@Test
public void testDoService_AbsoluteExpiry_Millis() throws Exception {
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage("Hello World");
ExpiringMapCache cache = createCacheInstanceForTests();
MyCacheEventListener listener = new MyCacheEventListener();
cache.getEventListener().addEventListener(listener);
AddValueToCache service = new AddValueToCache().withExpiry("%message{expiry}").withValueTranslator(new StringPayloadCacheTranslator()).withKey("%message{%uniqueId}").withConnection(new CacheConnection().withCacheInstance(cache));
try {
start(service);
// Expire in 2 seconds or so.
long expiry = System.currentTimeMillis() + ThreadLocalRandom.current().nextInt(1000) + 1000;
msg.addMetadata("expiry", String.valueOf(expiry));
System.err.println(getName() + ":" + msg.getMetadataValue("expiry"));
service.doService(msg);
Object value = cache.get(msg.getUniqueId());
assertEquals("Hello World", value);
// Default expiration is > 5 seconds.
await().atMost(Duration.ofSeconds(5)).with().pollInterval(Duration.ofMillis(100)).until(listener::expiredCount, greaterThanOrEqualTo(1));
assertEquals(0, cache.size());
} finally {
stop(service);
}
}
use of com.adaptris.core.cache.ExpiringMapCache in project interlok by adaptris.
the class AddValueToCacheTest method testDoService_Expiry_Unsupported.
@Test
public void testDoService_Expiry_Unsupported() throws Exception {
AdaptrisMessage msg = AdaptrisMessageFactory.getDefaultInstance().newMessage("Hello World");
ExpiringMapCache cache = createCacheInstanceForTests().withExpiration(new TimeInterval(1L, TimeUnit.SECONDS));
MyCacheEventListener listener = new MyCacheEventListener();
cache.getEventListener().addEventListener(listener);
AddValueToCache service = new AddValueToCache().withExpiry("%message{expiry}").withValueTranslator(new StringPayloadCacheTranslator()).withKey("%message{%uniqueId}").withConnection(new CacheConnection().withCacheInstance(cache));
try {
start(service);
// unparseable expiry should not expire.
msg.addMetadata("expiry", "a");
service.doService(msg);
Object value = cache.get(msg.getUniqueId());
assertEquals("Hello World", value);
await().atMost(Duration.ofSeconds(5)).with().pollInterval(Duration.ofMillis(100)).until(listener::expiredCount, greaterThanOrEqualTo(1));
assertEquals(0, cache.size());
} finally {
stop(service);
}
}
use of com.adaptris.core.cache.ExpiringMapCache in project interlok by adaptris.
the class CheckCacheServiceTest method testDoService_Error.
@Test
public void testDoService_Error() throws Exception {
AdaptrisMessage msg = createMessage("Hello World", Arrays.asList(new MetadataElement[] { new MetadataElement(LOOKUP_VALUE, LOOKUP_VALUE) }));
ExpiringMapCache cache = new KeysSizeUnsupportedCache().withMaxEntries(10).withExpiration(new TimeInterval(10L, TimeUnit.SECONDS));
CheckCacheService service = new CheckCacheService() {
@Override
protected boolean eval(AdaptrisMessage msg, FoundInCache callback) throws CoreException {
throw new CoreException();
}
};
try {
service.withConnection(new CacheConnection().withCacheInstance(cache));
service.setKeysFoundServiceId(FOUND);
service.setKeysNotFoundServiceId(NOT_FOUND);
start(service);
cache.put(LOOKUP_VALUE, LOOKED_UP_VALUE);
service.doService(msg);
fail();
} catch (ServiceException expected) {
} finally {
stop(service);
}
}
Aggregations