我正试图实现第一个Zats测试,但由于缺少Spring依赖注入而陷入困境。
带有下面代码片段的测试变为绿色,但永远不会调用doAfterComment。似乎向zul页面中注入的控制器不起作用。将应用="${teamsPopupCtrl}"更改为完全限定的名称,控制器将被使用,但teamService为空,并且当从doAfterComment调用teamService.findAll()时,我得到了一个NullPointerExcture。所以似乎没有东西被注射。
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
我不能再详细说明了。
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;
}
}
有没有人知道如何使用依赖注入进行测试,或者知道我在测试设置中缺少了什么?
我认为这可能与您的ZATS环境设置有关。
知道ZATS实际上使用Jetty来运行您的应用程序,因为它需要运行应用程序中的“真实”组件来运行这些测试。因此,必须按照运行应用程序的方式设置ZATS。
在你的测试设置代码中,我看到你只打电话
Zats.init("./src/main/webapp/WEB-INF/pages/schemaOverview");
如果这是您所做的唯一设置,那么ZATS将使用自己的web.xml
您可以检查此文档以设置ZATS加载web。xml
自定义测试环境
问题内容: 我是AngularJS的新手,正在学习编写控制器函数的两种样式。似乎某人不使用显式注释的唯一原因是节省时间,这似乎不是一个好理由。能够最小化/混淆代码似乎是我想要保留在任何应用程序中的要求。 另请注意,我并不是在问哪个更好,也不是在辩论。我在问什么原因(或在什么情况下) 不 使用显式注释会更有利。 我正在谈论的示例: 与 问题答案: 该直列排列注释是简单地在Java脚本限制的解决办法,
我在试着用Kotlin的micronaut。我有这个: 我写了以下控制器测试: 但是测试失败,出现。 我已经对此进行了调试,在测试期间,从我所知的情况来看,在中没有找到限定符的bean。当我使用类启动应用程序时,我可以看到它找到并使路由可用。 这几乎是微型机器人的Hello世界,我不确定这里出了什么问题。
我有控制器 我有一个控制器的组件 我还对我的控制器进行了测试。 当控制器调用。我得到一个。虽然我知道可以将添加到构造函数中,但我想知道是否有必要使用字段来实现这一点。如何确保字段注释在我的测试中有效?
英文原文:http://emberjs.com/guides/testing/testing-controllers/ 单元测试方案和计算属性与之前单元测试基础中说明的相同,因为Ember.Controller集成自Ember.Object。 针对控制器的单元测试使用ember-qunit框架的moduleFor来做使这一切变得非常简单。 测试控制器操作 下面给出一个PostsController
当使用mockito单元测试Spring mvc控制器时,如何注入道层对象。当使用SpringJUnit4ClassRunner类时,它总是使用@Spy注释给空指针异常。 示例代码: 在这个测试用例中,依次调用,它总是返回
什么是微控制器,为什么需要微控制器? 在阅读Arduino 文档的时候, Arduino是一款便捷灵活、方便上手的开源电子原型平台。包含硬件(各种型号的Arduino板)和软件(ArduinoIDE)。由一个欧洲开发团队于2005年冬季开发。其成员包括Massimo Banzi、David Cuartielles、Tom Igoe、Gianluca Martino、David Mellis和Nic