diff options
author | aclement <aclement> | 2009-10-13 13:21:35 +0000 |
---|---|---|
committer | aclement <aclement> | 2009-10-13 13:21:35 +0000 |
commit | 1a790bef0683ad844f66b668c93b41154fc5a3fb (patch) | |
tree | 5dfbfab0b4985cbc147803e9b33f4628981fcad0 /org.aspectj.matcher | |
parent | 9def160bb51220f4079cbe69d35f131f0fe7ff6b (diff) | |
download | aspectj-1a790bef0683ad844f66b668c93b41154fc5a3fb.tar.gz aspectj-1a790bef0683ad844f66b668c93b41154fc5a3fb.zip |
292069: make this/target cheaper than call
Diffstat (limited to 'org.aspectj.matcher')
-rw-r--r-- | org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PointcutRewriterTest.java | 453 |
1 files changed, 226 insertions, 227 deletions
diff --git a/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PointcutRewriterTest.java b/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PointcutRewriterTest.java index 43a26208c..60b75b937 100644 --- a/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PointcutRewriterTest.java +++ b/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PointcutRewriterTest.java @@ -13,287 +13,286 @@ import java.util.Iterator; import java.util.Set; import java.util.StringTokenizer; -import org.aspectj.weaver.Shadow; -import org.aspectj.weaver.patterns.AndPointcut; -import org.aspectj.weaver.patterns.IfPointcut; -import org.aspectj.weaver.patterns.NotPointcut; -import org.aspectj.weaver.patterns.OrPointcut; -import org.aspectj.weaver.patterns.PatternParser; -import org.aspectj.weaver.patterns.Pointcut; -import org.aspectj.weaver.patterns.PointcutRewriter; - import junit.framework.TestCase; +import org.aspectj.weaver.Shadow; + /** * @author colyer - * - * TODO To change the template for this generated type comment go to - * Window - Preferences - Java - Code Style - Code Templates + * + * TODO To change the template for this generated type comment go to Window - Preferences - Java - Code Style - Code + * Templates */ public class PointcutRewriterTest extends TestCase { private PointcutRewriter prw; - + public void testDistributeNot() { Pointcut plain = getPointcut("this(Foo)"); - assertEquals("Unchanged",plain,prw.rewrite(plain)); + assertEquals("Unchanged", plain, prw.rewrite(plain)); Pointcut not = getPointcut("!this(Foo)"); - assertEquals("Unchanged",not,prw.rewrite(not)); + assertEquals("Unchanged", not, prw.rewrite(not)); Pointcut notNot = getPointcut("!!this(Foo)"); - assertEquals("this(Foo)",prw.rewrite(notNot).toString()); + assertEquals("this(Foo)", prw.rewrite(notNot).toString()); Pointcut notNotNOT = getPointcut("!!!this(Foo)"); - assertEquals("!this(Foo)",prw.rewrite(notNotNOT).toString()); + assertEquals("!this(Foo)", prw.rewrite(notNotNOT).toString()); Pointcut and = getPointcut("!(this(Foo) && this(Goo))"); - assertEquals("(!this(Foo) || !this(Goo))",prw.rewrite(and,true).toString()); + assertEquals("(!this(Foo) || !this(Goo))", prw.rewrite(and, true).toString()); Pointcut or = getPointcut("!(this(Foo) || this(Goo))"); - assertEquals("(!this(Foo) && !this(Goo))",prw.rewrite(or,true).toString()); + assertEquals("(!this(Foo) && !this(Goo))", prw.rewrite(or, true).toString()); Pointcut nestedNot = getPointcut("!(this(Foo) && !this(Goo))"); - assertEquals("(!this(Foo) || this(Goo))",prw.rewrite(nestedNot,true).toString()); + assertEquals("(!this(Foo) || this(Goo))", prw.rewrite(nestedNot, true).toString()); } - + public void testPullUpDisjunctions() { Pointcut aAndb = getPointcut("this(Foo) && this(Goo)"); - assertEquals("Unchanged",aAndb,prw.rewrite(aAndb)); + assertEquals("Unchanged", aAndb, prw.rewrite(aAndb)); Pointcut aOrb = getPointcut("this(Foo) || this(Moo)"); - assertEquals("Unchanged",aOrb,prw.rewrite(aOrb)); + assertEquals("Unchanged", aOrb, prw.rewrite(aOrb)); Pointcut leftOr = getPointcut("this(Foo) || (this(Goo) && this(Boo))"); - assertEquals("or%anyorder%this(Foo)%and%anyorder%this(Boo)%this(Goo)",prw.rewrite(leftOr)); - //assertEquals("(this(Foo) || (this(Boo) && this(Goo)))",prw.rewrite(leftOr).toString()); - + assertEquals("or%anyorder%this(Foo)%and%anyorder%this(Boo)%this(Goo)", prw.rewrite(leftOr)); + // assertEquals("(this(Foo) || (this(Boo) && this(Goo)))",prw.rewrite(leftOr).toString()); + Pointcut rightOr = getPointcut("(this(Goo) && this(Boo)) || this(Foo)"); -// assertEquals("(this(Foo) || (this(Boo) && this(Goo)))",prw.rewrite(rightOr).toString()); - assertEquals("or%anyorder%this(Foo)%and%anyorder%this(Goo)%this(Boo)",prw.rewrite(rightOr)); - + // assertEquals("(this(Foo) || (this(Boo) && this(Goo)))",prw.rewrite(rightOr).toString()); + assertEquals("or%anyorder%this(Foo)%and%anyorder%this(Goo)%this(Boo)", prw.rewrite(rightOr)); + Pointcut leftAnd = getPointcut("this(Foo) && (this(Goo) || this(Boo))"); -// assertEquals("((this(Boo) && this(Foo)) || (this(Foo) && this(Goo)))",prw.rewrite(leftAnd).toString()); - assertEquals("or%anyorder%and%anyorder%this(Boo)%this(Foo)%and%anyorder%this(Foo)%this(Goo)",prw.rewrite(leftAnd)); - + // assertEquals("((this(Boo) && this(Foo)) || (this(Foo) && this(Goo)))",prw.rewrite(leftAnd).toString()); + assertEquals("or%anyorder%and%anyorder%this(Boo)%this(Foo)%and%anyorder%this(Foo)%this(Goo)", prw.rewrite(leftAnd)); + Pointcut rightAnd = getPointcut("(this(Goo) || this(Boo)) && this(Foo)"); -// assertEquals("((this(Boo) && this(Foo)) || (this(Foo) && this(Goo)))",prw.rewrite(rightAnd).toString()); - assertEquals("or%anyorder%and%anyorder%this(Boo)%this(Foo)%and%anyorder%this(Foo)%this(Goo)",prw.rewrite(rightAnd)); - + // assertEquals("((this(Boo) && this(Foo)) || (this(Foo) && this(Goo)))",prw.rewrite(rightAnd).toString()); + assertEquals("or%anyorder%and%anyorder%this(Boo)%this(Foo)%and%anyorder%this(Foo)%this(Goo)", prw.rewrite(rightAnd)); + Pointcut nestedOrs = getPointcut("this(Foo) || this(Goo) || this(Boo)"); -// assertEquals("((this(Boo) || this(Foo)) || this(Goo))",prw.rewrite(nestedOrs).toString()); - assertEquals("or%anyorder%this(Goo)%or%anyorder%this(Boo)%this(Foo)",prw.rewrite(nestedOrs)); - + // assertEquals("((this(Boo) || this(Foo)) || this(Goo))",prw.rewrite(nestedOrs).toString()); + assertEquals("or%anyorder%this(Goo)%or%anyorder%this(Boo)%this(Foo)", prw.rewrite(nestedOrs)); + Pointcut nestedAnds = getPointcut("(this(Foo) && (this(Boo) && (this(Goo) || this(Moo))))"); // t(F) && (t(B) && (t(G) || t(M))) // ==> t(F) && ((t(B) && t(G)) || (t(B) && t(M))) // ==> (t(F) && (t(B) && t(G))) || (t(F) && (t(B) && t(M))) -// assertEquals("(((this(Boo) && this(Foo)) && this(Goo)) || ((this(Boo) && this(Foo)) && this(Moo)))", -// prw.rewrite(nestedAnds).toString()); - assertEquals("or%anyorder%and%anyorder%and%anyorder%this(Boo)%this(Foo)%this(Goo)%and%anyorder%and%anyorder%this(Boo)%this(Foo)%this(Moo)",prw.rewrite(nestedAnds)); + // assertEquals("(((this(Boo) && this(Foo)) && this(Goo)) || ((this(Boo) && this(Foo)) && this(Moo)))", + // prw.rewrite(nestedAnds).toString()); + assertEquals( + "or%anyorder%and%anyorder%and%anyorder%this(Boo)%this(Foo)%this(Goo)%and%anyorder%and%anyorder%this(Boo)%this(Foo)%this(Moo)", + prw.rewrite(nestedAnds)); } - + /** - * spec is reverse polish notation with operators and, or , not, anyorder, - * delimiter is "%" (not whitespace). + * spec is reverse polish notation with operators and, or , not, anyorder, delimiter is "%" (not whitespace). + * * @param spec * @param pc */ private void assertEquals(String spec, Pointcut pc) { - StringTokenizer strTok = new StringTokenizer(spec,"%"); - String[] tokens = new String[strTok.countTokens()]; - for (int i = 0; i < tokens.length; i++) { - tokens[i] = strTok.nextToken(); - } - tokenIndex = 0; - assertTrue(spec,equals(pc,tokens)); - } - + StringTokenizer strTok = new StringTokenizer(spec, "%"); + String[] tokens = new String[strTok.countTokens()]; + for (int i = 0; i < tokens.length; i++) { + tokens[i] = strTok.nextToken(); + } + tokenIndex = 0; + assertTrue(spec, equals(pc, tokens)); + } + private int tokenIndex = 0; + private boolean equals(Pointcut pc, String[] tokens) { - if (tokens[tokenIndex].equals("and")) { - tokenIndex++; - if (!(pc instanceof AndPointcut)) return false; - AndPointcut apc = (AndPointcut) pc; - Pointcut left = apc.getLeft(); - Pointcut right = apc.getRight(); - if (tokens[tokenIndex].equals("anyorder")) { - tokenIndex++; - int restorePoint = tokenIndex; - boolean leftMatchFirst = equals(left,tokens) && - equals(right,tokens); - if (leftMatchFirst) return true; - tokenIndex = restorePoint; - boolean rightMatchFirst = equals(right,tokens) && - equals(left,tokens); - return rightMatchFirst; - } else { - return equals(left,tokens) && - equals(right,tokens); - } - } else if (tokens[tokenIndex].equals("or")) { - tokenIndex++; - if (!(pc instanceof OrPointcut)) return false; - OrPointcut opc = (OrPointcut) pc; - Pointcut left = opc.getLeft(); - Pointcut right = opc.getRight(); - if (tokens[tokenIndex].equals("anyorder")) { - tokenIndex++; - int restorePoint = tokenIndex; - boolean leftMatchFirst = equals(left,tokens) && - equals(right,tokens); - if (leftMatchFirst) return true; - tokenIndex = restorePoint; - boolean rightMatchFirst = equals(right,tokens) && - equals(left,tokens); - return rightMatchFirst; - } else { - return equals(left,tokens) && - equals(right,tokens); - } - - } else if (tokens[tokenIndex].equals("not")) { - if (!(pc instanceof NotPointcut)) return false; - tokenIndex++; - NotPointcut np = (NotPointcut) pc; - return equals(np.getNegatedPointcut(),tokens); - } else { - return tokens[tokenIndex++].equals(pc.toString()); - } - } - -// public void testSplitOutWithins() { -// Pointcut simpleExecution = getPointcut("execution(* *.*(..))"); -// assertEquals("Unchanged",simpleExecution,prw.rewrite(simpleExecution)); -// Pointcut simpleWithinCode = getPointcut("withincode(* *.*(..))"); -// assertEquals("Unchanged",simpleWithinCode,prw.rewrite(simpleWithinCode)); -// Pointcut execution = getPointcut("execution(@Foo Foo (@Goo org.xyz..*).m*(Foo,Boo))"); -// assertEquals("(within((@(Goo) org.xyz..*)) && execution(@(Foo) Foo m*(Foo, Boo)))", -// prw.rewrite(execution).toString()); -// Pointcut withincode = getPointcut("withincode(@Foo Foo (@Goo org.xyz..*).m*(Foo,Boo))"); -// assertEquals("(within((@(Goo) org.xyz..*)) && withincode(@(Foo) Foo m*(Foo, Boo)))", -// prw.rewrite(withincode).toString()); -// Pointcut notExecution = getPointcut("!execution(Foo BankAccount+.*(..))"); -// assertEquals("(!within(BankAccount+) || !execution(Foo *(..)))", -// prw.rewrite(notExecution).toString()); -// Pointcut andWithincode = getPointcut("withincode(Foo.new(..)) && this(Foo)"); -// assertEquals("((within(Foo) && withincode(new(..))) && this(Foo))", -// prw.rewrite(andWithincode).toString()); -// Pointcut orExecution = getPointcut("this(Foo) || execution(Goo Foo.moo(Baa))"); -// assertEquals("((within(Foo) && execution(Goo moo(Baa))) || this(Foo))", -// prw.rewrite(orExecution).toString()); -// } - + if (tokens[tokenIndex].equals("and")) { + tokenIndex++; + if (!(pc instanceof AndPointcut)) { + return false; + } + AndPointcut apc = (AndPointcut) pc; + Pointcut left = apc.getLeft(); + Pointcut right = apc.getRight(); + if (tokens[tokenIndex].equals("anyorder")) { + tokenIndex++; + int restorePoint = tokenIndex; + boolean leftMatchFirst = equals(left, tokens) && equals(right, tokens); + if (leftMatchFirst) { + return true; + } + tokenIndex = restorePoint; + boolean rightMatchFirst = equals(right, tokens) && equals(left, tokens); + return rightMatchFirst; + } else { + return equals(left, tokens) && equals(right, tokens); + } + } else if (tokens[tokenIndex].equals("or")) { + tokenIndex++; + if (!(pc instanceof OrPointcut)) { + return false; + } + OrPointcut opc = (OrPointcut) pc; + Pointcut left = opc.getLeft(); + Pointcut right = opc.getRight(); + if (tokens[tokenIndex].equals("anyorder")) { + tokenIndex++; + int restorePoint = tokenIndex; + boolean leftMatchFirst = equals(left, tokens) && equals(right, tokens); + if (leftMatchFirst) { + return true; + } + tokenIndex = restorePoint; + boolean rightMatchFirst = equals(right, tokens) && equals(left, tokens); + return rightMatchFirst; + } else { + return equals(left, tokens) && equals(right, tokens); + } + + } else if (tokens[tokenIndex].equals("not")) { + if (!(pc instanceof NotPointcut)) { + return false; + } + tokenIndex++; + NotPointcut np = (NotPointcut) pc; + return equals(np.getNegatedPointcut(), tokens); + } else { + return tokens[tokenIndex++].equals(pc.toString()); + } + } + + // public void testSplitOutWithins() { + // Pointcut simpleExecution = getPointcut("execution(* *.*(..))"); + // assertEquals("Unchanged",simpleExecution,prw.rewrite(simpleExecution)); + // Pointcut simpleWithinCode = getPointcut("withincode(* *.*(..))"); + // assertEquals("Unchanged",simpleWithinCode,prw.rewrite(simpleWithinCode)); + // Pointcut execution = getPointcut("execution(@Foo Foo (@Goo org.xyz..*).m*(Foo,Boo))"); + // assertEquals("(within((@(Goo) org.xyz..*)) && execution(@(Foo) Foo m*(Foo, Boo)))", + // prw.rewrite(execution).toString()); + // Pointcut withincode = getPointcut("withincode(@Foo Foo (@Goo org.xyz..*).m*(Foo,Boo))"); + // assertEquals("(within((@(Goo) org.xyz..*)) && withincode(@(Foo) Foo m*(Foo, Boo)))", + // prw.rewrite(withincode).toString()); + // Pointcut notExecution = getPointcut("!execution(Foo BankAccount+.*(..))"); + // assertEquals("(!within(BankAccount+) || !execution(Foo *(..)))", + // prw.rewrite(notExecution).toString()); + // Pointcut andWithincode = getPointcut("withincode(Foo.new(..)) && this(Foo)"); + // assertEquals("((within(Foo) && withincode(new(..))) && this(Foo))", + // prw.rewrite(andWithincode).toString()); + // Pointcut orExecution = getPointcut("this(Foo) || execution(Goo Foo.moo(Baa))"); + // assertEquals("((within(Foo) && execution(Goo moo(Baa))) || this(Foo))", + // prw.rewrite(orExecution).toString()); + // } public void testRemoveDuplicatesInAnd() { Pointcut dupAnd = getPointcut("this(Foo) && this(Foo)"); - assertEquals("this(Foo)",prw.rewrite(dupAnd).toString()); + assertEquals("this(Foo)", prw.rewrite(dupAnd).toString()); Pointcut splitdupAnd = getPointcut("(this(Foo) && target(Boo)) && this(Foo)"); - assertEquals("(target(Boo) && this(Foo))",prw.rewrite(splitdupAnd).toString()); + assertEquals("(target(Boo) && this(Foo))", prw.rewrite(splitdupAnd).toString()); } - + public void testNotRemoveNearlyDuplicatesInAnd() { Pointcut toAndto = getPointcut("this(Object+) && this(Object)"); -// Pointcut rewritten = - prw.rewrite(toAndto); + // Pointcut rewritten = + prw.rewrite(toAndto); } - + public void testAAndNotAinAnd() { Pointcut aAndNota = getPointcut("this(Foo)&& !this(Foo)"); - assertEquals("Matches nothing","",prw.rewrite(aAndNota).toString()); + assertEquals("Matches nothing", "", prw.rewrite(aAndNota).toString()); Pointcut aAndBAndNota = getPointcut("this(Foo) && execution(* *.*(..)) && !this(Foo)"); - assertEquals("Matches nothing","",prw.rewrite(aAndBAndNota).toString()); + assertEquals("Matches nothing", "", prw.rewrite(aAndBAndNota).toString()); } - + public void testIfFalseInAnd() { Pointcut ifFalse = IfPointcut.makeIfFalsePointcut(Pointcut.CONCRETE); Pointcut p = getPointcut("this(A)"); - assertEquals("Matches nothing","",prw.rewrite(new AndPointcut(ifFalse,p)).toString()); + assertEquals("Matches nothing", "", prw.rewrite(new AndPointcut(ifFalse, p)).toString()); } public void testMatchesNothinginAnd() { Pointcut nothing = Pointcut.makeMatchesNothing(Pointcut.CONCRETE); Pointcut p = getPointcut("this(A)"); - assertEquals("Matches nothing","",prw.rewrite(new AndPointcut(nothing,p)).toString()); + assertEquals("Matches nothing", "", prw.rewrite(new AndPointcut(nothing, p)).toString()); } - + public void testMixedKindsInAnd() { Pointcut mixedKinds = getPointcut("call(* *(..)) && execution(* *(..))"); - assertEquals("Matches nothing","",prw.rewrite(mixedKinds).toString()); - Pointcut ok = getPointcut("call(* *(..)) && this(Foo)"); - assertEquals(ok,prw.rewrite(ok)); + assertEquals("Matches nothing", "", prw.rewrite(mixedKinds).toString()); + Pointcut ok = getPointcut("this(Foo) && call(* *(..))"); + assertEquals(ok, prw.rewrite(ok)); } - + public void testDetermineKindSetOfAnd() { Pointcut oneKind = getPointcut("execution(* foo(..)) && this(Boo)"); AndPointcut rewritten = (AndPointcut) prw.rewrite(oneKind); - assertEquals("Only one kind",1,Shadow.howMany(rewritten.couldMatchKinds())); - assertTrue("It's Shadow.MethodExecution",Shadow.MethodExecution.isSet(rewritten.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(rewritten.couldMatchKinds())); + assertTrue("It's Shadow.MethodExecution", Shadow.MethodExecution.isSet(rewritten.couldMatchKinds())); } - + public void testKindSetOfExecution() { Pointcut p = getPointcut("execution(* foo(..))"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.MethodExecution",Shadow.MethodExecution.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.MethodExecution", Shadow.MethodExecution.isSet(p.couldMatchKinds())); p = getPointcut("execution(new(..))"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.ConstructorExecution",Shadow.ConstructorExecution.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.ConstructorExecution", Shadow.ConstructorExecution.isSet(p.couldMatchKinds())); } - + public void testKindSetOfCall() { Pointcut p = getPointcut("call(* foo(..))"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.MethodCall",Shadow.MethodCall.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.MethodCall", Shadow.MethodCall.isSet(p.couldMatchKinds())); p = getPointcut("call(new(..))"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.ConstructorCall",Shadow.ConstructorCall.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.ConstructorCall", Shadow.ConstructorCall.isSet(p.couldMatchKinds())); } - + public void testKindSetOfAdviceExecution() { Pointcut p = getPointcut("adviceexecution()"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.AdviceExecution",Shadow.AdviceExecution.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.AdviceExecution", Shadow.AdviceExecution.isSet(p.couldMatchKinds())); } - + public void testKindSetOfGet() { Pointcut p = getPointcut("get(* *)"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.FieldGet",Shadow.FieldGet.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.FieldGet", Shadow.FieldGet.isSet(p.couldMatchKinds())); } - + public void testKindSetOfSet() { Pointcut p = getPointcut("set(* *)"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.FieldSet",Shadow.FieldSet.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.FieldSet", Shadow.FieldSet.isSet(p.couldMatchKinds())); } - + public void testKindSetOfHandler() { Pointcut p = getPointcut("handler(*)"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.ExceptionHandler",Shadow.ExceptionHandler.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.ExceptionHandler", Shadow.ExceptionHandler.isSet(p.couldMatchKinds())); } - + public void testKindSetOfInitialization() { Pointcut p = getPointcut("initialization(new (..))"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.Initialization",Shadow.Initialization.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.Initialization", Shadow.Initialization.isSet(p.couldMatchKinds())); } - + public void testKindSetOfPreInitialization() { Pointcut p = getPointcut("preinitialization(new (..))"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.PreInitialization",Shadow.PreInitialization.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.PreInitialization", Shadow.PreInitialization.isSet(p.couldMatchKinds())); } - + public void testKindSetOfStaticInitialization() { Pointcut p = getPointcut("staticinitialization(*)"); - assertEquals("Only one kind",1,Shadow.howMany(p.couldMatchKinds())); - assertTrue("It's Shadow.StaticInitialization",Shadow.StaticInitialization.isSet(p.couldMatchKinds())); + assertEquals("Only one kind", 1, Shadow.howMany(p.couldMatchKinds())); + assertTrue("It's Shadow.StaticInitialization", Shadow.StaticInitialization.isSet(p.couldMatchKinds())); } - + public void testKindSetOfThis() { Pointcut p = getPointcut("this(Foo)"); Set matches = Shadow.toSet(p.couldMatchKinds()); for (Iterator iter = matches.iterator(); iter.hasNext();) { Shadow.Kind kind = (Shadow.Kind) iter.next(); - assertFalse("No kinds that don't have a this",kind.neverHasThis()); + assertFalse("No kinds that don't have a this", kind.neverHasThis()); } for (int i = 0; i < Shadow.SHADOW_KINDS.length; i++) { if (!Shadow.SHADOW_KINDS[i].neverHasThis()) { - assertTrue("All kinds that do have this",matches.contains(Shadow.SHADOW_KINDS[i])); + assertTrue("All kinds that do have this", matches.contains(Shadow.SHADOW_KINDS[i])); } } // + @ @@ -301,25 +300,25 @@ public class PointcutRewriterTest extends TestCase { matches = Shadow.toSet(p.couldMatchKinds()); for (Iterator iter = matches.iterator(); iter.hasNext();) { Shadow.Kind kind = (Shadow.Kind) iter.next(); - assertFalse("No kinds that don't have a this",kind.neverHasThis()); + assertFalse("No kinds that don't have a this", kind.neverHasThis()); } for (int i = 0; i < Shadow.SHADOW_KINDS.length; i++) { if (!Shadow.SHADOW_KINDS[i].neverHasThis()) { - assertTrue("All kinds that do have this",matches.contains(Shadow.SHADOW_KINDS[i])); + assertTrue("All kinds that do have this", matches.contains(Shadow.SHADOW_KINDS[i])); } } } - + public void testKindSetOfTarget() { Pointcut p = getPointcut("target(Foo)"); Set matches = Shadow.toSet(p.couldMatchKinds()); for (Iterator iter = matches.iterator(); iter.hasNext();) { Shadow.Kind kind = (Shadow.Kind) iter.next(); - assertFalse("No kinds that don't have a target",kind.neverHasTarget()); + assertFalse("No kinds that don't have a target", kind.neverHasTarget()); } for (int i = 0; i < Shadow.SHADOW_KINDS.length; i++) { if (!Shadow.SHADOW_KINDS[i].neverHasTarget()) { - assertTrue("All kinds that do have target",matches.contains(Shadow.SHADOW_KINDS[i])); + assertTrue("All kinds that do have target", matches.contains(Shadow.SHADOW_KINDS[i])); } } // + @ @@ -327,36 +326,36 @@ public class PointcutRewriterTest extends TestCase { matches = Shadow.toSet(p.couldMatchKinds()); for (Iterator iter = matches.iterator(); iter.hasNext();) { Shadow.Kind kind = (Shadow.Kind) iter.next(); - assertFalse("No kinds that don't have a target",kind.neverHasTarget()); + assertFalse("No kinds that don't have a target", kind.neverHasTarget()); } for (int i = 0; i < Shadow.SHADOW_KINDS.length; i++) { if (!Shadow.SHADOW_KINDS[i].neverHasTarget()) { - assertTrue("All kinds that do have target",matches.contains(Shadow.SHADOW_KINDS[i])); + assertTrue("All kinds that do have target", matches.contains(Shadow.SHADOW_KINDS[i])); } } } - + public void testKindSetOfArgs() { Pointcut p = getPointcut("args(..)"); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); // + @ p = getPointcut("@args(..)"); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); } - + public void testKindSetOfAnnotation() { Pointcut p = getPointcut("@annotation(Foo)"); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); } - + public void testKindSetOfWithin() { Pointcut p = getPointcut("within(*)"); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); // + @ p = getPointcut("@within(Foo)"); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); } - + public void testKindSetOfWithinCode() { Pointcut p = getPointcut("withincode(* foo(..))"); Set matches = Shadow.toSet(p.couldMatchKinds()); @@ -367,82 +366,82 @@ public class PointcutRewriterTest extends TestCase { } for (int i = 0; i < Shadow.SHADOW_KINDS.length; i++) { if (!Shadow.SHADOW_KINDS[i].isEnclosingKind()) { - assertTrue("All kinds that are not enclosing",matches.contains(Shadow.SHADOW_KINDS[i])); + assertTrue("All kinds that are not enclosing", matches.contains(Shadow.SHADOW_KINDS[i])); } - } - assertTrue("Need cons-exe for inlined field inits",matches.contains(Shadow.ConstructorExecution)); - assertTrue("Need init for inlined field inits",matches.contains(Shadow.Initialization)); + } + assertTrue("Need cons-exe for inlined field inits", matches.contains(Shadow.ConstructorExecution)); + assertTrue("Need init for inlined field inits", matches.contains(Shadow.Initialization)); // + @ p = getPointcut("@withincode(Foo)"); matches = Shadow.toSet(p.couldMatchKinds()); for (Iterator iter = matches.iterator(); iter.hasNext();) { Shadow.Kind kind = (Shadow.Kind) iter.next(); - assertFalse("No kinds that are themselves enclosing",kind.isEnclosingKind()); + assertFalse("No kinds that are themselves enclosing", kind.isEnclosingKind()); } for (int i = 0; i < Shadow.SHADOW_KINDS.length; i++) { if (!Shadow.SHADOW_KINDS[i].isEnclosingKind()) { - assertTrue("All kinds that are not enclosing",matches.contains(Shadow.SHADOW_KINDS[i])); + assertTrue("All kinds that are not enclosing", matches.contains(Shadow.SHADOW_KINDS[i])); } - } + } } - + public void testKindSetOfIf() { - Pointcut p = new IfPointcut(null,0); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + Pointcut p = new IfPointcut(null, 0); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); p = IfPointcut.makeIfTruePointcut(Pointcut.CONCRETE); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); p = IfPointcut.makeIfFalsePointcut(Pointcut.CONCRETE); - assertTrue("Nothing",p.couldMatchKinds()==Shadow.NO_SHADOW_KINDS_BITS); + assertTrue("Nothing", p.couldMatchKinds() == Shadow.NO_SHADOW_KINDS_BITS); } - + public void testKindSetOfCflow() { Pointcut p = getPointcut("cflow(this(Foo))"); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); // [below] p = getPointcut("cflowbelow(this(Foo))"); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); } - + public void testKindSetInNegation() { Pointcut p = getPointcut("!execution(new(..))"); - assertTrue("All kinds",p.couldMatchKinds()==Shadow.ALL_SHADOW_KINDS_BITS); + assertTrue("All kinds", p.couldMatchKinds() == Shadow.ALL_SHADOW_KINDS_BITS); } - + public void testKindSetOfOr() { Pointcut p = getPointcut("execution(new(..)) || get(* *)"); Set matches = Shadow.toSet(p.couldMatchKinds()); - assertEquals("2 kinds",2,matches.size()); - assertTrue("ConstructorExecution",matches.contains(Shadow.ConstructorExecution)); - assertTrue("FieldGet",matches.contains(Shadow.FieldGet)); + assertEquals("2 kinds", 2, matches.size()); + assertTrue("ConstructorExecution", matches.contains(Shadow.ConstructorExecution)); + assertTrue("FieldGet", matches.contains(Shadow.FieldGet)); } - + public void testOrderingInAnd() { Pointcut bigLongPC = getPointcut("cflow(this(Foo)) && @args(X) && args(X) && @this(Foo) && @target(Boo) && this(Moo) && target(Boo) && @annotation(Moo) && @withincode(Boo) && withincode(new(..)) && set(* *)&& @within(Foo) && within(Foo)"); Pointcut rewritten = prw.rewrite(bigLongPC); - assertEquals("((((((((((((within(Foo) && @within(Foo)) && set(* *)) && withincode(new(..))) && @withincode(Boo)) && @annotation(Moo)) && target(Boo)) && this(Moo)) && @target(Boo)) && @this(Foo)) && args(X)) && @args(X)) && cflow(this(Foo)))",rewritten.toString()); + assertEquals( + "((((((((((((within(Foo) && @within(Foo)) && set(* *)) && withincode(new(..))) && @withincode(Boo)) && target(Boo)) && this(Moo)) && @annotation(Moo)) && @target(Boo)) && @this(Foo)) && args(X)) && @args(X)) && cflow(this(Foo)))", + rewritten.toString()); } - + public void testOrderingInSimpleOr() { OrPointcut opc = (OrPointcut) getPointcut("execution(new(..)) || get(* *)"); - assertEquals("reordered","(get(* *) || execution(new(..)))",prw.rewrite(opc).toString()); + assertEquals("reordered", "(get(* *) || execution(new(..)))", prw.rewrite(opc).toString()); } - + public void testOrderingInNestedOrs() { OrPointcut opc = (OrPointcut) getPointcut("(execution(new(..)) || get(* *)) || within(abc)"); - assertEquals("reordered","((within(abc) || get(* *)) || execution(new(..)))", - prw.rewrite(opc).toString()); + assertEquals("reordered", "((within(abc) || get(* *)) || execution(new(..)))", prw.rewrite(opc).toString()); } - + public void testOrderingInOrsWithNestedAnds() { OrPointcut opc = (OrPointcut) getPointcut("get(* *) || (execution(new(..)) && within(abc))"); - assertEquals("reordered","((within(abc) && execution(new(..))) || get(* *))", - prw.rewrite(opc).toString()); + assertEquals("reordered", "((within(abc) && execution(new(..))) || get(* *))", prw.rewrite(opc).toString()); } - + private Pointcut getPointcut(String s) { return new PatternParser(s).parsePointcut(); } - + /* * @see TestCase#setUp() */ |