diff options
author | avasseur <avasseur> | 2005-12-12 10:48:46 +0000 |
---|---|---|
committer | avasseur <avasseur> | 2005-12-12 10:48:46 +0000 |
commit | 979124d0fe6ac23df1dd5ee41838056bbaed6789 (patch) | |
tree | 6cd8cc92593f67ff29794a49bc35f68d9f25ffec /tests | |
parent | 0c8c0a3d21365eade6f53a0484bba71f24637a65 (diff) | |
download | aspectj-979124d0fe6ac23df1dd5ee41838056bbaed6789.tar.gz aspectj-979124d0fe6ac23df1dd5ee41838056bbaed6789.zip |
#120351 cflowbelow @AJ and binding
Diffstat (limited to 'tests')
4 files changed, 125 insertions, 0 deletions
diff --git a/tests/java5/ataspectj/ataspectj/bugs/CflowBelowStackTest.java b/tests/java5/ataspectj/ataspectj/bugs/CflowBelowStackTest.java new file mode 100644 index 000000000..36810f7cd --- /dev/null +++ b/tests/java5/ataspectj/ataspectj/bugs/CflowBelowStackTest.java @@ -0,0 +1,105 @@ +/******************************************************************************* + * Copyright (c) 2005 Contributors. + * All rights reserved. + * This program and the accompanying materials are made available + * under the terms of the Eclipse Public License v1.0 + * which accompanies this distribution and is available at + * http://eclipse.org/legal/epl-v10.html + * + * Contributors: + * Alexandre Vasseur initial implementation + *******************************************************************************/ +package ataspectj.bugs; + +import ataspectj.TestHelper; +import junit.framework.Test; +import junit.framework.TestCase; +import junit.framework.TestSuite; +import org.aspectj.lang.JoinPoint; +import org.aspectj.lang.annotation.After; +import org.aspectj.lang.annotation.Aspect; +import org.aspectj.lang.annotation.Before; +import org.aspectj.lang.annotation.Pointcut; + +import java.io.File; +import java.io.FileInputStream; +import java.io.FileOutputStream; +import java.io.ObjectInputStream; +import java.io.ObjectOutputStream; +import java.util.HashMap; +import java.util.Map; + +/** + * @author <a href="mailto:alex AT gnilux DOT com">Alexandre Vasseur</a> + */ +public class CflowBelowStackTest extends TestCase { + + public void testMe() { + assertTrue(true); + } + + public static void main(String[] args) { + TestHelper.runAndThrowOnFailure(suite()); + } + + public static Test suite() { + return new TestSuite(CflowBelowStackTest.class); + } + + + @Aspect + public static class TestAspect { + + @Pointcut("this(testCase) && execution(void test*())") + public void inTestClass(TestCase testCase) { + } + + private Map<String, Map<String, Integer>> coverage; + + @Before("cflowbelow(inTestClass(testCase)) && execution(* *(..))") + public void beforeMethodExecution(JoinPoint thisJoinPoint, TestCase testCase) { + String testname = testCase.getClass().getName(); + String methodSignature = thisJoinPoint.getStaticPart().getSignature().toString(); + Map<String, Integer> tests = coverage.get(methodSignature); + if (tests == null) { + tests = new HashMap<String, Integer>(); + coverage.put(methodSignature, tests); + } + Integer count = tests.get(testname); + if (count == null) { + count = 1; + } else { + count++; + } + tests.put(testname, count); + } + + @Before("inTestClass(testCase)") + public void beforeExecutingTestMethod(TestCase testCase) { + try { + File file = new File("results.ser"); + if (file.exists()) { + ObjectInputStream ois = new ObjectInputStream(new FileInputStream(file)); + coverage = (Map<String, Map<String, Integer>>) ois.readObject(); + ois.close(); + } else { + coverage = new HashMap<String, Map<String, Integer>>(); + } + } catch (Exception e) { + e.printStackTrace(); + } + } + + @After("inTestClass(testCase)") + public void afterExecutingTestMethod(TestCase testCase) { + try { + File file = new File("results.ser"); + ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(file)); + oos.writeObject(coverage); + oos.close(); + } catch (Exception e) { + e.printStackTrace(); + } + } + } +} diff --git a/tests/java5/ataspectj/ataspectj/bugs/aop-cflowbelowstacktest.xml b/tests/java5/ataspectj/ataspectj/bugs/aop-cflowbelowstacktest.xml new file mode 100644 index 000000000..076124118 --- /dev/null +++ b/tests/java5/ataspectj/ataspectj/bugs/aop-cflowbelowstacktest.xml @@ -0,0 +1,7 @@ +<aspectj> + <weaver options="-1.5 -showWeaveInfo"> + </weaver> + <aspects> + <aspect name="ataspectj.bugs.CflowBelowStackTest.TestAspect"/> + </aspects> +</aspectj>
\ No newline at end of file diff --git a/tests/src/org/aspectj/systemtest/ajc150/ataspectj/AtAjLTWTests.java b/tests/src/org/aspectj/systemtest/ajc150/ataspectj/AtAjLTWTests.java index 2d27cb8e1..7c2e52978 100644 --- a/tests/src/org/aspectj/systemtest/ajc150/ataspectj/AtAjLTWTests.java +++ b/tests/src/org/aspectj/systemtest/ajc150/ataspectj/AtAjLTWTests.java @@ -200,6 +200,10 @@ public class AtAjLTWTests extends XMLBasedAjcTestCase { runTest("AppContainer"); } + public void testCflowBelowStack() { + runTest("CflowBelowStack"); + } + private static class CountingFilenameFilter implements FilenameFilter { private int count; diff --git a/tests/src/org/aspectj/systemtest/ajc150/ataspectj/ltw.xml b/tests/src/org/aspectj/systemtest/ajc150/ataspectj/ltw.xml index f4ac1a7bb..6b7f35987 100644 --- a/tests/src/org/aspectj/systemtest/ajc150/ataspectj/ltw.xml +++ b/tests/src/org/aspectj/systemtest/ajc150/ataspectj/ltw.xml @@ -277,4 +277,13 @@ /> <ant file="ajc-ant.xml" target="ltw.AppContainer" verbose="true"/> </ajc-test> + + <ajc-test dir="java5/ataspectj" title="CflowBelowStack"> + <compile + files="ataspectj/bugs/CflowBelowStackTest.java,ataspectj/TestHelper.java" + options="-1.5 -verbose "/> + <run class="ataspectj.bugs.CflowBelowStackTest" ltw="ataspectj/bugs/aop-cflowbelowstacktest.xml"/> + </ajc-test> + + </suite>
\ No newline at end of file |