Опять, как в моем другом ответе , общее замечание: зачем вам проверять такую вещь? И если вы протестируете его, я бы предпочел интегрировать проверки типа stati c в процесс компиляции (или посткомпиляции). В идеале, компилятор должен выдавать ошибку, если такой контракт нарушен.
В любом случае, для чего бы это ни стоило, вы можете сделать это (и классы приложений, и тестовые классы являются логическими продолжениями моего MCVE в другом ответе):
package de.scrum_master.stackoverflow.q61032514;
public class TaskItem {}
package de.scrum_master.stackoverflow.q61032514;
public class TreeTableCell<A, B> {}
package de.scrum_master.stackoverflow.q61032514;
import java.time.LocalDate;
public class DueDateEditor extends TreeTableCell<TaskItem, LocalDate> {
String text;
public boolean isEmpty() {
return text == null || text.trim() == "";
}
public void startEdit() {
if (!isEmpty())
callSuperStartEdit();
}
public void callSuperStartEdit() {}
}
Теперь проходит следующий тест:
package de.scrum_master.stackoverflow.q61032514
import spock.lang.Specification
import java.lang.reflect.ParameterizedType
import java.time.LocalDate
class DueDateEditorTest extends Specification {
def "test generic type arguments for DueDateEditor"() {
given:
def superclass = DueDateEditor.superclass
def genericSuperclass = DueDateEditor.genericSuperclass
expect:
superclass == TreeTableCell
genericSuperclass instanceof ParameterizedType
genericSuperclass.actualTypeArguments == [TaskItem, LocalDate]
// Or, if you want to avoid the underlined 'actualTypeArguments' in your IDE:
// (genericSuperclass as ParameterizedType).actualTypeArguments == [TaskItem, LocalDate]
}
}
Если вы изменяете тестируемый класс на DueDateEditor extends TreeTableCell
, тест не проходит так:
Condition not satisfied:
genericSuperclass instanceof ParameterizedType
| | |
| false interface java.lang.reflect.ParameterizedType
class de.scrum_master.stackoverflow.q61032514.TreeTableCell (java.lang.Class)
Если вы переключитесь на что-то вроде DueDateEditor extends TreeTableCell<String, LocalDate>
, он потерпит неудачу так:
genericSuperclass.actualTypeArguments == [TaskItem, LocalDate]
| | | | |
| | | | class java.time.LocalDate
| | | class de.scrum_master.stackoverflow.q61032514.TaskItem
| | false
| [<java.lang.Class@192d43ce cachedConstructor=null newInstanceCallerCache=null name=java.lang.String reflectionData=java.lang.ref.SoftReference@54709809 classRedefinedCount=0 genericInfo=sun.reflect.generics.repository.ClassRepository@2a2da905 enumConstants=null enumConstantDirectory=null annotationData=java.lang.Class$AnnotationData@24f360b2 annotationType=null classValueMap=[java.lang.ClassValue$Identity@39c0f4a:java.lang.ClassValue$Entry@60cf80e7]>, <java.lang.Class@38e79ae3 cachedConstructor=null newInstanceCallerCache=null name=java.time.LocalDate reflectionData=java.lang.ref.SoftReference@302fec27 classRedefinedCount=0 genericInfo=sun.reflect.generics.repository.ClassRepository@770d0ea6 enumConstants=null enumConstantDirectory=null annotationData=null annotationType=null classValueMap=[java.lang.ClassValue$Identity@39c0f4a:java.lang.ClassValue$Entry@48c40605]>]
de.scrum_master.stackoverflow.q61032514.TreeTableCell<java.lang.String, java.time.LocalDate>
Или если вы хотите лучше сравнить списки в ошибке сообщение, вы можете использовать toList()
следующим образом:
genericSuperclass.actualTypeArguments.toList() == [TaskItem, LocalDate]
// Or, if you want to avoid the underlined 'actualTypeArguments' in your IDE:
//(genericSuperclass as ParameterizedType).actualTypeArguments.toList() == [TaskItem, LocalDate]
Тогда последнее сообщение об ошибке изменится на:
Condition not satisfied:
genericSuperclass.actualTypeArguments.toList() == [TaskItem, LocalDate]
| | | | | |
| | | | | class java.time.LocalDate
| | | | class de.scrum_master.stackoverflow.q61032514.TaskItem
| | | false
| | [class java.lang.String, class java.time.LocalDate]
| [<java.lang.Class@192d43ce cachedConstructor=null newInstanceCallerCache=null name=java.lang.String reflectionData=java.lang.ref.SoftReference@60cf80e7 classRedefinedCount=0 genericInfo=sun.reflect.generics.repository.ClassRepository@302fec27 enumConstants=null enumConstantDirectory=null annotationData=java.lang.Class$AnnotationData@770d0ea6 annotationType=null classValueMap=[java.lang.ClassValue$Identity@39c0f4a:java.lang.ClassValue$Entry@48c40605]>, <java.lang.Class@2d2ffcb7 cachedConstructor=null newInstanceCallerCache=null name=java.time.LocalDate reflectionData=java.lang.ref.SoftReference@54107f42 classRedefinedCount=0 genericInfo=sun.reflect.generics.repository.ClassRepository@1b11ef33 enumConstants=null enumConstantDirectory=null annotationData=null annotationType=null classValueMap=[java.lang.ClassValue$Identity@39c0f4a:java.lang.ClassValue$Entry@476aac9]>]
de.scrum_master.stackoverflow.q61032514.TreeTableCell<java.lang.String, java.time.LocalDate>