HamcrestでSecurityException

環境

Java 9 + JUnit 4.12でも確認

現象

JUnit 4ライブラリーに加えてhamcrest-library-1.3.jarをビルドパスに加えて1org.hamcrest.Matchersを使おうとしたところ、以下の例外が発生した。

java.lang.SecurityException: class "org.hamcrest.Matchers"'s signer information does not match signer information of other classes in the same package
    at java.base/java.lang.ClassLoader.checkCerts(Unknown Source)
    at java.base/java.lang.ClassLoader.preDefineClass(Unknown Source)
    at java.base/java.lang.ClassLoader.defineClass(Unknown Source)
    at java.base/java.security.SecureClassLoader.defineClass(Unknown Source)
    at java.base/jdk.internal.loader.BuiltinClassLoader.defineClass(Unknown Source)
    at java.base/jdk.internal.loader.BuiltinClassLoader.findClassOnClassPathOrNull(Unknown Source)
    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClassOrNull(Unknown Source)
    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(Unknown Source)
    at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(Unknown Source)
    at java.base/java.lang.ClassLoader.loadClass(Unknown Source)
    at kurukuruz.test.UnitTest.test(UnitTest.java:12)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.base/java.lang.reflect.Method.invoke(Unknown Source)
    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.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:538)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:760)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:460)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:206)
Google翻訳

クラス "org.hamcrest.Matchers"の署名者情報が、同じパッケージ内の他のクラスの署名者情報と一致しません

原因

  • JUnit 4ライブラリーのorg.hamcrest.core_1.3.0v~.jar
  • hamcrest-library-1.3.jar

の間で署名者情報が一致しないことが原因らしい。

対策

hamcrest-core-1.3.jarをダウンロードしてビルドパスに追加し、順序をJUnitライブラリーより上にする。
hamcrest-library-1.3.jarの順序はどこでもOK。

その他

ダメだった方法

参考サイトでorg.hamcrest.core_1.3.0v~.jarの名前を変えて無効化するというような意見もあったが、JUnitライブラリーがビルドエラーを起こしたので却下した。

Mavenを使っている場合

hamcrest-libraryをpom.xmlに追加し2Maven依存関係の順序をJUnitライブラリーより上にする。
 ⇒SecurityException発生……。
JUnitライブラリーをビルドパスから除去して、JUnitもpom.xmlに追加する。
 ⇒成功!

参考サイト


  1. 職場でMavenが使えないためjarをダウンロードして追加した

  2. hamcrest-coreは記述不要 (hamcrest-libraryの依存関係に含まれるため)