1

私は、の依存関係と、の依存関係をJUnit 4.11持つ推移的な依存関係を持つプロジェクトに取り組んでJMock 2.6.0-RC2JUnit-dep 4.4ます。のこの推移的な依存関係はJUnit-dep、ローカルの pom for の設定をオーバーライドしていますJUnit。オーバーライドするとは、JUnit メソッドを呼び出すときに、v4.11 ではなく v4.4 のメソッドを呼び出すことを意味します。JMockforおよび for の除外を追加しJUnit-depても、解決された依存関係には影響しませんでした。

注: JUnitJUnit-depは別個artifactIdの であるため、一方を使用しても他方が省略されることはありません。


前の質問: JUnit アノテーションが機能しない

JUnit のルールを使用してテストを実行しようとしていますが、テストを実行するExpectedExceptionと、ルールが実行されていないように見えます。以下のコードでは、ルールが存在しない場合に予想されるように、例外はそのまま通過し、テストに失敗します。

最近、プロジェクトの Maven 依存関係を 4.3.1 から 4.11 に変更しました。ワークスペースのクリーンビルドも行いました。この問題を解決するには、どのような手順を検討する必要がありますか? Maven からの推移的な依存関係はランナーを混乱させますか? どうすれば 4.11 で実行していることを確認できますか?

@Rule
public ExpectedException thrown= ExpectedException.none();

@Test
public void throwsNullPointerException() {
    thrown.expect(NullPointerException.class);
    throw new NullPointerException();
}

編集:

それが役立つかどうかはわかりませんが@RunWith(BlockJUnit4ClassRunner.class)、クラスのトップに追加すると、次のことがわかりました。

java.lang.NoSuchFieldError: NULL
    at org.junit.runners.ParentRunner.<init>(ParentRunner.java:57)
    at org.junit.runners.BlockJUnit4ClassRunner.<init>(BlockJUnit4ClassRunner.java:57)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
    at org.junit.internal.requests.ClassRequest.buildRunner(ClassRequest.java:33)
    at org.junit.internal.requests.ClassRequest.getRunner(ClassRequest.java:28)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.<init>(JUnit4TestReference.java:32)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestClassReference.<init>(JUnit4TestClassReference.java:25)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createTest(JUnit4TestLoader.java:41)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.loadTests(JUnit4TestLoader.java:31)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:452)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

編集:

Eclipse で m2e を介して依存関係を調べる: pom の [依存関係階層] タブを確認すると、左側に 1 つの解決済み依存関係(JUnit: 4.11) と複数 (4.11 との競合のため省略) のバージョンが表示されます。さらに、junit-dep 4.4の解決済み依存関係jmock-junit4: 2.6.0-RC2 ありますが、この依存関係を除外 ( Right-click + Exclude Maven Artifact...) としてマークしました。さらに、JMock 自体は、私自身の への呼び出しと競合するため、省略されているとマークされていますJMock 2.1.0

編集: Ctrl+Shift+T RunWith除外にもかかわらず、4.4 と 4.11 の 2 つのバージョンが表示されます。

編集:問題 を「修正」した依存関係を追加しjunit-dep 4.10、最終的に4.4バージョンの作成に関する問題を省略しました。しかし、これは解決策というよりハックのようです。

4

1 に答える 1

0

ビルド パスのどこかにまだ JUnit 4.3 (または少なくとも 4.5 より前) があるようです。詳細について は、Spring で jUnit テストを実行しようとすると NoSuchFieldError を参照してください。

于 2013-07-10T06:48:55.457 に答える