summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authoracolyer <acolyer>2005-09-27 15:00:24 +0000
committeracolyer <acolyer>2005-09-27 15:00:24 +0000
commite76b37012601cf67a069b4a78f60f183efad563d (patch)
tree3148225993d764b6389b0d360e618e73ad0e0042 /tests
parentc6567597adac0d457cdab8df3c24f9044f21e0e8 (diff)
downloadaspectj-e76b37012601cf67a069b4a78f60f183efad563d.tar.gz
aspectj-e76b37012601cf67a069b4a78f60f183efad563d.zip
tests and fix for pr88900, unneccessary warning
Diffstat (limited to 'tests')
-rw-r--r--tests/bugs150/pr104229.aj132
-rw-r--r--tests/bugs150/pr88900.aj5
-rw-r--r--tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java8
-rw-r--r--tests/src/org/aspectj/systemtest/ajc150/ajc150.xml19
4 files changed, 164 insertions, 0 deletions
diff --git a/tests/bugs150/pr104229.aj b/tests/bugs150/pr104229.aj
new file mode 100644
index 000000000..d3feb328b
--- /dev/null
+++ b/tests/bugs150/pr104229.aj
@@ -0,0 +1,132 @@
+import java.lang.annotation.*;
+import javax.swing.*;
+import javax.swing.event.*;
+import java.awt.*;
+
+interface GoalSelectedNotice {
+ public void goalSelected(Object goal);
+}
+
+@Retention(RetentionPolicy.RUNTIME)
+@interface DefaultImplementation {}
+
+aspect X {
+ /**
+ * Watch for goalSelected(..) method being called when
+ * not within this aspect.
+ */
+ pointcut goalSelectedPointcut(GoalSelectedNotice _this, Object goal):
+ call(void GoalSelectedNotice.goalSelected(Object))
+ && target(_this) && args(goal) && !cflow(adviceexecution());
+
+ declare warning : call(void GoalSelectedNotice.goalSelected(Object)) : "bingo";
+
+ after(Object caller, Object o) returning : call(void GoalSelectedNotice.goalSelected(Object)) && args(o) && target(caller){
+ System.out.println("call match " + caller.getClass());
+ }
+
+ after(GoalSelectedNotice _this, Object goal) returning:
+ goalSelectedPointcut(_this, goal){
+ System.out.println("OK it worked!");
+ }
+ /**
+ * Empty body, can be overriden by classes implementing
+ * {@link GoalSelectedNotice}.
+ */
+ @DefaultImplementation
+ public void GoalSelectedNotice.goalSelected(Object goal){
+ }
+}
+
+public class pr104229 implements GoalSelectedNotice {
+
+ interface CallMe { void doIt(); }
+
+ public static void main(String[] args) {
+ pr104229 pr = new pr104229();
+ pr.callInner();
+ }
+
+ public void callInner() {
+
+ CallMe callMe = new CallMe() {
+ public void doIt() {
+ pr104229.this.goalSelected("MyGoal");
+ }
+ };
+
+ callMe.doIt();
+
+ }
+
+
+}
+
+class ListPanel extends JPanel implements GoalSelectedNotice{
+
+ private JComboBox jComboBox = null;
+ private JList jList = null;
+ /**
+ * This is the default constructor
+ */
+ public ListPanel() {
+ super();
+ initialize();
+ }
+ /**
+ * This method initializes this
+ *
+ * @return void
+ */
+ private void initialize() {
+ this.setLayout(new BorderLayout());
+ this.setSize(300,200);
+ this.add(getJComboBox(), java.awt.BorderLayout.NORTH);
+ this.add(getJList(), java.awt.BorderLayout.CENTER);
+ }
+ /**
+ * This method initializes jComboBox
+ *
+ * @return javax.swing.JComboBox
+ */
+ private JComboBox getJComboBox() {
+ if (jComboBox == null) {
+ jComboBox = new JComboBox((ComboBoxModel)null);
+ }
+ return jComboBox;
+ }
+ /**
+ * This method initializes jList
+ *
+ * @return javax.swing.JList
+ */
+ private JList getJList() {
+ if (jList == null) {
+ jList = new JList((ListModel)null);
+ jList.addListSelectionListener(
+ new ListSelectionListener(){
+ public void valueChanged(ListSelectionEvent e){
+ if(!e.getValueIsAdjusting()){
+ JList list = (JList)e.getSource();
+ Object goal = list.getSelectedValue();
+ System.out.println(goal);
+
+// If I replace the line below with...
+ ListPanel.this.goalSelected(goal); //the join point is not seen!;
+// This was working before a switched to source level 5!
+ ListPanel.this.sendGoalSelectedNotice(goal); // this is workaround!
+
+ }
+ }
+ }
+ );
+ }
+ return jList;
+ }
+
+ // this is part of workaround
+ protected void sendGoalSelectedNotice(Object goal){
+ // join point is found by pointcut here! This is ok!
+ goalSelected(goal);
+ }
+} \ No newline at end of file
diff --git a/tests/bugs150/pr88900.aj b/tests/bugs150/pr88900.aj
new file mode 100644
index 000000000..4f3e65bc8
--- /dev/null
+++ b/tests/bugs150/pr88900.aj
@@ -0,0 +1,5 @@
+aspect RunnableDefaultImpl {
+
+ public void Runnable.run() {}
+
+}
diff --git a/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java b/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
index 6c3cb6dac..15516c6fc 100644
--- a/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
+++ b/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
@@ -454,6 +454,14 @@ public class Ajc150Tests extends org.aspectj.testing.XMLBasedAjcTestCase {
runTest("parameterized generic methods");
}
+ public void testCallJoinPointsInAnonymousInnerClasses() {
+ runTest("call join points in anonymous inner classes");
+ }
+
+ public void testNoRequirementForUnwovenTypesToBeExposedToWeaver() {
+ runTest("default impl of Runnable");
+ }
+
// helper methods.....
public SyntheticRepository createRepos(File cpentry) {
diff --git a/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml b/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
index fb1ce4b0b..eb518ceba 100644
--- a/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
+++ b/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
@@ -607,6 +607,25 @@
</compile>
</ajc-test>
+ <ajc-test dir="bugs150" title="call join points in anonymous inner classes">
+ <compile files="pr104229.aj" options="-1.5">
+ <message kind="warning" line="54" text="bingo"/>
+ <message kind="warning" line="115" text="bingo"/>
+ <message kind="warning" line="130" text="bingo"/>
+ </compile>
+ <run class="pr104229">
+ <stdout>
+ <line text="call match class pr104229"/>
+ <line text="OK it worked!"/>
+ </stdout>
+ </run>
+ </ajc-test>
+
+ <ajc-test dir="bugs150" title="default impl of Runnable">
+ <compile files="pr88900.aj" options="-Xdev:Pinpoint">
+ </compile>
+ </ajc-test>
+
<!-- ============================================================================ -->
<!-- ============================================================================ -->