对于我的一个项目,我试图摆脱基于字符串的单元测试;我现在作为目标的一门课是ParsingResult
。
我已经成功地用自定义AssertJ断言转换了另一个类,所以我现在正在尝试为我的下一个“受害者”编写一个自定义断言类。课程是这样的:
public final class ParsingResultAssert<V>
extends AbstractAssert<ParsingResultAssert<V>, ParsingResult<V>>
{
private ParsingResultAssert(final ParsingResult<V> actual)
{
super(actual, ParsingResult.class);
}
public static <E> ParsingResultAssert<E> assertResult(
final ParsingResult<E> actual)
{
return new ParsingResultAssert<E>(actual);
}
}
为了对其进行测试,我尝试将其插入到我最终要删除的测试文件中:
public abstract class ParboiledTest<V> {
public class TestResult<V> {
public final ParsingResult<V> result;
private final ParsingResultAssert<V> resultAssert;
public TestResult(ParsingResult<V> result) {
this.result = result;
resultAssert = ParsingResultAssert.assertResult(result); // HERE
}
// rest is not relevant
在标记的行中HERE
,它失败了:
java.lang.ClassCastException
at java.lang.Class.cast(Class.java:2999)
at org.assertj.core.api.AbstractAssert.<init>(AbstractAssert.java:63)
at com.github.parboiled1.grappa.assertions.ParsingResultAssert.<init>(ParsingResultAssert.java:13)
at com.github.parboiled1.grappa.assertions.ParsingResultAssert.assertResult(ParsingResultAssert.java:19)
at org.parboiled.test.ParboiledTest$TestResult.<init>(ParboiledTest.java:42)
[...]
堆栈跟踪的最后一行是这一行:
resultAssert = ParsingResultAssert.assertResult(result);
这org.assertj.core.api.AbstractAssert.<init>(AbstractAssert.java:63)
是:
// we prefer not to use Class<? extends S> selfType because it would force inherited
// constructor to cast with a compiler warning
// let's keep compiler warning internal (when we can) and not expose them to our end users.
@SuppressWarnings("unchecked")
protected AbstractAssert(A actual, Class<?> selfType) {
myself = (S) selfType.cast(this); // <-- THIS ONE
this.actual = actual;
info = new WritableAssertionInfo();
}
但我迷路了;我无法理解为什么会发生这种情况。我已经成功编写了两个自定义断言(here和here),但这是我第一次看到这个错误;这里唯一的区别是我尝试为其创建断言类的类有一个类型参数。
我错过了什么?