bombed tests for resolve in multiple modules (IDEA-58042)
authorpeter <peter@jetbrains.com>
Thu, 12 Feb 2015 13:56:21 +0000 (14:56 +0100)
committerpeter <peter@jetbrains.com>
Thu, 12 Feb 2015 13:58:00 +0000 (14:58 +0100)
java/java-tests/testSrc/com/intellij/codeInsight/MultipleModuleHighlightingTest.groovy [new file with mode: 0644]

diff --git a/java/java-tests/testSrc/com/intellij/codeInsight/MultipleModuleHighlightingTest.groovy b/java/java-tests/testSrc/com/intellij/codeInsight/MultipleModuleHighlightingTest.groovy
new file mode 100644 (file)
index 0000000..05a14ef
--- /dev/null
@@ -0,0 +1,101 @@
+/*
+ * Copyright 2000-2015 JetBrains s.r.o.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package com.intellij.codeInsight
+
+import com.intellij.idea.Bombed
+import com.intellij.openapi.module.JavaModuleType
+import com.intellij.openapi.roots.ModuleRootModificationUtil
+import com.intellij.testFramework.PsiTestUtil
+import com.intellij.testFramework.fixtures.JavaCodeInsightFixtureTestCase
+/**
+ * @author peter
+ */
+class MultipleModuleHighlightingTest extends JavaCodeInsightFixtureTestCase {
+
+  @Bombed(day = 1, month = Calendar.MARCH)
+  public void "test use original place classpath for reference type resolving"() {
+    addTwoModules()
+
+    myFixture.addFileToProject "mod1/Class2.java", '''
+public class Class2 {
+  public void m1() {}
+  public void m2() {}
+}
+'''
+
+    myFixture.addFileToProject "mod2/Class2.java", '''
+public class Class2 {
+  public void m1() {}
+}
+'''
+    myFixture.addFileToProject "mod2/Class1.java", '''
+public class Class1 {
+  public Class2 getClass2() {}
+  public Class2 class2Field;
+}
+'''
+
+    myFixture.configureFromExistingVirtualFile(myFixture.addClass("""
+class Class3 {
+  {
+    new Class1().getClass2().m2();
+    new Class1().class2Field.m2();
+  }
+}
+
+""").containingFile.virtualFile)
+    myFixture.checkHighlighting()
+  }
+
+  @Bombed(day = 1, month = Calendar.MARCH)
+  public void "test use original place classpath for new expression type resolving"() {
+    addTwoModules()
+
+    myFixture.addFileToProject "mod1/A.java", '''
+public class A {
+  public void m1();
+}
+'''
+
+    myFixture.addFileToProject "mod2/A.java", '''
+public class A {
+  public void m2() {}
+}
+'''
+    myFixture.addFileToProject "mod2/B.java", '''
+public class B extends A {
+}
+'''
+
+    myFixture.configureFromExistingVirtualFile(myFixture.addClass("""
+class Class3 {
+  {
+    new B().m1();
+    new B().<error descr="Cannot resolve method 'm2()'">m2</error>();
+  }
+}
+
+""").containingFile.virtualFile)
+    myFixture.checkHighlighting()
+  }
+
+  private void addTwoModules() {
+    def mod1 = PsiTestUtil.addModule(project, JavaModuleType.moduleType, "mod1", myFixture.tempDirFixture.findOrCreateDir("mod1"))
+    def mod2 = PsiTestUtil.addModule(project, JavaModuleType.moduleType, "mod2", myFixture.tempDirFixture.findOrCreateDir("mod2"))
+    ModuleRootModificationUtil.addDependency(myModule, mod1)
+    ModuleRootModificationUtil.addDependency(myModule, mod2)
+  }
+}