summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/multiIncremental/PR192877/base/src/DefaultTestImpl.java10
-rw-r--r--tests/multiIncremental/PR192877/base/src/Foo.java4
-rw-r--r--tests/multiIncremental/PR192877/base/src/FooImpl.java5
-rw-r--r--tests/multiIncremental/PR192877/base/src/Test.java5
-rw-r--r--tests/multiIncremental/PR192877/base/src/TestAspect.java20
-rw-r--r--tests/multiIncremental/PR192877/inc1/src/Test.java5
-rw-r--r--tests/src/org/aspectj/systemtest/incremental/tools/MultiProjectIncrementalTests.java83
7 files changed, 124 insertions, 8 deletions
diff --git a/tests/multiIncremental/PR192877/base/src/DefaultTestImpl.java b/tests/multiIncremental/PR192877/base/src/DefaultTestImpl.java
new file mode 100644
index 000000000..1a2954354
--- /dev/null
+++ b/tests/multiIncremental/PR192877/base/src/DefaultTestImpl.java
@@ -0,0 +1,10 @@
+
+public class DefaultTestImpl implements Test {
+ public void methodA() {
+ System.out.println("methodA");
+ }
+
+ public void methodB() {
+ System.out.println("methodB");
+ }
+}
diff --git a/tests/multiIncremental/PR192877/base/src/Foo.java b/tests/multiIncremental/PR192877/base/src/Foo.java
new file mode 100644
index 000000000..9eac48b58
--- /dev/null
+++ b/tests/multiIncremental/PR192877/base/src/Foo.java
@@ -0,0 +1,4 @@
+
+public interface Foo {
+ void doSomething();
+}
diff --git a/tests/multiIncremental/PR192877/base/src/FooImpl.java b/tests/multiIncremental/PR192877/base/src/FooImpl.java
new file mode 100644
index 000000000..85c45fa74
--- /dev/null
+++ b/tests/multiIncremental/PR192877/base/src/FooImpl.java
@@ -0,0 +1,5 @@
+public class FooImpl implements Foo {
+ public void doSomething() {
+ System.out.println("doSomething");
+ }
+}
diff --git a/tests/multiIncremental/PR192877/base/src/Test.java b/tests/multiIncremental/PR192877/base/src/Test.java
new file mode 100644
index 000000000..7d6914e2c
--- /dev/null
+++ b/tests/multiIncremental/PR192877/base/src/Test.java
@@ -0,0 +1,5 @@
+public interface Test {
+ void methodA();
+
+ void methodB();
+}
diff --git a/tests/multiIncremental/PR192877/base/src/TestAspect.java b/tests/multiIncremental/PR192877/base/src/TestAspect.java
new file mode 100644
index 000000000..50d1d1dc9
--- /dev/null
+++ b/tests/multiIncremental/PR192877/base/src/TestAspect.java
@@ -0,0 +1,20 @@
+import org.aspectj.lang.annotation.Aspect;
+import org.aspectj.lang.annotation.Before;
+import org.aspectj.lang.annotation.DeclareParents;
+
+@Aspect
+public class TestAspect {
+ @DeclareParents(value="Foo+",defaultImpl=DefaultTestImpl.class)
+ public Test implementedInterface;
+
+ @Before("execution(* Foo.doSomething()) && this(t)")
+ public void verifyRunningSender(Test t) {
+ t.methodA();
+ t.methodB();
+ }
+
+ public static void main(String[] args) {
+ Foo foo = new FooImpl();
+ foo.doSomething();
+ }
+} \ No newline at end of file
diff --git a/tests/multiIncremental/PR192877/inc1/src/Test.java b/tests/multiIncremental/PR192877/inc1/src/Test.java
new file mode 100644
index 000000000..7d6914e2c
--- /dev/null
+++ b/tests/multiIncremental/PR192877/inc1/src/Test.java
@@ -0,0 +1,5 @@
+public interface Test {
+ void methodA();
+
+ void methodB();
+}
diff --git a/tests/src/org/aspectj/systemtest/incremental/tools/MultiProjectIncrementalTests.java b/tests/src/org/aspectj/systemtest/incremental/tools/MultiProjectIncrementalTests.java
index 69edd6bdf..1c6e8fc03 100644
--- a/tests/src/org/aspectj/systemtest/incremental/tools/MultiProjectIncrementalTests.java
+++ b/tests/src/org/aspectj/systemtest/incremental/tools/MultiProjectIncrementalTests.java
@@ -171,6 +171,69 @@ public class MultiProjectIncrementalTests extends AbstractMultiProjectIncrementa
// incomplete
}
+ public void testBeanExample() throws Exception {
+ String p = "BeanExample";
+ initialiseProject(p);
+ build(p);
+ dumptree(AsmManager.getDefault().getHierarchy().getRoot(), 0);
+ PrintWriter pw = new PrintWriter(System.out);
+ AsmManager.getDefault().dumprels(pw);
+ pw.flush();
+ // incomplete
+ }
+
+ private void checkIfContainsFile(Set s, String filename, boolean shouldBeFound) {
+ StringBuffer sb = new StringBuffer("Set of files\n");
+ for (Iterator iterator = s.iterator(); iterator.hasNext();) {
+ Object object = iterator.next();
+ sb.append(object).append("\n");
+ }
+ for (Iterator iterator = s.iterator(); iterator.hasNext();) {
+ File fname = (File) iterator.next();
+ if (fname.getName().endsWith(filename)) {
+ if (!shouldBeFound) {
+ System.out.println(sb.toString());
+ fail("Unexpectedly found file " + filename);
+ } else {
+ return;
+ }
+ }
+ }
+ if (shouldBeFound) {
+ System.out.println(sb.toString());
+ fail("Did not find filename " + filename);
+ }
+ }
+
+ /**
+ * Checking return values of the AsmManager API calls that can be invoked post incremental build that tell the caller which
+ * files had their relationships altered. As well as the affected (woven) files, it is possible to query the aspects that wove
+ * those files.
+ */
+ public void testChangesOnBuild() throws Exception {
+ String p = "ChangesOnBuild";
+ initialiseProject(p);
+ build(p);
+ // Not incremental
+ checkIfContainsFile(AsmManager.getDefault().getModelChangesOnLastBuild(), "A.java", false);
+ alter(p, "inc1");
+ build(p);
+ // Incremental
+ checkIfContainsFile(AsmManager.getDefault().getModelChangesOnLastBuild(), "A.java", true);
+ checkIfContainsFile(AsmManager.getDefault().getAspectsWeavingFilesOnLastBuild(), "X.java", true);
+ checkIfContainsFile(AsmManager.getDefault().getAspectsWeavingFilesOnLastBuild(), "Y.java", false);
+ }
+
+ public void testITDIncremental_pr192877() {
+ String p = "PR192877";
+ initialiseProject(p);
+ build(p);
+ checkWasFullBuild();
+ alter(p, "inc1");
+ build(p);
+ checkWasntFullBuild();
+ }
+
public void testAdviceHandlesAreJDTCompatible() {
String p = "AdviceHandles";
initialiseProject(p);
@@ -363,10 +426,10 @@ public class MultiProjectIncrementalTests extends AbstractMultiProjectIncrementa
configureAspectPath(bug2, getProjectRelativePath(bug, "bin"));
build(bug);
build(bug2);
-// dumptree(AsmManager.getDefault().getHierarchy().getRoot(), 0);
-// PrintWriter pw = new PrintWriter(System.out);
-// AsmManager.getDefault().dumprels(pw);
-// pw.flush();
+ // dumptree(AsmManager.getDefault().getHierarchy().getRoot(), 0);
+ // PrintWriter pw = new PrintWriter(System.out);
+ // AsmManager.getDefault().dumprels(pw);
+ // pw.flush();
IProgramElement root = AsmManager.getDefault().getHierarchy().getRoot();
assertEquals("=AspectPathTwo/binaries<pkg(Asp.class}Asp&before", findElementAtLine(root, 5).getHandleIdentifier());
assertEquals("=AspectPathTwo/binaries<(Asp2.class}Asp2&before", findElementAtLine(root, 16).getHandleIdentifier());
@@ -516,10 +579,14 @@ public class MultiProjectIncrementalTests extends AbstractMultiProjectIncrementa
// assertNoErrors();
// }
- /*
- * public void testRefactoring_pr148285() { configureBuildStructureModel(true); initialiseProject("PR148285");
- * build("PR148285"); System.err.println("xxx"); alter("PR148285","inc1"); build("PR148285"); }
- */
+ public void testRefactoring_pr148285() {
+ // configureBuildStructureModel(true);
+
+ initialiseProject("PR148285");
+ build("PR148285");
+ alter("PR148285", "inc1");
+ build("PR148285");
+ }
/**
* In order for this next test to run, I had to move the weaver/world pair we keep in the AjBuildManager instance down into the