From 77da838587dd23523cba21f2e8b77f391f54601e Mon Sep 17 00:00:00 2001 From: aclement Date: Wed, 15 Jun 2011 16:14:41 +0000 Subject: 349398 --- tests/bugs1612/pr349398/CacheAspect.java | 35 ++++++++++++++++++ tests/bugs1612/pr349398/DataGenerator.java | 14 ++++++++ .../pr349398/DataGeneratorCacheAspect.java | 13 +++++++ tests/bugs1612/pr349398/DataGeneratorTest.java | 41 ++++++++++++++++++++++ 4 files changed, 103 insertions(+) create mode 100644 tests/bugs1612/pr349398/CacheAspect.java create mode 100644 tests/bugs1612/pr349398/DataGenerator.java create mode 100644 tests/bugs1612/pr349398/DataGeneratorCacheAspect.java create mode 100644 tests/bugs1612/pr349398/DataGeneratorTest.java (limited to 'tests/bugs1612') diff --git a/tests/bugs1612/pr349398/CacheAspect.java b/tests/bugs1612/pr349398/CacheAspect.java new file mode 100644 index 000000000..3240327b6 --- /dev/null +++ b/tests/bugs1612/pr349398/CacheAspect.java @@ -0,0 +1,35 @@ +//package info.unterstein.hagen.moderne.ea6.a3; + +import java.util.HashMap; + +/** + * Enables a more complex and generic caching aspect which can be extended to +be + * used in several use cases. + * + * @author Johannes Unterstein + * @param + * the class of the keys + * @param + * the class of the cached values + */ +public abstract aspect CacheAspect { + private HashMap cache; + + public abstract pointcut cachePoint(Object key); + + V around(Object key) : cachePoint(key) { + if (this.cache == null) { + this.cache = new HashMap(); + } + V result; + if (this.cache.containsKey(key)) { + result = this.cache.get(key); + } else { + result = proceed(key); + this.cache.put(key, result); + } +Object o = this.cache; + return result; + } +} diff --git a/tests/bugs1612/pr349398/DataGenerator.java b/tests/bugs1612/pr349398/DataGenerator.java new file mode 100644 index 000000000..65619545a --- /dev/null +++ b/tests/bugs1612/pr349398/DataGenerator.java @@ -0,0 +1,14 @@ +//package info.unterstein.hagen.moderne.ea6.a3; + +public class DataGenerator { + + private static final int MAGIC_NUMBER = 23; + + public Integer getData(Integer i) { + try { + Thread.sleep(100); + } catch (InterruptedException ex) { + } + return new Integer(i * MAGIC_NUMBER); + } +} diff --git a/tests/bugs1612/pr349398/DataGeneratorCacheAspect.java b/tests/bugs1612/pr349398/DataGeneratorCacheAspect.java new file mode 100644 index 000000000..53c941bf3 --- /dev/null +++ b/tests/bugs1612/pr349398/DataGeneratorCacheAspect.java @@ -0,0 +1,13 @@ +//package info.unterstein.hagen.moderne.ea6.a3; + +/** + * An extension of the generic cache for the concrete use case of caching the + * {@link DataGenerator}. + * + * @author Johannes Unterstein + */ +public aspect DataGeneratorCacheAspect extends CacheAspect { + + public pointcut cachePoint(Object key) : call(Integer +DataGenerator.getData(Integer)) && args(key); +} diff --git a/tests/bugs1612/pr349398/DataGeneratorTest.java b/tests/bugs1612/pr349398/DataGeneratorTest.java new file mode 100644 index 000000000..9a2c0ec0a --- /dev/null +++ b/tests/bugs1612/pr349398/DataGeneratorTest.java @@ -0,0 +1,41 @@ +//package info.unterstein.hagen.moderne.ea6.a3; + +public class DataGeneratorTest { + public static void main(String []argv) { + new DataGeneratorTest().testGetData(); + new DataGeneratorTest().testGetDataSpeedUp(); + } + + public void testGetData() { + DataGenerator generator = new DataGenerator(); + assertEquals(new Integer(0), generator.getData(0)); + assertEquals(new Integer(23), generator.getData(1)); + assertEquals(new Integer(2 * 23), generator.getData(2)); + } + + public void assertEquals(Object o, Object p) { + if (!o.equals(p)) { + throw new IllegalStateException(); + } + } + + public void assertTrue(boolean b) { + if (!b) { + throw new IllegalStateException(); + } + } + + public void testGetDataSpeedUp() { + DataGenerator generator = new DataGenerator(); + long before = System.currentTimeMillis(); + for (int i = 0; i < 5; i++) { + generator.getData(i); + } + for (int i = 0; i < 5; i++) { + generator.getData(0); + } + long after = System.currentTimeMillis(); + assertTrue((after - before) < 600); + } +} + -- cgit v1.2.3