2

我正在尝试实施第一个 Zats 测试,但由于缺少 Spring 依赖注入而陷入困境。

使用下面代码片段的测试变为绿色,但doAfterCompose从未被调用。似乎控制器注入zul页面不起作用。将apply="${teamsPopupCtrl}"更改为完整的限定名称,控制器被使用,但teamService为 null 并且当从doAfterCompose调用teamService.findAll()时出现 NullPointerException 。因此,似乎没有任何东西被注入。

ApplicationContext 本身正在加载,没有任何错误,并使用@Autowired private TeamService teamService;在我的测试类中进行验证按预期工作。执行 firstTest 时,teamService 不为空。

我也尝试使用

<?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");
    }
}

控制器类:

@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;
    }
}

有谁知道如何使用依赖注入来进行测试,或者我的测试设置中缺少什么?

4

1 回答 1

2

我认为可能与您的 ZATS 环境设置有关。

知道 ZATS 实际上是使用 Jetty 来运行您的应用程序,因为它需要来自正在运行的应用程序的“真实”组件来运行这些测试。因此,必须像运行应用程序一样设置 ZATS。

在您的测试设置代码中,我看到您只调用

Zats.init("./src/main/webapp/WEB-INF/pages/schemaOverview");

如果这是你做的唯一设置,那么 ZATS 将使用它自己的web.xmlzk.xml来运行你的应用程序。我认为这就是为什么弹簧根本不起作用的原因,因为它从未被加载过。

您可以查看此文档以从您想要的位置设置 ZATS 加载web.xmlzk.xml

ZATS : 自定义测试环境

于 2012-10-31T16:21:54.220 回答