Отражающий доступ не работает в тестах в модульном (Java 9+) приложении в IntelliJ IDEA - PullRequest
0 голосов
/ 26 января 2020

У меня есть проект, в котором я использую отражающий доступ к своим классам (например, Spring, но также и другим). И все работает нормально. Теперь я попытался добавить module-info.java, и вдруг мои тесты не могут найти мой производственный код, используя отражения в IntelliJ IDEA Ultimate 2019.3 с OpenJDK 11.0.2. Я объявил свой модуль как «открытый модуль».

  • он работает нормально, когда я снова удаляю module-info.java
  • , он отлично работает, когда я запускаю тесты, которые не требуют отражающий доступ
  • работает нормально, когда я запускаю тесты с использованием Maven (насколько я могу судить)

Для воспроизведения я настроил новый проект, как описано ниже, и он все еще не работает:


Простой проект с двумя файлами:

  • src / com / stackoverflow / test / Main. java (практически любой класс)
  • test / com / stackoverflow / test / MainTest. java

MainTest.java содержит следующие два простых теста, которые оба проходят:

package com.stackoverflow.test;
imports...
public class MainTest {
    @Test
    public void testingAccess() {
        var actual = new Main();
        assertNotNull(actual);
    }

    @Test
    public void testingReflections() {
        Set<String> allClasses = new Reflections("com.stackoverflow.test", new SubTypesScanner(false)).getAllTypes();
        for (String oneClass : allClasses) {
            System.out.println(oneClass);
        }
        assertEquals(2, allClasses.size());
    }
}

Когда я теперь добавляю src/module-info.java со следующим содержимым, второй тест testingReflections() не выполняется в IntelliJ IDEA, потому что он находит только «MainTest».

open module com.stackoverflow.test {
    exports com.stackoverflow.test;
}

Как включить рефлексивный доступ в моих тестах к моему производственному коду в IDEA?


Выполненная команда выглядит примерно так:

/Library/Java/JavaVirtualMachines/openjdk-11.0.2.jdk/Contents/Home/bin/java -ea -Didea.test.cyclic.buffer.size=1048576 "-javaagent:/Applications/IntelliJ IDEA.app/Contents/lib/idea_rt.jar=56350:/Applications/IntelliJ IDEA.app/Contents/bin" --patch-module com.stackoverflow.module=out/test/ModuleInfoTest --add-reads com.stackoverflow.module=ALL-UNNAMED --add-opens com.stackoverflow.module/com.stackoverflow.example=ALL-UNNAMED --add-modules com.stackoverflow.module -Dfile.encoding=UTF-8 -classpath "/Applications/IntelliJ IDEA.app/Contents/lib/idea_rt.jar:/Applications/IntelliJ IDEA.app/Contents/plugins/junit/lib/junit5-rt.jar:/Applications/IntelliJ IDEA.app/Contents/plugins/junit/lib/junit-rt.jar:out/test/ModuleInfoTest:lib/junit-4.12.jar:lib/hamcrest-core-1.3.jar:lib/reflections-0.9.12.jar:lib/javassist-3.26.0-GA.jar" -p out/production/ModuleInfoTest com.intellij.rt.junit.JUnitStarter -ideVersion5 -junit4 com.stackoverflow.example.MainTest
* 1 040 * Ant ошибка примерно такая:
Found class: com.stackoverflow.example.MainTest

java.lang.AssertionError: 
Expected :2
Actual   :1
<Click to see difference>


    at org.junit.Assert.fail(Assert.java:88)
    at org.junit.Assert.failNotEquals(Assert.java:834)
    at org.junit.Assert.assertEquals(Assert.java:645)
    at org.junit.Assert.assertEquals(Assert.java:631)
    at com.stackoverflow.module/com.stackoverflow.example.MainTest.testingReflections(MainTest.java:33)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:566)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
    at com.intellij.rt.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:33)
    at com.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:230)
    at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:58)

Process finished with exit code 255

1 Ответ

0 голосов
/ 27 января 2020

Похоже, что ваш случай связан с исправлением модульной системы в 2019.3 (https://youtrack.jetbrains.com/issue/IDEA-171419), что позволяет запускать тесты с поддержкой модулей. Пожалуйста, рассмотрите следующие обходные пути:

  • экспортируйте необходимый модуль в module-info;
  • добавьте экспорт в конфигурацию Run;
  • создайте выделенный тестовый модуль со своим собственным модулем -info.

Также рассмотрите следующие вопросы: https://youtrack.jetbrains.com/issue/IDEA-222831 (файл конфигурации support module-info.test).

А вот и обсуждение по аналогичной проблеме: https://youtrack.jetbrains.com/issue/IDEA-228999

...