assertThat(dirReader.document(0).getFields(), hasItem(
new FeatureMatcher<IndexableField, String>(equalTo("Patisnummer"), "Field key", "Field key") {
@Override
protected String featureValueOf(IndexableField actual) {
return actual.name();
} } ));
java.lang.NoSuchMethodError: org.hamcrest.Matcher.describeMismatch(Ljava/lang/Object;Lorg/hamcrest/Description;)V
at org.hamcrest.FeatureMatcher.matchesSafely(FeatureMatcher.java:43)
at org.hamcrest.TypeSafeDiagnosingMatcher.matches(TypeSafeDiagnosingMatcher.java:55)
at org.hamcrest.core.IsCollectionContaining.matchesSafely(IsCollectionContaining.java:25)
at org.hamcrest.core.IsCollectionContaining.matchesSafely(IsCollectionContaining.java:14)
at org.hamcrest.TypeSafeDiagnosingMatcher.matches(TypeSafeDiagnosingMatcher.java:55)
at org.junit.Assert.assertThat(Assert.java:770)
at org.junit.Assert.assertThat(Assert.java:736)
at indexer.IndexerTest.testIndexContainsField(IndexerTest.java:152)
>
pom包含对Hamcrest-library 1.3、Hamcrest-core 1.3和JUnit 4.11(按照顺序)的显式依赖关系,正如Garrett Hall在IntelliJ 10.5中运行test时获得“nosuchmethoderror:org.hamcrest.matcher.descripmisMatch”时所建议的那样
根据JUnit文档,JUnit4.11Maven依赖项不再包括编译的Hamcrest类,而是依赖于Hamcrest-Core1.3;因此nosuchmethoderror
不应发生。
按照Dan在回答junit和hamcrest声明时的建议,用MVN dependency:tree
检查依赖关系树,将显示对hamcrest 1.3和junit 4.11的显式依赖关系,而不是对这些文件的其他依赖关系(完整的输出请参见http://db.tt/c2oftdjb)。
在另一个测试中,nosuchmethoderror
通过使用:
assertThat(
"Zylab detector not available",
d.getDetectors(),
hasItem(Matchers.<Detector>instanceOf(ZylabMetadataXmlDetector.class)));
在indexertest.java(提交ac72ce)的第120-123行中,而不是更明显的:
assertThat(
"Zylab detector not available",
d.getDetectors(),
hasItem(isA(ZylabMetadataDetector.class));
我不确定显式类型参数
是否使用instanceof
而不是isa
、显式引用Hamcrest的matchers
,或者这些参数的组合是否避免了NosuchMethodException
;在四处摆弄和尝试不同的事情后,它奏效了。
使用从basematcher
派生的类而不是featurematcher
不能解决/避免错误。
这个博客帮助我解决了同样的问题:
https://tedvinke.wordpress.com/2013/12/17/mixing-junit-hamcrest-and-mockito-explain-nosuchmethoderror/
在Mockito和Junit的依赖项中,作者添加了排除:
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<exclusions>
<exclusion>
<artifactId>hamcrest-core</artifactId>
<groupId>org.hamcrest</groupId>
</exclusion>
</exclusions>
</dependency>
问题内容: 我一直在尝试使用此处的少量指导,使用RecyclerView实现CollapsingToolbar:http : //android-developers.blogspot.co.uk/2015/05/android-design-support- library.html 和项目此处:https : //github.com/chrisbanes/cheesesquare,我目前具有
问题内容: 有一种简单的方法可以将hibernate设置为对每个带有postgres的表使用不同的主键ID。我试图在数据源中使用postgres方言: 但这是行不通的。谢谢 问题答案: 简短的答案是没有,没有 简单的 方法可以做到这一点。但是,我找到了一种有效的解决方案。基本上,您需要实现自定义方言。这是一个实现(请在注释中注明实现的原始来源)。 上述实施应当存储为下你的Grails项目中。 接下
问题内容: 我正在使用和。我知道,这两个类和是不相容的,但我仍然希望做的相当自然的事情- 我想换了每一个在每个迭代步骤一解析(嵌套内部的)。我尝试这样做: 当我尝试编译此代码时,即使看起来很自然,实际上我也会收到“不兼容的类型”错误。所以,我的问题是迭代的最佳方法是什么? 问题答案: 显然,实现了一个 原始 Iterator。这意味着每个元素都被视为。您可以尝试投射: 这就是在Java 1.4和更
我已经添加了版本 注意:我还没有迁移任何测试,所有测试都是JUnit4语法。
我有一个java类,它使用来自队列的消息,向一些URL发送HTTP调用。我已经在google和stackoverflow上做了一些搜索(如果我错过了提到这个问题的任何来源,我真的很抱歉),但是没有找到关于setRollbackOnly调用的任何细节。 我的问题是...在回滚的情况下,从队列中消耗的消息将阻塞队列的其余部分,并且将循环直到它被成功处理,或者在当前队列的末尾重新使用? 下面是我用于从队
我有一个使用JPA注释生成数据库主键的代码。一个数据库序列用于使用Oracle DB生成PK.Am 现在我对此的理解是:DB sequencer返回的sequence id作为rec_id。这是正确的吗? 医生说: 序列策略序列策略由两部分组成——定义命名序列和在一个或多个类的一个或多个字段中使用命名序列。@Sequence Generator注释用于定义序列并接受名称、初始值(默认值为1)和分配
我有一个spring mvc控制器,它生成一个“应用程序/PDF”来下载生成的PDF。我想返回的总是pdf,也返回不同的HTTP代码取决于某些条件。 我们的想法是,我希望返回输出流中的pdf,但返回不同的结果代码(200、500等)。事件当我返回500时,我想返回一个PDF。有可能吗? 任何帮助都将不胜感激。
我已经实现了帖子中的演示:Android和MJPEG 但应用程序总是在一段时间后出现错误,我得到了一个异常: