diff --git a/README.md b/README.md index 64e3275..64aafb4 100644 --- a/README.md +++ b/README.md @@ -151,11 +151,10 @@ public class ArcusConfiguration extends CachingConfigurerSupport { @Bean public ArcusCacheConfiguration defaultCacheConfig() { - ArcusCacheConfiguration defaultCacheConfig = new ArcusCacheConfiguration(); - defaultCacheConfig.setPrefix("DEFAULT"); - defaultCacheConfig.setExpireSeconds(60); - defaultCacheConfig.setTimeoutMilliSeconds(800); - return defaultCacheConfig; + return new ArcusCacheConfiguration() + .withPrefix("DEFAULT") + .withExpireSeconds(60) + .withTimeoutMilliSeconds(800); } @Bean @@ -168,22 +167,20 @@ public class ArcusConfiguration extends CachingConfigurerSupport { @Bean public ArcusCacheConfiguration testCacheConfig() { - ArcusCacheConfiguration cacheConfig = new ArcusCacheConfiguration(); - cacheConfig.setServiceId("TEST-"); - cacheConfig.setPrefix("PRODUCT"); - cacheConfig.setExpireSeconds(60); - cacheConfig.setTimeoutMilliSeconds(800); - return cacheConfig; + return new ArcusCacheConfiguration() + .withServiceId("TEST-") + .withPrefix("PRODUCT") + .withExpireSeconds(60) + .withTimeoutMillisSeconds(800); } @Bean public ArcusCacheConfiguration devCacheConfig() { - ArcusCacheConfiguration cacheConfig = new ArcusCacheConfiguration(); - cacheConfig.setServiceId("DEV-"); - cacheConfig.setPrefix("PRODUCT"); - cacheConfig.setExpireSeconds(120); - cacheConfig.setTimeoutMilliSeconds(800); - return cacheConfig; + return new ArcusCacheConfiguration() + .withServiceId("DEV-") + .withPrefix("PRODUCT") + .withExpireSeconds(120) + .withTimeoutMillisSeconds(800); } } @@ -234,32 +231,30 @@ You can use the front cache to provide fast responsiveness of cache requests. Th ```java @Bean public ArcusCacheConfiguration testCacheConfig() { - ArcusCacheConfiguration cacheConfig = new ArcusCacheConfiguration(); - cacheConfig.setServiceId("TEST-"); - cacheConfig.setPrefix("PRODUCT"); - cacheConfig.setExpireSeconds(60); - cacheConfig.setTimeoutMilliSeconds(800); - /* front cache configuration */ - cacheConfig.setArcusFrontCache(testArcusFrontCache()); - cacheConfig.setFrontExpireSeconds(120); - cacheConfig.setForceFrontCaching(false); - /* front cache configuration */ - return cacheConfig; + return new ArcusCacheConfiguration() + .withServiceId("TEST-") + .withPrefix("PRODUCT") + .withExpireSeconds(60) + .withTimeoutMilliSeconds(800) + /* front cache configuration */ + .withArcusFrontCache(testArcusFrontCache()) + .withFrontExpireSeconds(120) + .enableForcingFrontCache(); + /* front cache configuration */ } @Bean public ArcusCacheConfiguration devCacheConfig() { - ArcusCacheConfiguration cacheConfig = new ArcusCacheConfiguration(); - cacheConfig.setServiceId("DEV-"); - cacheConfig.setPrefix("PRODUCT"); - cacheConfig.setExpireSeconds(120); - cacheConfig.setTimeoutMilliSeconds(800); - /* front cache configuration */ - cacheConfig.setArcusFrontCache(devArcusFrontCache()); - cacheConfig.setFrontExpireSeconds(240); - cacheConfig.setForceFrontCaching(true); - /* front cache configuration */ - return cacheConfig; + return new ArcusCacheConfiguration() + .withServiceId("DEV-") + .withPrefix("PRODUCT") + .withExpireSeconds(120) + .withTimeoutMilliSeconds(800) + /* front cache configuration */ + .withArcusFrontCache(devArcusFrontCache()) + .withFrontExpireSeconds(240) + .enableForcingFrontCache(); + /* front cache configuration */ } @Bean @@ -273,16 +268,22 @@ public ArcusFrontCache devArcusFrontCache() { } ``` -The properties added to the `ArcusCache` class related to Front Cache are as follows. +The properties added to the `ArcusCacheConfiguration` class related to Front Cache are as follows. + +- `withArcusFrontCache(ArcusFrontCache arcusFrontCache)` + - Set the ArcusFrontCache object to enable Front Caching. + - The DefaultArcusFrontCache class provided by Arcus Spring can be used. + - Front caching is disabled by default and arguments cannot be set to null. +- `withFrontExpireSeconds(int frontExpireSeconds)` + - Set Front Cache TTL(TimeToLive). +- `enableForcingFrontCache()`, `disableForcingFrontCache()` + - Whether to perform front caching regardless of the ARCUS request is success or fail. +- `withFrontExpireSeconds(int frontExpireSeconds)` + - Front Cache의 TTL(TimeToLive)을 설정한다. +- `enableForcingFrontCache()`, `disableForcingFrontCache()` + - Set whether to perform Front Cache regardless of success or failure of ARCUS request. + - It is disabled by default. -- `setArcusFrontCache(ArcusFrontCache arcusFrontCache)` - - Front Cache instance setting. If it is a null value, Front Cache does not work. -- `setFrontExpireSeconds(int frontExpireSeconds)` - - Front Cache TTL(TimeToLive) setting. -- `setForceFrontCaching(int forceFrontCaching)` - - true: Even if the change request of ARCUS fails, the change request is reflected in Front Cache. When a request fails due to an ARCUS failure, the Front Cache function can be worked. But, it is prone to data consistency issues, so we recommend using it only for data that doesn't change frequently. - - false: If the change request of ARCUS fails, the change request is not reflected in Front Cache. - Front Caching is not always performed. It is performed depending on the attribute of `forceFrontCaching` property and the result of the ARCUS request. | ArcusCache API | ARCUS Result | forceFrontCaching=false | forceFrontCaching=true | diff --git a/docs/02-arcus-spring-concept.md b/docs/02-arcus-spring-concept.md index 2b345da..1c75149 100644 --- a/docs/02-arcus-spring-concept.md +++ b/docs/02-arcus-spring-concept.md @@ -56,27 +56,39 @@ ArcusCache 객체는 String 타입의 캐시 이름과 ArcusCacheConfiguration ArcusCache 객체를 생성하기 위해 사용되는 캐시 설정 클래스이다. -사용자가 직접 ArcusCacheConfiguration 객체를 생성하고 Setter 메소드를 통해 캐시 설정을 조정한 뒤, ArcusCacheManager 객체를 생성할 때 생성자의 인자로 넘겨주면 된다. +ArcusCacheConfiguration 객체를 생성하고 아래 메소드를 통해 속성을 설정한 뒤, ArcusCacheManager 객체를 생성할 때 생성자의 인자로 넘겨주면 된다. +모든 속성을 기본값으로 사용하고 싶다면 인자가 없는 생성자로 생성한 객체를 사용하면 된다. -캐시 키에 들어갈 Prefix, 캐시 아이템의 Expire Time, 비동기 연산의 Timeout을 설정할 수 있다. - -- `String serviceId` - - 다음에 설명할 prefix와 조합하여 캐시 키의 Prefix를 생성하는 데 사용된다. - - 배포 단계(test, dev, stage, prod, ...)를 구분하기 위한 문자열을 지정한다. +- `withServiceId(String serviceId)` + - 다음에 설명할 prefix와 조합하여 캐시 키의 Prefix를 생성할 때 사용되는 serviceId를 지정한다. + - 인자로 null을 입력할 수 없으며, 보통 배포 단계(test, dev, stage, prod, ...)를 구분하기 위한 문자열에 `-`를 붙여 지정한다. ex) "DEV-" - [1장의 Cache Key 설명](01-arcus-cache-basics.md#cache-key)을 참고하여 ARCUS Cache의 캐시 키로 사용할 수 없는 문자열이 포함되지 않도록 해야 한다. -- `String prefix` +- `withPrefix(String prefix)` - serviceId와 조합하여 캐시 키의 Prefix를 생성하는 데 사용된다. - 주로 ARCUS Cache에 저장할 객체의 종류(Product, User, Order, ...)를 나타내는 문자열을 지정한다. - - 필수적으로 지정하지 않아도 되며, 이 경우 캐시 키의 Prefix를 생성할 때 serviceId와 현재 캐시 설정으로 생성하는 ArcusCache 객체의 캐시 이름이 사용된다. - - null이 아닌 값을 지정하는 경우, [1장의 Cache Key 설명](01-arcus-cache-basics.md#cache-key)을 참고하여 ARCUS Cache의 캐시 키로 사용할 수 없는 문자열이 포함되지 않도록 해야 한다. -- `int expireSeconds` + - 이 메서드로 prefix를 지정하지 않을 경우 캐시 키의 Prefix를 생성할 때 serviceId와 현재 캐시 설정 객체를 담은 ArcusCache 객체의 캐시 이름이 사용된다. + - 인자로 null을 입력할 수 없으며, [1장의 Cache Key 설명](01-arcus-cache-basics.md#cache-key)을 참고하여 ARCUS Cache의 캐시 키로 사용할 수 없는 문자열이 포함되지 않도록 해야 한다. +- `withExpireSeconds(int expireSeconds)` - 캐시 아이템의 Expire Time을 Seconds 단위로 지정한다. - - 지정하지 않을 경우 0으로 설정된다. + - 이 메서드로 expireSeconds를 지정하지 않을 경우 0으로 설정된다. + - 인자로 양수, 0, -1을 제외한 값은 넣을 수 없다. - [1장의 Expiration Time 설명](01-arcus-cache-basics.md#expiration-eviction)을 참고하여 지정해야 한다. -- `long timeoutMilliSeconds` +- `withTimeoutMilliSeconds(long timeoutMilliSeconds)` - ARCUS Client의 비동기 연산에서 사용할 Timeout을 Milliseconds 단위로 설정한다. - - 지정하지 않을 경우 700ms로 정해진다. - - 값을 지정하는 경우 0보다 큰 값을 지정해야 한다. + - 이 메서드로 timeoutMilliSeconds를 지정하지 않을 경우 700ms로 설정된다. + - 인자로 0보다 큰 값만 넣을 수 있다. +- `withOperationTranscoder(Transcoder operationTranscoder)` + - ARCUS Client의 연산 결과를 Serialize, Deserialize하는 데 사용되는 Transcoder 객체를 지정한다. + - 이 메서드로 operationTranscoder를 지정하지 않을 경우 Arcus Client의 기본 Transcoder가 사용된다. + - 인자로 null을 입력할 수 없다. +- `enableGettingException()` / `disableGettingException()` + - ARCUS Client의 연산에서 발생하는 예외를 받을지 여부를 설정한다. + - 기본적으로 disable 상태이며 예외가 발생하면 원본 메서드를 수행하도록 한다. + - enable시킬 경우 예외가 발생하면 그대로 반환하므로 직접 상황에 맞게 예외를 처리해주어야 한다. +- `enableCachingNullValues()` / `disableCachingNullValues()` + - 캐시 아이템의 값으로 null을 허용할지 여부를 설정한다. + - 기본적으로 enable 상태이며 null 값을 NullValue 객체로 변환하여 캐시에 저장한다. + - disable 시킬 경우 null 값을 저장하려 하면 예외가 발생한다. ### KeyGenerator @@ -122,17 +134,17 @@ ARCUS Cache의 캐시 키는 공백(` `) 문자를 허용하지 않고 초기에 로컬 캐시를 활용하는 Front Cache 기능을 사용할 경우, 로컬 캐시 특성 상 데이터의 비일관성이 생길 수 있으므로 주의해야 한다. -Front Cache 기능을 사용하려면 ArcusCacheConfiguration 객체에서 다음의 설정을 지정하면 된다. +Front Cache 기능을 사용하려면 ArcusCacheConfiguration 객체에서 다음의 메서드들을 사용해 설정해야 한다. -- `ArcusFrontCache arcusFrontCache` +- `withArcusFrontCache(ArcusFrontCache arcusFrontCache)` - ArcusFrontCache 구현체를 설정한다. - 기본 제공되는 DefaultArcusFrontCache를 사용할 수 있다. - - null 값을 설정하면 Front Cache 기능이 비활성화된다. -- `int frontExpireSeconds` + - 기본적으로 비활성화 되어있는 상태이며, 인자로 null 값은 입력할 수 없다. +- `withFrontExpireSeconds(int frontExpireSeconds)` - Front Cache의 TTL(TimeToLive)을 설정한다. -- `int forceFrontCaching` - - true: ARCUS Cache 저장이 실패해도 Front Cache에 저장한다. ARCUS Cache와 로컬 캐시 간의 데이터 비일관성을 유발할 수 있으므로, 자주 변경되지 않는 데이터를 캐싱할 때 적합하다. - - false: ARCUS Cache 저장이 실패하면 Front Cache에도 저장하지 않는다. +- `enableForcingFrontCache()`, `disableForcingFrontCache()` + - ARCUS 요청의 성공, 실패에 상관 없이 Front Cache를 수행하는지에 대한 여부를 설정한다. + - 기본적으로 disable 상태이다. Front Cache를 설정해도, 항상 Front Cache에 저장하지는 않는다. `forceFrontCaching` 여부에 따라 다음과 같이 Front Cache에 저장한다. diff --git a/docs/03-arcus-spring-usage.md b/docs/03-arcus-spring-usage.md index cf6b915..72a1e5b 100644 --- a/docs/03-arcus-spring-usage.md +++ b/docs/03-arcus-spring-usage.md @@ -139,22 +139,20 @@ public class ArcusConfiguration extends CachingConfigurerSupport { @Bean public ArcusCacheConfiguration testCacheConfig() { - ArcusCacheConfiguration cacheConfig = new ArcusCacheConfiguration(); - cacheConfig.setServiceId("TEST-"); - cacheConfig.setPrefix("PRODUCT"); - cacheConfig.setExpireSeconds(60); - cacheConfig.setTimeoutMilliSeconds(800); - return cacheConfig; + return new ArcusCacheConfiguration() + .withServiceId("TEST-") + .withPrefix("PRODUCT") + .withExpireSeconds(60) + .withTimeoutMilliSeconds(800); } @Bean public ArcusCacheConfiguration devCacheConfig() { - ArcusCacheConfiguration cacheConfig = new ArcusCacheConfiguration(); - cacheConfig.setServiceId("DEV-"); - cacheConfig.setPrefix("PRODUCT"); - cacheConfig.setExpireSeconds(120); - cacheConfig.setTimeoutMilliSeconds(800); - return cacheConfig; + return new ArcusCacheConfiguration() + .withServiceId("DEV-") + .withPrefix("PRODUCT") + .withExpireSeconds(120) + .withTimeoutMilliSeconds(800); } } ``` @@ -237,32 +235,30 @@ Front Cache 기능에 대한 설명은 [2장](02-arcus-spring-concept.md#front-c ```java @Bean public ArcusCacheConfiguration testCacheConfig() { - ArcusCacheConfiguration cacheConfig = new ArcusCacheConfiguration(); - cacheConfig.setServiceId("TEST-"); - cacheConfig.setPrefix("PRODUCT"); - cacheConfig.setExpireSeconds(60); - cacheConfig.setTimeoutMilliSeconds(800); - /* front cache configuration */ - cacheConfig.setArcusFrontCache(testArcusFrontCache()); - cacheConfig.setFrontExpireSeconds(120); - cacheConfig.setForceFrontCaching(false); - /* front cache configuration */ - return cacheConfig; + return new ArcusCacheConfiguration() + .withServiceId("TEST-") + .withPrefix("PRODUCT") + .withExpireSeconds(60) + .withTimeoutMilliSeconds(800) + /* front cache configuration */ + .withArcusFrontCache(testArcusFrontCache()) + .withFrontExpireSeconds(120) + .enableForcingFrontCache(); + /* front cache configuration */ } @Bean public ArcusCacheConfiguration devCacheConfig() { - ArcusCacheConfiguration cacheConfig = new ArcusCacheConfiguration(); - cacheConfig.setServiceId("DEV-"); - cacheConfig.setPrefix("PRODUCT"); - cacheConfig.setExpireSeconds(120); - cacheConfig.setTimeoutMilliSeconds(800); - /* front cache configuration */ - cacheConfig.setArcusFrontCache(devArcusFrontCache()); - cacheConfig.setFrontExpireSeconds(240); - cacheConfig.setForceFrontCaching(true); - /* front cache configuration */ - return cacheConfig; + return new ArcusCacheConfiguration() + .withServiceId("DEV-") + .withPrefix("PRODUCT") + .withExpireSeconds(120) + .withTimeoutMilliSeconds(800) + /* front cache configuration */ + .withArcusFrontCache(devArcusFrontCache()) + .withFrontExpireSeconds(240) + .enableForcingFrontCache(); + /* front cache configuration */ } @Bean diff --git a/src/main/java/com/navercorp/arcus/spring/cache/ArcusCache.java b/src/main/java/com/navercorp/arcus/spring/cache/ArcusCache.java index e1ab61b..ee7803f 100644 --- a/src/main/java/com/navercorp/arcus/spring/cache/ArcusCache.java +++ b/src/main/java/com/navercorp/arcus/spring/cache/ArcusCache.java @@ -79,11 +79,6 @@ @SuppressWarnings({"DeprecatedIsStillUsed", "deprecation"}) public class ArcusCache extends AbstractValueAdaptingCache { - public static final long DEFAULT_TIMEOUT_MILLISECONDS = 700L; - @Deprecated - public static final boolean DEFAULT_WANT_TO_GET_EXCEPTION = false; - public static final boolean DEFAULT_ALLOW_NULL_VALUES = true; - private final Logger logger = LoggerFactory.getLogger(this.getClass()); private String name; @@ -97,7 +92,7 @@ public class ArcusCache extends AbstractValueAdaptingCache { */ @Deprecated public ArcusCache() { - super(DEFAULT_ALLOW_NULL_VALUES); + super(ArcusCacheConfiguration.DEFAULT_ALLOW_NULL_VALUES); this.configuration = new ArcusCacheConfiguration(); } diff --git a/src/main/java/com/navercorp/arcus/spring/cache/ArcusCacheConfiguration.java b/src/main/java/com/navercorp/arcus/spring/cache/ArcusCacheConfiguration.java index 3b4ed2b..2f5c7e4 100644 --- a/src/main/java/com/navercorp/arcus/spring/cache/ArcusCacheConfiguration.java +++ b/src/main/java/com/navercorp/arcus/spring/cache/ArcusCacheConfiguration.java @@ -23,28 +23,113 @@ import net.spy.memcached.transcoders.Transcoder; -import org.springframework.beans.factory.InitializingBean; import org.springframework.util.Assert; @SuppressWarnings("DeprecatedIsStillUsed") -public class ArcusCacheConfiguration implements InitializingBean { +public class ArcusCacheConfiguration { + + static final long DEFAULT_TIMEOUT_MILLISECONDS = 700L; + @Deprecated + static final boolean DEFAULT_WANT_TO_GET_EXCEPTION = false; + static final boolean DEFAULT_ALLOW_NULL_VALUES = true; private String serviceId = ""; + @Nullable private String prefix; private int expireSeconds; - private int frontExpireSeconds; - private long timeoutMilliSeconds = ArcusCache.DEFAULT_TIMEOUT_MILLISECONDS; + private long timeoutMilliSeconds = DEFAULT_TIMEOUT_MILLISECONDS; + @Nullable private Transcoder operationTranscoder; + @Nullable private ArcusFrontCache arcusFrontCache; - @Deprecated - private boolean wantToGetException = ArcusCache.DEFAULT_WANT_TO_GET_EXCEPTION; + private int frontExpireSeconds = 5; private boolean forceFrontCaching; - private boolean allowNullValues = ArcusCache.DEFAULT_ALLOW_NULL_VALUES; + @Deprecated + private boolean wantToGetException = DEFAULT_WANT_TO_GET_EXCEPTION; + private boolean allowNullValues = DEFAULT_ALLOW_NULL_VALUES; + + public ArcusCacheConfiguration() { + } + + public ArcusCacheConfiguration withServiceId(String serviceId) { + Assert.notNull(serviceId, "ServiceId must not be null."); + this.serviceId = serviceId; + return this; + } + + public ArcusCacheConfiguration withPrefix(String prefix) { + Assert.notNull(prefix, "Prefix must not be null."); + this.prefix = prefix; + return this; + } + + public ArcusCacheConfiguration withExpireSeconds(int expireSeconds) { + Assert.isTrue(expireSeconds > -2, "ExpireSeconds must be positive integer, 0, or -1."); + this.expireSeconds = expireSeconds; + return this; + } + + public ArcusCacheConfiguration withTimeoutMilliSeconds(long timeoutMilliSeconds) { + Assert.isTrue(timeoutMilliSeconds > 0, "TimeoutMilliSeconds must be larger than 0."); + this.timeoutMilliSeconds = timeoutMilliSeconds; + return this; + } + + public ArcusCacheConfiguration withOperationTranscoder(Transcoder operationTranscoder) { + Assert.notNull(operationTranscoder, "OperationTranscoder must not be null."); + this.operationTranscoder = operationTranscoder; + return this; + } + + public ArcusCacheConfiguration withArcusFrontCache(ArcusFrontCache arcusFrontCache) { + Assert.notNull(arcusFrontCache, "ArcusFrontCache must not be null."); + this.arcusFrontCache = arcusFrontCache; + return this; + } + + public ArcusCacheConfiguration withFrontExpireSeconds(int frontExpireSeconds) { + Assert.isTrue(frontExpireSeconds > -1, "FrontExpireSeconds must not be negative integer."); + this.frontExpireSeconds = frontExpireSeconds; + return this; + } + + public ArcusCacheConfiguration enableForcingFrontCache() { + this.forceFrontCaching = true; + return this; + } + + public ArcusCacheConfiguration disableForcingFrontCache() { + this.forceFrontCaching = false; + return this; + } + + @Deprecated + public ArcusCacheConfiguration enableGettingException() { + this.wantToGetException = true; + return this; + } + + @Deprecated + public ArcusCacheConfiguration disableGettingException() { + this.wantToGetException = false; + return this; + } + + public ArcusCacheConfiguration enableCachingNullValues() { + this.allowNullValues = true; + return this; + } + + public ArcusCacheConfiguration disableCachingNullValues() { + this.allowNullValues = false; + return this; + } public String getServiceId() { return serviceId; } + @Deprecated public void setServiceId(String serviceId) { this.serviceId = serviceId; } @@ -54,6 +139,7 @@ public String getPrefix() { return prefix; } + @Deprecated public void setPrefix(@Nullable String prefix) { this.prefix = prefix; } @@ -62,6 +148,7 @@ public int getExpireSeconds() { return expireSeconds; } + @Deprecated public void setExpireSeconds(int expireSeconds) { this.expireSeconds = expireSeconds; } @@ -70,6 +157,7 @@ public int getFrontExpireSeconds() { return frontExpireSeconds; } + @Deprecated public void setFrontExpireSeconds(int frontExpireSeconds) { this.frontExpireSeconds = frontExpireSeconds; } @@ -78,7 +166,9 @@ public long getTimeoutMilliSeconds() { return timeoutMilliSeconds; } + @Deprecated public void setTimeoutMilliSeconds(long timeoutMilliSeconds) { + Assert.isTrue(timeoutMilliSeconds > 0, "TimeoutMilliSeconds must be larger than 0."); this.timeoutMilliSeconds = timeoutMilliSeconds; } @@ -87,6 +177,7 @@ public Transcoder getOperationTranscoder() { return operationTranscoder; } + @Deprecated public void setOperationTranscoder(@Nullable Transcoder operationTranscoder) { this.operationTranscoder = operationTranscoder; } @@ -96,6 +187,7 @@ public ArcusFrontCache getArcusFrontCache() { return arcusFrontCache; } + @Deprecated public void setArcusFrontCache(@Nullable ArcusFrontCache arcusFrontCache) { this.arcusFrontCache = arcusFrontCache; } @@ -114,6 +206,7 @@ public boolean isForceFrontCaching() { return forceFrontCaching; } + @Deprecated public void setForceFrontCaching(boolean forceFrontCaching) { this.forceFrontCaching = forceFrontCaching; } @@ -122,13 +215,9 @@ public boolean isAllowNullValues() { return this.allowNullValues; } + @Deprecated public void setAllowNullValues(boolean allowNullValues) { this.allowNullValues = allowNullValues; } - @Override - public void afterPropertiesSet() { - Assert.isTrue(timeoutMilliSeconds > 0, "TimeoutMilliSeconds must be larger than 0."); - } - } diff --git a/src/test/java/com/navercorp/arcus/spring/cache/ArcusCacheConfigurationTest.java b/src/test/java/com/navercorp/arcus/spring/cache/ArcusCacheConfigurationTest.java new file mode 100644 index 0000000..cf61024 --- /dev/null +++ b/src/test/java/com/navercorp/arcus/spring/cache/ArcusCacheConfigurationTest.java @@ -0,0 +1,36 @@ +package com.navercorp.arcus.spring.cache; + +import net.spy.memcached.ArcusClient; +import net.spy.memcached.ArcusClientPool; + +import org.junit.jupiter.api.Test; + +import static org.junit.jupiter.api.Assertions.assertThrows; +import static org.junit.jupiter.api.Assertions.assertTrue; + +class ArcusCacheConfigurationTest { + + @Test + void createValidCacheKey() { + ArcusCacheConfiguration config = new ArcusCacheConfiguration() + .withServiceId("TEST-") + .withPrefix("test1"); + ArcusClientPool clientPool = ArcusClient.createArcusClientPool("localhost:2181", "test", 8); + ArcusCache arcusCache = new ArcusCache("cache1", clientPool, config); + + assertTrue(arcusCache.createArcusKey("key1").startsWith("TEST-test1:key1")); + } + + @Test + void failWhenSettingInvalidValueInConfigMethod() { + ArcusCacheConfiguration config = new ArcusCacheConfiguration(); + + assertThrows(IllegalArgumentException.class, () -> config.withServiceId(null)); + assertThrows(IllegalArgumentException.class, () -> config.withPrefix(null)); + assertThrows(IllegalArgumentException.class, () -> config.withExpireSeconds(-30)); + assertThrows(IllegalArgumentException.class, () -> config.withTimeoutMilliSeconds(-1)); + assertThrows(IllegalArgumentException.class, () -> config.withArcusFrontCache(null)); + assertThrows(IllegalArgumentException.class, () -> config.withOperationTranscoder(null)); + } + +} diff --git a/src/test/java/com/navercorp/arcus/spring/cache/ArcusCacheManagerBuilderTest.java b/src/test/java/com/navercorp/arcus/spring/cache/ArcusCacheManagerBuilderTest.java index 0f02045..139200e 100644 --- a/src/test/java/com/navercorp/arcus/spring/cache/ArcusCacheManagerBuilderTest.java +++ b/src/test/java/com/navercorp/arcus/spring/cache/ArcusCacheManagerBuilderTest.java @@ -22,8 +22,7 @@ class ArcusCacheManagerBuilderTest { @Test void testMissingCacheMadeByDefaultCacheConfig() { - ArcusCacheConfiguration configuration = new ArcusCacheConfiguration(); - configuration.setServiceId("TEST-"); + ArcusCacheConfiguration configuration = new ArcusCacheConfiguration().withServiceId("TEST-"); ArcusCacheManager cm = ArcusCacheManager.builder(arcusClientPool).cacheDefaults(configuration).build(); cm.afterPropertiesSet(); @@ -36,8 +35,7 @@ void testMissingCacheMadeByDefaultCacheConfig() { @Test void testSettingDifferentDefaultCacheConfiguration() { - ArcusCacheConfiguration withPrefix = new ArcusCacheConfiguration(); - withPrefix.setPrefix("prefix"); + ArcusCacheConfiguration withPrefix = new ArcusCacheConfiguration().withPrefix("prefix"); ArcusCacheConfiguration withoutPrefix = new ArcusCacheConfiguration(); ArcusCacheManager cm = ArcusCacheManager.builder(arcusClientPool)