2

Jmockit を使用してコードをジャントし、Eclipse でコード カバレッジ用の Eclemma プラグインを使用しています。なんらかの理由で、私は報道を得るために阿部ではありません。PowerMock を使用する他のプロジェクトである Eclemma は、コード カバレッジが良好であることを示しています。しかし、Jmockit には問題があるようです。

以下は例外です。

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at sun.instrument.InstrumentationImpl.loadClassAndStartAgent(InstrumentationImpl.java:323)
    at sun.instrument.InstrumentationImpl.loadClassAndCallAgentmain(InstrumentationImpl.java:348)
Caused by: java.lang.UnsupportedOperationException: class redefinition failed: attempted to change the schema (add/remove fields)
    at sun.instrument.InstrumentationImpl.redefineClasses0(Native Method)
    at sun.instrument.InstrumentationImpl.redefineClasses(InstrumentationImpl.java:150)
    at mockit.internal.RedefinitionEngine.redefineMethods(RedefinitionEngine.java:245)
    at mockit.internal.RedefinitionEngine.redefineMethods(RedefinitionEngine.java:239)
    at mockit.internal.RedefinitionEngine.redefineMethods(RedefinitionEngine.java:166)
    at mockit.internal.RedefinitionEngine.setUpStartupMock(RedefinitionEngine.java:132)
    at mockit.internal.startup.JMockitInitialization.setUpInternalStartupMock(JMockitInitialization.java:55)
    at mockit.internal.startup.JMockitInitialization.loadInternalStartupMocksForJUnitIntegration(JMockitInitialization.java:38)
    at mockit.internal.startup.JMockitInitialization.initialize(JMockitInitialization.java:25)
    at mockit.internal.startup.Startup.initialize(Startup.java:68)
    at mockit.internal.startup.Startup.agentmain(Startup.java:62)
    ... 6 more
5 Dec, 2014 6:40:44 PM com.nn.ood.common.props.PropertyReader
WARNING: No configuration file(s) found for application ca and layer be.
Agent failed to start!
Exception in thread "Attach Listener" 
4

1 に答える 1

4

次の解決策は私のために働いた:

  1. jmockit のバージョンを 1.9 にアップグレードしました。バージョン 1.9 以降、グループ ID が「com.googlecode.jmockit」から「org.jmockit」に変更されたことに注意してください。
  2. pomのjunitの前にjmockit依存関係を配置してください

pom.xml の依存関係は次のようになります。

      <dependency>
        <groupId>org.jmockit</groupId>
        <artifactId>jmockit</artifactId>
      </dependency>
      <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
      </dependency>
于 2014-12-10T05:33:40.613 に答える