aboutsummaryrefslogtreecommitdiffstats
path: root/org.aspectj.matcher/testsrc
diff options
context:
space:
mode:
authoraclement <aclement>2010-06-29 00:12:05 +0000
committeraclement <aclement>2010-06-29 00:12:05 +0000
commit767bb859f169094181618e45651ed04697e735b4 (patch)
tree60683b790488a65671f82339492922dd0511f458 /org.aspectj.matcher/testsrc
parent7a2f0c64f6454510b1d1933c85e93bc95c16ccea (diff)
downloadaspectj-767bb859f169094181618e45651ed04697e735b4.tar.gz
aspectj-767bb859f169094181618e45651ed04697e735b4.zip
317743: import handling and type lookup issues
Diffstat (limited to 'org.aspectj.matcher/testsrc')
-rw-r--r--org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PatternsTests.java18
-rw-r--r--org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/SimpleScopeTests.java278
-rw-r--r--org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/TypePatternTestCase.java18
3 files changed, 288 insertions, 26 deletions
diff --git a/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PatternsTests.java b/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PatternsTests.java
index 452f6a26e..afd75eab3 100644
--- a/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PatternsTests.java
+++ b/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/PatternsTests.java
@@ -12,23 +12,6 @@
package org.aspectj.weaver.patterns;
-import org.aspectj.weaver.patterns.AndOrNotTestCase;
-import org.aspectj.weaver.patterns.ArgsTestCase;
-import org.aspectj.weaver.patterns.BindingTestCase;
-import org.aspectj.weaver.patterns.DeclareErrorOrWarningTestCase;
-import org.aspectj.weaver.patterns.ModifiersPatternTestCase;
-import org.aspectj.weaver.patterns.NamePatternParserTestCase;
-import org.aspectj.weaver.patterns.NamePatternTestCase;
-import org.aspectj.weaver.patterns.ParserTestCase;
-import org.aspectj.weaver.patterns.PatternsTests;
-import org.aspectj.weaver.patterns.PointcutRewriterTest;
-import org.aspectj.weaver.patterns.SignaturePatternTestCase;
-import org.aspectj.weaver.patterns.ThisOrTargetTestCase;
-import org.aspectj.weaver.patterns.TypePatternListTestCase;
-import org.aspectj.weaver.patterns.TypePatternTestCase;
-import org.aspectj.weaver.patterns.VisitorTestCase;
-import org.aspectj.weaver.patterns.WithinTestCase;
-
import junit.framework.Test;
import junit.framework.TestCase;
import junit.framework.TestSuite;
@@ -49,6 +32,7 @@ public class PatternsTests extends TestCase {
suite.addTestSuite(ThisOrTargetTestCase.class);
suite.addTestSuite(TypePatternListTestCase.class);
suite.addTestSuite(TypePatternTestCase.class);
+ suite.addTestSuite(SimpleScopeTests.class);
suite.addTestSuite(WithinTestCase.class);
suite.addTestSuite(ArgsTestCase.class);
// suite.addTestSuite(AnnotationPatternTestCase.class);
diff --git a/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/SimpleScopeTests.java b/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/SimpleScopeTests.java
new file mode 100644
index 000000000..8df97e2f3
--- /dev/null
+++ b/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/SimpleScopeTests.java
@@ -0,0 +1,278 @@
+/* *******************************************************************
+ * Copyright (c) 2002 Palo Alto Research Center, Incorporated (PARC).
+ * 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://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * PARC initial implementation
+ * ******************************************************************/
+
+package org.aspectj.weaver.patterns;
+
+import org.aspectj.weaver.UnresolvedType;
+import org.aspectj.weaver.World;
+import org.aspectj.weaver.reflect.ReflectionWorld;
+
+public class SimpleScopeTests extends PatternsTestCase {
+
+ public World getWorld() {
+ return new ReflectionWorld(true, this.getClass().getClassLoader());
+ }
+
+ public void testTestScope() {
+ SimpleScope scope = makeTestScope();
+
+ FormalBinding formalBinding = scope.lookupFormal("i");
+ assertEquals("i", formalBinding.getName());
+ assertEquals("I", formalBinding.getType().getSignature());
+
+ formalBinding = scope.lookupFormal("string");
+ assertEquals("string", formalBinding.getName());
+ assertEquals("Ljava/lang/String;", formalBinding.getType().getSignature());
+ }
+
+ public void test1() {
+ SimpleScope scope = makeTestScope();
+ UnresolvedType unresolvedType = scope.lookupType("void", null);
+ System.out.println(unresolvedType);
+ }
+
+ public static final String[] ZERO_STRINGS = new String[0];
+
+ private TestScope makeTestScope() {
+ // i = int
+ // string = String
+ return new TestScope(new String[] { "int", "java.lang.String" }, new String[] { "i", "string" }, world);
+ }
+ //
+ // public void testStaticMatch() {
+ // checkMatch("java.lang.Object", "java.lang.Object", true);
+ // checkMatch("java.lang.Object+", "java.lang.Object", true);
+ // checkMatch("java.lang.Object+", "java.lang.String", true);
+ // checkMatch("java.lang.String+", "java.lang.Object", false);
+ // checkMatch("java.lang.Integer", "java.lang.String", false);
+ //
+ // checkMatch("java.lang.Integer", "int", false);
+ //
+ // checkMatch("java.lang.Number+", "java.lang.Integer", true);
+ //
+ // checkMatch("java..*", "java.lang.Integer", true);
+ // checkMatch("java..*", "java.lang.reflect.Modifier", true);
+ // checkMatch("java..*", "int", false);
+ // checkMatch("java..*", "javax.swing.Action", false);
+ // checkMatch("java..*+", "javax.swing.Action", true);
+ //
+ // checkMatch("*.*.Object", "java.lang.Object", true);
+ // checkMatch("*.Object", "java.lang.Object", false);
+ // checkMatch("*..*", "java.lang.Object", true);
+ // checkMatch("*..*", "int", false);
+ // checkMatch("java..Modifier", "java.lang.reflect.Modifier", true);
+ // checkMatch("java.lang.reflect.Mod..ifier", "java.lang.reflect.Modifier", false);
+ //
+ // checkMatch("java..reflect..Modifier", "java.lang.reflect.Modifier", true);
+ // checkMatch("java..lang..Modifier", "java.lang.reflect.Modifier", true);
+ // checkMatch("java..*..Modifier", "java.lang.reflect.Modifier", true);
+ // checkMatch("java..*..*..Modifier", "java.lang.reflect.Modifier", true);
+ // checkMatch("java..*..*..*..Modifier", "java.lang.reflect.Modifier", false);
+ // // checkMatch("java..reflect..Modifier", "java.lang.reflect.Modxifier", false);
+ // checkMatch("ja*va..Modifier", "java.lang.reflect.Modifier", true);
+ // checkMatch("java..*..Mod*ifier", "java.lang.reflect.Modifier", true);
+ //
+ // }
+ //
+ // // three levels:
+ // // 0. defined in current compilation unit, or imported by name
+ // // 1. defined in current package/type/whatever
+ // // 2. defined in package imported by *
+ // /**
+ // * We've decided not to test this here, but rather in any compilers
+ // */
+ // public void testImportResolve() {
+ // // checkIllegalImportResolution("List", new String[] { "java.util", "java.awt", },
+ // // ZERO_STRINGS);
+ //
+ // }
+ //
+ // // Assumption for bcweaver: Already resolved type patterns with no *s or ..'s into exact type
+ // // patterns. Exact type patterns don't have import lists. non-exact-type pattens don't
+ // // care about precedence, so the current package can be included with all the other packages,
+ // // and we don't care about compilation units, and we don't care about ordering.
+ //
+ // // only giving this wild-type patterns
+ // public void testImportMatch() {
+ //
+ // checkImportMatch("*List", new String[] { "java.awt.", }, ZERO_STRINGS, "java.awt.List", true);
+ // checkImportMatch("*List", new String[] { "java.awt.", }, ZERO_STRINGS, "java.awt.List", true);
+ // checkImportMatch("*List", new String[] { "java.awt.", }, ZERO_STRINGS, "java.util.List", false);
+ // checkImportMatch("*List", new String[] { "java.util.", }, ZERO_STRINGS, "java.awt.List", false);
+ // checkImportMatch("*List", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.List", true);
+ //
+ // checkImportMatch("*List", ZERO_STRINGS, new String[] { "java.awt.List", }, "java.awt.List", true);
+ //
+ // checkImportMatch("awt.*List", ZERO_STRINGS, new String[] { "java.awt.List", }, "java.awt.List", false);
+ // checkImportMatch("*Foo", ZERO_STRINGS, new String[] { "java.awt.List", }, "java.awt.List", false);
+ //
+ // checkImportMatch("*List", new String[] { "java.util.", "java.awt.", }, ZERO_STRINGS, "java.util.List", true);
+ // checkImportMatch("*List", new String[] { "java.util.", "java.awt.", }, ZERO_STRINGS, "java.awt.List", true);
+ //
+ // checkImportMatch("*..List", new String[] { "java.util." }, ZERO_STRINGS, "java.util.List", true);
+ // checkImportMatch("*..List", new String[] { "java.util." }, ZERO_STRINGS, "java.awt.List", true);
+ //
+ // }
+ //
+ // public void testImportMatchWithInners() {
+ // // checkImportMatch("*Entry", new String[] { "java.util.", "java.util.Map$" }, ZERO_STRINGS, "java.util.Map$Entry", true);
+ // //
+ // // checkImportMatch("java.util.Map.*Entry", ZERO_STRINGS, ZERO_STRINGS, "java.util.Map$Entry", true);
+ // //
+ // // checkImportMatch("*Entry", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", false);
+ // //
+ // // checkImportMatch("*.Entry", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", true);
+ // //
+ // // checkImportMatch("Map.*", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", true);
+ //
+ // checkImportMatch("Map.*", ZERO_STRINGS, new String[] { "java.util.Map" }, "java.util.Map$Entry", true);
+ // }
+ //
+ // private void checkImportMatch(String wildPattern, String[] importedPackages, String[] importedNames, String matchName,
+ // boolean shouldMatch) {
+ // WildTypePattern p = makeResolvedWildTypePattern(wildPattern, importedPackages, importedNames);
+ // checkPatternMatch(p, matchName, shouldMatch);
+ // }
+ //
+ // private WildTypePattern makeResolvedWildTypePattern(String wildPattern, String[] importedPackages, String[] importedNames) {
+ // WildTypePattern unresolved = (WildTypePattern) new PatternParser(wildPattern).parseTypePattern();
+ //
+ // WildTypePattern resolved = resolve(unresolved, importedPackages, importedNames);
+ // return resolved;
+ //
+ // }
+ //
+ // private WildTypePattern resolve(WildTypePattern unresolved, String[] importedPrefixes, String[] importedNames) {
+ //
+ // TestScope scope = makeTestScope();
+ // scope.setImportedPrefixes(importedPrefixes);
+ // scope.setImportedNames(importedNames);
+ // return (WildTypePattern) unresolved.resolveBindings(scope, Bindings.NONE, false, false);
+ // }
+ //
+
+ //
+ // public void testInstanceofMatch() {
+ //
+ // checkInstanceofMatch("java.lang.Object", "java.lang.Object", FuzzyBoolean.YES);
+ //
+ // checkIllegalInstanceofMatch("java.lang.Object+", "java.lang.Object");
+ // checkIllegalInstanceofMatch("java.lang.Object+", "java.lang.String");
+ // checkIllegalInstanceofMatch("java.lang.String+", "java.lang.Object");
+ // checkIllegalInstanceofMatch("java.lang.*", "java.lang.Object");
+ // checkInstanceofMatch("java.lang.Integer", "java.lang.String", FuzzyBoolean.NO);
+ //
+ // checkInstanceofMatch("java.lang.Number", "java.lang.Integer", FuzzyBoolean.YES);
+ // checkInstanceofMatch("java.lang.Integer", "java.lang.Number", FuzzyBoolean.MAYBE);
+ //
+ // checkIllegalInstanceofMatch("java..Integer", "java.lang.Integer");
+ //
+ // checkInstanceofMatch("*", "java.lang.Integer", FuzzyBoolean.YES);
+ //
+ // }
+ //
+ // public void testArrayMatch() {
+ // checkMatch("*[][]", "java.lang.Object", false);
+ // checkMatch("*[]", "java.lang.Object[]", true);
+ // checkMatch("*[][]", "java.lang.Object[][]", true);
+ // checkMatch("java.lang.Object+", "java.lang.Object[]", true);
+ // checkMatch("java.lang.Object[]", "java.lang.Object", false);
+ // checkMatch("java.lang.Object[]", "java.lang.Object[]", true);
+ // checkMatch("java.lang.Object[][]", "java.lang.Object[][]", true);
+ // checkMatch("java.lang.String[]", "java.lang.Object", false);
+ // checkMatch("java.lang.String[]", "java.lang.Object[]", false);
+ // checkMatch("java.lang.String[][]", "java.lang.Object[][]", false);
+ // checkMatch("java.lang.Object+[]", "java.lang.String[][]", true);
+ // checkMatch("java.lang.Object+[]", "java.lang.String[]", true);
+ // checkMatch("java.lang.Object+[]", "int[][]", true);
+ // checkMatch("java.lang.Object+[]", "int[]", false);
+ // }
+ //
+ // private void checkIllegalInstanceofMatch(String pattern, String name) {
+ // try {
+ // TypePattern p = makeTypePattern(pattern);
+ // ResolvedType type = world.resolve(name);
+ // p.matchesInstanceof(type);
+ // } catch (Throwable e) {
+ // return;
+ // }
+ // assertTrue("matching " + pattern + " with " + name + " should fail", false);
+ // }
+ //
+ // private void checkInstanceofMatch(String pattern, String name, FuzzyBoolean shouldMatch) {
+ // TypePattern p = makeTypePattern(pattern);
+ // ResolvedType type = world.resolve(name);
+ //
+ // p = p.resolveBindings(makeTestScope(), null, false, false);
+ //
+ // // System.out.println("type: " + p);
+ // FuzzyBoolean result = p.matchesInstanceof(type);
+ // String msg = "matches " + pattern + " to " + type;
+ // assertEquals(msg, shouldMatch, result);
+ // }
+ //
+ //
+ // private TypePattern makeTypePattern(String pattern) {
+ // PatternParser pp = new PatternParser(pattern);
+ // TypePattern tp = pp.parseSingleTypePattern();
+ // pp.checkEof();
+ // return tp;
+ // }
+ //
+ // private void checkMatch(String pattern, String name, boolean shouldMatch) {
+ // TypePattern p = makeTypePattern(pattern);
+ // p = p.resolveBindings(makeTestScope(), null, false, false);
+ // checkPatternMatch(p, name, shouldMatch);
+ // }
+ //
+ // private void checkPatternMatch(TypePattern p, String name, boolean shouldMatch) {
+ // ResolvedType type = world.resolve(name);
+ // // System.out.println("type: " + type);
+ // boolean result = p.matchesStatically(type);
+ // String msg = "matches " + p + " to " + type + " expected ";
+ // if (shouldMatch) {
+ // assertTrue(msg + shouldMatch, result);
+ // } else {
+ // assertTrue(msg + shouldMatch, !result);
+ // }
+ // }
+ //
+ // public void testSerialization() throws IOException {
+ // String[] patterns = new String[] { "java.lang.Object", "java.lang.Object+", "java.lang.Integer", "int", "java..*",
+ // "java..util..*", "*.*.Object", "*", };
+ //
+ // for (int i = 0, len = patterns.length; i < len; i++) {
+ // checkSerialization(patterns[i]);
+ // }
+ // }
+ //
+ // /**
+ // * Method checkSerialization.
+ // *
+ // * @param string
+ // */
+ // private void checkSerialization(String string) throws IOException {
+ // TypePattern p = makeTypePattern(string);
+ // ByteArrayOutputStream bo = new ByteArrayOutputStream();
+ // ConstantPoolSimulator cps = new ConstantPoolSimulator();
+ // CompressingDataOutputStream out = new CompressingDataOutputStream(bo, cps);
+ // p.write(out);
+ // out.close();
+ //
+ // ByteArrayInputStream bi = new ByteArrayInputStream(bo.toByteArray());
+ // VersionedDataInputStream in = new VersionedDataInputStream(bi, cps);
+ // TypePattern newP = TypePattern.read(in, null);
+ //
+ // assertEquals("write/read", p, newP);
+ // }
+
+}
diff --git a/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/TypePatternTestCase.java b/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/TypePatternTestCase.java
index 4654fbd40..058bd2450 100644
--- a/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/TypePatternTestCase.java
+++ b/org.aspectj.matcher/testsrc/org/aspectj/weaver/patterns/TypePatternTestCase.java
@@ -105,15 +105,15 @@ public class TypePatternTestCase extends PatternsTestCase {
}
public void testImportMatchWithInners() {
- checkImportMatch("*Entry", new String[] { "java.util.", "java.util.Map$" }, ZERO_STRINGS, "java.util.Map$Entry", true);
-
- checkImportMatch("java.util.Map.*Entry", ZERO_STRINGS, ZERO_STRINGS, "java.util.Map$Entry", true);
-
- checkImportMatch("*Entry", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", false);
-
- checkImportMatch("*.Entry", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", true);
-
- checkImportMatch("Map.*", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", true);
+ // checkImportMatch("*Entry", new String[] { "java.util.", "java.util.Map$" }, ZERO_STRINGS, "java.util.Map$Entry", true);
+ //
+ // checkImportMatch("java.util.Map.*Entry", ZERO_STRINGS, ZERO_STRINGS, "java.util.Map$Entry", true);
+ //
+ // checkImportMatch("*Entry", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", false);
+ //
+ // checkImportMatch("*.Entry", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", true);
+ //
+ // checkImportMatch("Map.*", new String[] { "java.util.", }, ZERO_STRINGS, "java.util.Map$Entry", true);
checkImportMatch("Map.*", ZERO_STRINGS, new String[] { "java.util.Map" }, "java.util.Map$Entry", true);
}