Browse Source
Fix CacheAspectSupport to consider a cache hit from any of the multiple @Cachables that may have been specified using the @Caching annotation. Prior to this commit the following scenario would never produce a hit: @Caching(cacheable = { @Cacheable(value = "c1", unless = "#result.size() < 4"), @Cacheable(value = "c2", unless = "#result.size() > 3") }) Issue: SPR-11124pull/422/head
2 changed files with 115 additions and 1 deletions
@ -0,0 +1,104 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2002-2013 the original author or authors. |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
|
||||||
|
package org.springframework.cache; |
||||||
|
|
||||||
|
import java.util.Collections; |
||||||
|
import java.util.List; |
||||||
|
|
||||||
|
import org.junit.Test; |
||||||
|
import org.springframework.cache.annotation.Cacheable; |
||||||
|
import org.springframework.cache.annotation.Caching; |
||||||
|
import org.springframework.cache.annotation.EnableCaching; |
||||||
|
import org.springframework.cache.concurrent.ConcurrentMapCacheManager; |
||||||
|
import org.springframework.context.annotation.AnnotationConfigApplicationContext; |
||||||
|
import org.springframework.context.annotation.Bean; |
||||||
|
import org.springframework.context.annotation.Configuration; |
||||||
|
|
||||||
|
import static org.junit.Assert.*; |
||||||
|
|
||||||
|
/** |
||||||
|
* Tests to reproduce raised caching issues. |
||||||
|
* |
||||||
|
* @author Phillip Webb |
||||||
|
*/ |
||||||
|
public class CacheReproTests { |
||||||
|
|
||||||
|
@Test |
||||||
|
public void spr11124() throws Exception { |
||||||
|
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext( |
||||||
|
Spr11124Config.class); |
||||||
|
Spr11124Service bean = context.getBean(Spr11124Service.class); |
||||||
|
bean.single(2); |
||||||
|
bean.single(2); |
||||||
|
bean.multiple(2); |
||||||
|
bean.multiple(2); |
||||||
|
context.close(); |
||||||
|
} |
||||||
|
|
||||||
|
@Configuration |
||||||
|
@EnableCaching |
||||||
|
public static class Spr11124Config { |
||||||
|
|
||||||
|
@Bean |
||||||
|
public CacheManager cacheManager() { |
||||||
|
return new ConcurrentMapCacheManager(); |
||||||
|
} |
||||||
|
|
||||||
|
@Bean |
||||||
|
public Spr11124Service service() { |
||||||
|
return new Spr11124ServiceImpl(); |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
public interface Spr11124Service { |
||||||
|
|
||||||
|
public List<String> single(int id); |
||||||
|
|
||||||
|
public List<String> multiple(int id); |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
public static class Spr11124ServiceImpl implements Spr11124Service { |
||||||
|
|
||||||
|
private int multipleCount = 0; |
||||||
|
|
||||||
|
@Override |
||||||
|
@Cacheable(value = "smallCache") |
||||||
|
public List<String> single(int id) { |
||||||
|
if (this.multipleCount > 0) { |
||||||
|
fail("Called too many times"); |
||||||
|
} |
||||||
|
this.multipleCount++; |
||||||
|
return Collections.emptyList(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
@Caching(cacheable = { |
||||||
|
@Cacheable(value = "bigCache", unless = "#result.size() < 4"), |
||||||
|
@Cacheable(value = "smallCache", unless = "#result.size() > 3") }) |
||||||
|
public List<String> multiple(int id) { |
||||||
|
if (this.multipleCount > 0) { |
||||||
|
fail("Called too many times"); |
||||||
|
} |
||||||
|
this.multipleCount++; |
||||||
|
return Collections.emptyList(); |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
Loading…
Reference in new issue