我正在尝试实现第一个 Zats 测试,但由于缺少 Spring 依赖注入(inject)而陷入困境。
使用下面的代码片段进行的测试会变绿,但永远不会调用doAfterCompose。看来 Controller 注入(inject)zul页面不起作用。将 apply="${teamsPopupCtrl}" 更改为完整限定名称,可以使用 Controller ,但 teamService 为空,并且当 teamService. findAll() 是从 doAfterCompose 调用的。因此,似乎没有任何内容被注入(inject)。
ApplicationContext 本身加载时没有任何错误,并使用 @Autowired private TeamService teamService; 在我的测试类中按预期进行验证。执行firstTest时,teamService不为null。
我也尝试过使用
<?variable-resolver class="org.zkoss.zkplus.spring.DelegatingVariableResolver"?>
在 zul 页面中,但这只会导致
IOException: Server returned HTTP response code: 500 for URL: http://127.0.0.1:56851/teamsPopup.zul
我无法进一步说明。
祖尔页面:
<?page id="teamsPopup" title="layout" contentType="text/html;charset=UTF-8"?>
<zk>
<window apply="${teamsPopupCtrl}" width="400px" title="Fachteams" border="normal" closable="true">
<listbox id="teamsList" multiple="true" checkmark="true" width="380px" mold="paging" pageSize="10">
<listhead><listheader label="Fachteams" /></listhead>
</listbox>
<hbox height="10px" />
<toolbar mold="panel" align="center">
<button id="btnOk" forward="onOK" label="OK" mold="trendy" height="25px" width="120px" image="./images/ok.png" />
<button forward="onClose" label="Abbruch" mold="trendy" height="25px" width="120px" image="./images/cancel.png" />
</toolbar>
</window>
</zk>
测试类:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:applicationContext/test-applicationContext.xml"})
public class TeamsPopupTest {
@BeforeClass
public static void beforeClass() throws Exception {
Zats.init("./src/main/webapp/WEB-INF/pages/schemaOverview");
}
@AfterClass
public static void afterClass() throws Exception {
Zats.end();
}
@After
public void after() throws Exception {
Zats.cleanup();
}
@Test
public void firstTest() throws Exception {
final DesktopAgent desktop = Zats.newClient().connect("/teamsPopup.zul");
}
}
Controller 类:
@Component
@Scope(value = "prototype")
public class TeamsPopupCtrl extends AbstractPopupCtrl {
private static final long serialVersionUID = -1945118180857183121L;
// ZK Autowire
Listbox teamsList;
@Autowired
@Qualifier("teamsPopupModel")
private PopupModel popupModel;
@Autowired
private TeamService teamService;
// ZK Autowire
private Listbox teamsBox;
@Override
public void doAfterCompose(final Window comp) throws Exception {
super.doAfterCompose(comp);
this.teamsList.setItemRenderer(new TeamListBoxRenderer());
this.teamsList.setModel(getFilteredTeamList());
}
public SchemaModel getSchemaModel() {
return (SchemaModel) getPerspectiveController().getCurrentPerspective().getModel();
}
@SuppressWarnings({"unchecked", "rawtypes"})
public void onOK(final Event event) {
final ListModelList<?> model = (ListModelList<?>) this.teamsList.getModel();
final List<Team> selectedTeams = new ArrayList(model.getSelection());
this.teamService.addTeamsToNodeInSchema(getSchemaModel().getCurrentNode(), selectedTeams);
this.teamsBox.setModel(new ListModelList<NodeTeamAssociation>(getSchemaModel().getCurrentNode().getNodeTeamList()));
doClosePopup();
if (!model.getSelection().isEmpty()) {
modify();
}
}
@Override
public void doOpenPopup(final org.zkoss.zul.Window window) {
super.doOpenPopup(window);
Executions.createComponents("/WEB-INF/pages/schemaOverview/teamsPopup.zul", getModel().getPopupWindow(), null);
}
private ListModelList<Team> getFilteredTeamList() {
final Collection<Team> allTeams = new ArrayList<Team>(this.teamService.findAll());
for (final NodeTeamAssociation selectedTeam : getSchemaModel().getCurrentNode().getNodeTeamList()) {
allTeams.remove(selectedTeam.getTeam());
}
return new ListModelList<Team>(allTeams);
}
protected class TeamListBoxRenderer implements ListitemRenderer<Team>, Serializable {
private static final long serialVersionUID = 8268285374821502239L;
@Override
public void render(final Listitem item, final Team teamdata, final int index) throws Exception {
final Listcell lc = new org.zkoss.zul.Listcell();
lc.setLabel(teamdata.getName());
lc.setValue(teamdata);
lc.setParent(item);
TeamsPopupCtrl.this.teamsList.setMultiple(true);
TeamsPopupCtrl.this.teamsList.setCheckmark(true);
}
}
@Override
protected PopupModel getModel() {
return this.popupModel;
}
}
有谁知道如何通过依赖注入(inject)进行测试或者我的测试设置中缺少什么?
最佳答案
我认为这可能与您的 ZATS 环境设置有关。
知道 ZATS 实际上使用 Jetty 来运行您的应用程序,因为它需要正在运行的应用程序中的“真实”组件来运行这些测试。因此,ZATS 的设置必须与您运行应用程序的方式完全相同。
在您的测试设置代码中,我看到您只调用
Zats.init("./src/main/webapp/WEB-INF/pages/schemaOverview");
如果这是您执行的唯一设置,则 ZATS 将使用其自己的 web.xml 和 zk.xml 来运行您的应用程序。我认为这就是 spring 根本不起作用的原因,因为它从未被加载过。
您可以查看此文档来设置ZATS从您想要的位置加载web.xml和zk.xml。
关于java - 为什么使用 Zats 测试 .zul 页面时 Controller 没有被注入(inject)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13154433/