- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 ZATS 测试复杂的 zk-UI。 Gui 由几个相关的 ZUL 组成,并包括动态生成的列表框,我需要测试哪些项目。这是我的 GUI 的结构:
equipmentView.zul -> ribbon.zul -> entityList.zul -> < listbox>
-> folderTree.zul -> < tree >
因此,当用户操作树项时,列表框会使用react并生成实体列表。这是我的测试:
<!-- Entity Detail List -->
<listbox name="listboxName" model="@load(dm.selectedListContent)" mold="paging" pagingPosition="bottom" autopaging="true" vflex="true" emptyMessage="No Data to show" sclass="basiclist reportList"
selectedItem="@bind(dm.selectedEntity)">
<!-- List header -->
<listhead children="@load(dm.listHeader)">
<!-- Create Header Elements -->
<template name="children" var="header">
<!-- set width of icon or releaseSessionButton fix to 50px -->
<listheader if="${header.macro or header.icon}" label="@load(header.label)" width="50px" />
<!-- width for label attributes are auto -->
<listheader if="${not header.macro and not header.icon}" label="@load(header.label)" />
</template>
</listhead>
<!-- List Content -->
<template name="model" var="node">
<listitem sclass="reportList" children="@load(dm.listHeader)" onDoubleClick="@command('moveToNextRibbonElement')">
<!-- Create List Cell foreach column -->
<template name="children" var="headerInfo">
<!-- Show Icon in Listcell -->
<listcell if="${headerInfo.icon}" iconSclass="@load(node.columnValues.get(headerInfo.name))" />
<!-- Show attribute value as label in listcell -->
<listcell if="${not headerInfo.macro and not headerInfo.icon}" visible="@load(not node.changed)" label="@load(node.columnValues.get(headerInfo.name))" />
<!-- Unsaved changed unsaved entities are to be displayed in italics -->
<listcell if="${not headerInfo.macro and not headerInfo.icon}" visible="@load(node.changed)" label="@load(node.columnValues.get(headerInfo.name))" style="font-style:italic"/>
<!-- Load macro releaseSessionButton in listcell -->
<listcell if="${headerInfo.macro}">
<!-- Load Macro -->
<releaseSessionButton currentRS="@init(sessionScope.CurrentActiveReleaseSession)" entity="@init(node.dto)" />
</listcell>
</template>
</listitem>
</template>
</listbox>
public class EquipmentViewTest extends ZatsTestBase {
/**
* logger
*/
private Logger log = LoggerFactory.getLogger(this.getClass());
private DesktopAgent equipmentView;
// selectors
private String selectNavitemSearch = "navitem[label='Search']";
private String selectNavitemMasterdata = "navitem[label='Masterdata']";
private String selectTabFolder = "tab[label='Folder']";
private String selectFolderTree = "tree[id='folderTree']";
private String selectTabFilter = "tab[label='Filter']";
private String selectEntityList = "listbox[name='listboxName']; //listbox
// zats-agents
private ComponentAgent searchAgent;
private ComponentAgent masterAgent;
private ComponentAgent folderAgent;
private ComponentAgent folderTreeAgent;
private ComponentAgent filterAgent;
private ComponentAgent listboxAgent;
/**
* Initialization:<br>
* - login;<br>
* - agents initialization and test<br>
*/
@BeforeClass
private void initEquipmentViewTest() {
log.info("Test Suit 'Equipment View Test Suit': begin");
login();
// init equipmentView.zul desktop
equipmentView = client.connect("/ModuleResource/src/main/resources/web/view/equipmentView.zul");
Assert.assertNotNull(equipmentView);
// set Agents for "Search" and "Masterdata" navitems
searchAgent = equipmentView.query(selectNavitemSearch);
Assert.assertNotNull(searchAgent);
masterAgent = equipmentView.query(selectNavitemMasterdata);
Assert.assertNotNull(masterAgent);
// set Agents for "Folder" and "Filter" navitems
folderAgent = equipmentView.query(selectTabFolder);
Assert.assertNotNull(folderAgent);
filterAgent = equipmentView.query(selectTabFilter);
Assert.assertNotNull(filterAgent);
// set agent for folder tree
folderTreeAgent = equipmentView.query(selectFolderTree);
Assert.assertNotNull(folderTreeAgent);
// agent for the entity list
listboxAgent = equipmentView.query(selectEntityList);
Assert.assertNotNull(listboxAgent);
}
/**
* Logout
*/
@AfterClass
private void finish() {
logout();
log.info("Test Suit 'Equipment View Test Suit': end");
}
/**
* Verification of list items in the entityList.zul
*/
private Boolean verifyEntityList(String message) {
String expectedEmptyMessage = "No Data to show";
Boolean empty;
// list header test
ComponentAgent listHeaderName = listboxAgent.query("listheader[label='Name']");
Assert.assertNotNull(listHeaderName);
ComponentAgent listHeaderDescr = listboxAgent.query("listheader[label='Description']");
Assert.assertNotNull(listHeaderDescr);
ComponentAgent listHeaderState = listboxAgent.query("listheader[label='State']");
Assert.assertNotNull(listHeaderState);
// empty message
String actualEmptyMessage = listboxAgent.as(Listbox.class).getEmptyMessage();
Assert.assertEquals("empty messages must be equal", expectedEmptyMessage, actualEmptyMessage);
// get all list items
List<ComponentAgent> entityList = listboxAgent.queryAll("listitem");
Assert.assertNotNull("listbox must not be null", entityList);
int numberOfItems = entityList.size();
log.info("Number of the elements = " + numberOfItems+" in "+message);
if (numberOfItems < 1) {
Assert.assertEquals("list must be empty", numberOfItems, 0);
log.info("Entity List is empty.");
empty = true;
} else {
Assert.assertTrue("list must not be empty", numberOfItems > 0);
empty = false;
// TODO test the list items
}
return empty;
}
@Test(enabled = true, groups = {"TEST_GROUP_APPROVED"})
public void testFolderNoInput() {
String selectorFolder = "tree[id='folderTree']";
// "Search"-navitem is selected
Navitem searchNavitem = searchAgent.as(Navitem.class);
Assert.assertTrue(searchNavitem.isSelected());
// "Masterdata"-navitem is not selected
Navitem masterNavitem = masterAgent.as(Navitem.class);
Assert.assertFalse(masterNavitem.isSelected());
// "Folder"-tab is selected
Tab folderTab = folderAgent.as(Tab.class);
Assert.assertTrue(folderTab.isSelected());
// "Folder"-tab is not selected
Tab filterTab = filterAgent.as(Tab.class);
Assert.assertFalse(filterTab.isSelected());
// tree items closed
List<ComponentAgent> listOfTreeitemAgents = equipmentView.query(selectorFolder).queryAll("treeitem");
for (ComponentAgent agent : listOfTreeitemAgents) {
Assert.assertEquals(1, agent.as(Treeitem.class).getVisibleItemCount());
}
// list items verification of EQ
Boolean empty = verifyEntityList("testFolderNoInput");
Assert.assertTrue("the entity list must empty", empty);
// TODO CookiesTest
}
private void openTreeTest(List<ComponentAgent> treeitems) {
Boolean empty;
for (ComponentAgent item : treeitems) {
// listitem is closed
if (item.as(Treeitem.class).getVisibleItemCount() == 1) {
item.as(OpenAgent.class).open(true);
}
Assert.assertTrue("the listitem must be opend", item.as(Treeitem.class).isOpen());
// test the entityList - opened
empty = verifyEntityList("openTreeTest:opened");
Assert.assertTrue("the entity list must be empty", empty);
// test the entityList - clicked
item.click();
verifyEntityList("openTreeTest:clicked");
// //test the entityList - clicked
// item.as(SelectAgent.class).select();
// verifyEntityList();
// get all treeitems
List<ComponentAgent> fullList = item.queryAll("treeitem");
Assert.assertNotNull("list must not be empty", fullList);
List<ComponentAgent> newTreeitems = fullList.subList(1, fullList.size());
log.info("===>" + item.as(Treeitem.class).getLabel());
if (newTreeitems.size() > 1) {
openTreeTest(newTreeitems);
}
}
}
/**
* Folder-tab test
*/
@Test(enabled = true, groups = {"TEST_GROUP_APPROVED"}, dependsOnMethods = {"testFolderNoInput"})
public void testFolder() {
// test if the tab is selected
Tab folderTab = folderAgent.as(Tab.class);
if (!folderTab.isSelected()) {
// if tab is not selected - select
folderAgent.select();
}
Assert.assertTrue("tab must be selected", folderTab.isSelected());
// get the folders
List<ComponentAgent> folders = folderTreeAgent.queryAll("treeitem");
Assert.assertNotNull(folders);
// test the tree content
openTreeTest(folders);
}
}
无法通过 id(failed-GUIexception)/name(返回无列表项)/class(测试失败)来提取这些列表项,但我需要以某种方式执行此操作。有没有机会提取动态元素?有人尝试过 ID 生成器吗?是否可以使用包含通配符的选择器查询元素?谢谢
最佳答案
所以,为了解决这个问题,我刚刚实现了 IDGenerator。并使用 TAG_COUNTER 作为 zk 组件和没有 id 的页面的 uuid。 :)))
将这段代码添加到WEB-INF中的zk.xml中
<system-config>
<id-generator-class>com.mmm.mmm.initializer.IDGenerator</id-generator-class>
</system-config>
@Override
public String nextComponentUuid(Desktop desktop, Component comp, ComponentInfo compInfo) {
// get last id
String number = (String) desktop.getAttribute(LAST_ID);
if (number == null) {
number = "0";
}
// increment last id
int counter = Integer.parseInt(number);
counter++;
// write last id back to desktop
desktop.setAttribute(LAST_ID, String.valueOf(counter));
String componentID = "";
String id = comp.getId();
String tag = null;
if(compInfo != null){
tag = compInfo.getTag();
}
// add id if known
if (id != null && !id.isEmpty()) {
componentID = componentID + id;
}
// add tag if known
if (tag != null && !tag.isEmpty()) {
if (componentID.isEmpty()) {
componentID = componentID + tag;
} else {
componentID = componentID + ":" + tag;
}
}
// add counter
if (componentID.isEmpty()) {
componentID = componentID + "zkcomp_" + counter;
} else {
componentID = componentID + ":" + counter;
}
return componentID;
}
关于java - ZATS :How to get the dynamically generated zk-Elements?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33649307/
我是 Julia 的新手。 我主要用python编程。 在 python 中, 如果你想迭代大量的值, 通常构造一个所谓的生成器来节省内存使用。 这是一个示例代码: def generator(N):
这个问题很奇怪。我试图直接在 build.gradle 中添加一个字符串,因为我需要它来使用 Tray 库 ( https://github.com/grandcentrix/tray )。在我的第一
我正在尝试在我的新 symfony3 项目中使用生成 CRUD 功能。我创建了一个名为 AdminBundle 的 bundle ,其中包含生成器、实体测试以及生成器,所有这些都处理得很好。我检查了我
我尝试理解生成器,但我发现了一个我无法遵循的示例。 // First Generator function* Colors () { yield "blue"; yield* MoreColo
我将制作一款完全由程序生成的空间/交易/战斗游戏。但是,我知道将整个星系的所有细节存储在内存中是不可行的。因此,我一直认为我可以使用种子来生成太阳系,并且从该太阳系,您可以使用跳跃门前往其他太阳系。问
我在 Eclipse Helios 中使用 MyBatis Generator (MyBatis Generator 1.3.1.201101032122),但每次我自动生成持久类时,生成器都会删除属
@GenerateInterface class A {} @GenerateInterface class B { void setA(IA a) {} } 我的注释处理器应该生成这些接口(in
我刚刚在一个空目录中安装了 yeoman,它打印出一个错误。这就是我所做的: npm i yo -g npm i generator-webapp -g 之后我抛出一个错误: require('yeo
我正在使用 NReco PDFGenerator 从 HTML 字符串创建 PDF 文档。当表格被分页符拆分时,表格标题与表格中的下一行重叠(见下图)。 有想法该怎么解决这个吗? 最佳答案 我发现这是
我有这个命名空间: namespace :manage do # Directs /manage/products/* to Manage::ProductsController
我有一个 Open API 3 规范的 yaml 文件,它有一些 x- 前缀的属性。我正在尝试使用 openapi-generator-cli 生成一个 Angular Typescript SDK。
我有一个返回生成器的函数。目前它使用yield from: function foo() { $generator = getGenerator(); // some other st
我选择Symfony2 docs 。据说添加 /** * @ORM\Entity(repositoryClass="Acme\StoreBundle\Entity\ProductRepository
运行命令生成新的 rails 项目: $ rails generate controller home index 以上将创建四个新的 Rails 项目:generate、controller、hom
我们实际上已经将jvm内存增加到了256M,现在老年代看起来很小,但Perm Generation相当高,接近80%。通过 jstat 捕获的示例数据如下。高永久代意味着什么? Timestamp
class Invoice def Invoice.generate(order_id, charge_amount, credited_amount = 0.0) Invoice.new
我在写 this comparison为了帮助人们理解所有这些废话,目前看来,generator-angular 的好处和值(value)只是您使用 generator-angular-fullsta
我有一个包含以下代码段的 OpenAPI 规范文档(我无法控制): servers: - url: http://www.[someservice].com/api 我正在使用这个 OpenAPI
我正在使用 openapi-yaml 将 swagger 文件转换为开放的 API v3 文件。使用 Maven 生成器。 我想做的是将新文件直接放入某个目录。 但是会生成一些我不需要的其他文件,例如
我的生成器中有以下标准文件夹结构。我当前正在努力解决的任务是我目前有一个模板化的 _package.json ,我将其写入磁盘以用于主要生成。我想在编写的 package.json 中包含一个变量,它
我是一名优秀的程序员,十分优秀!