我正在为具有非常标准页面的应用程序编写硒测试,这些页面可以很容易地由通用结构建模为页面的基础,并且只有几种基本类型(主要是包含记录列表的列表页面,而编辑页面在其中一个可以编辑一个记录)。为了对此建模,我有以下两个类:
public abstract class AbstractListPage<E extends EditPage> extends AbstractSelfOpeningPage implements ListPage {
// Provides the specific object for the edit page when it's opened
protected abstract E editPageHook();
public E getEditPage() {
return editPageHook();
}
public E openEditPage(String key, boolean search) {
//Do page opening stuff like clicking buttons
// Return new object for the page that has been opened
return getEditPage();
}
}
// Implementation class
public class DossiersListPage extends AbstractListPage<DossierPage> {
@Override
protected DossierPage<DossiersListPage> editPageHook() {
return new DossierPage<>(driver, this);
}
}
// Usage in test, this shows an unchecked cast warning
DossierPage<DossiersListPage> dossierPage = new DossiersListPage(driver).openPage().openEditPage("3905");
我想知道是否有解决此问题的好方法,我想念的是什么?我目前没有任何问题,但是整个测试代码中的警告使我感到有些不安。
这里使用泛型的原因是,我可以在页面上对元素进行建模,以流畅的方式返回它们所属的页面:
public abstract class AbstractPageElement<P extends Page> implements PageElement<P> {
@Override
public P click() throws TimeoutException {
// Do click
return page;
}
}
// DossierPage
public class DossierPage<L extends ListPage> extends AbstractEditPage<L> {
public OrderDate<DossierPage<L>> orderDate = new OrderDate<>(driver, this);
public OrderType<DossierPage<L>> orderType = new OrderType<>(driver, this);
public Status<DossierPage<L>> status = new Status<>(driver, this);
}
// Test
dossierPage.orderDate.click()
.orderType.click()
.status.click();
我可以对这个问题进行逆向工程。在DossierPage
必须是这个样子:
public class DossierPage<E extends AbstractListPage> extends EditPage {
//...
}
所以现在我们要解决问题了。您可以通过指定更多类型参数来解决它:
public class DossiersListPage extends
AbstractListPage<DossierPage<DossiersListPage>> { // this is the tricky part
@Override
protected DossierPage<DossiersListPage> editPageHook() {
return new DossierPage<>();
}
//...
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句