我有一个Selenium/Java项目,我们正在使用ExtentReports。我们使用PageFactory模型,并有一个负责所有测试准备的BasePageFactory。
前面的方法大致如下所示:
@Before
public void beforeTest() throws MalformedURLException {
this.driver = DriverBase.getDriver();
driver.manage().window().maximize();
Capabilities cap = ((RemoteWebDriver) driver).getCapabilities();
browserName = cap.getBrowserName();
ExtentReportsWrapper.startTest(getTestName(), "Browser: " + browserName + "<br>" + getDescription());
}ExtentReports的包装器负责处理报告,它是从junit TestWatcher调用的。我们还使用此方法发布“信息消息”--这是测试步骤。这些通常放在PageObject方法中--每次该方法执行手动测试人员会执行的步骤(单击、sendKeys等)。
public static void postInfoMessage(String message) {
getRunningTest().log(Status.INFO, message + ".");
}我们最近开始编写具有多个驱动程序实例打开的测试。原因是测试,例如,用户权限。我们想要在不同的情况下这样做,以避免所有的时间登录和退出,以检查权利。相反,一个用户在一个浏览器中更改权限,而另一个用户在第二个浏览器中尝试这些权限。
我这里的问题是ExtentReports,因为它们将所有步骤混合在一起,因为reports实例绑定到该BasePageFactory,而不是每个浏览器实例。
示例简单测试,其中在一个实例中创建了一个新用户,然后在另一个实例中登录:
@Test
public void run() throws ItemNotFoundException {
UserFacade userFacade = new UserFacade(driver);
UserParams userParams = new UserParams();
userParams.setLanguage(Language.ENGLISH);
UserData userData = userFacade.createNewUser(userParams); //contains multiple postInfoMessage()
WebDriver newDriver = this.getNewWebDriver();
this.loginAnotherUser(newDriver, userParams.getNick(), userParams.getPassword()); //contains multiple postInfoMessage()
this.closeWebDriver(newDriver);
userFacade.deleteUser(this.userData); //contains multiple postInfoMessage()
}正如您所看到的,报告中有多个步骤被打印为信息消息,但是这些步骤被组合在一起,在真正长时间的测试中,很难判断在哪个实例中执行了哪些步骤。
UserFacade使用来自BasePageFactory的驱动程序实例,测试类对其进行了扩展。所有新实例都是通过getNewWebDriver()创建的
我看到ExtentReports提供了类似子节点的东西,但是我还没有找到很多关于它们的信息,也没有提供任何可用的解决方案。我很感谢你的帮助。
发布于 2018-04-09 07:47:50
我有一个简单的例子,用于学习区段报告(但不太成功)。也许会有帮助..。
ExtentReports extent = new ExtentReports(Use your config);
ExtentTest test = extent.startTest("Hello","Yeah");
extent.loadConfig(ExtentReports.class, "extent-config.xml");
test.log(LogStatus.PASS, "Before Step details");
ExtentTest child1 = extent.startTest("Child 1");
child1.log(LogStatus.INFO, "Info");
child1.log(LogStatus.PASS, "Pass");
ExtentTest child2 = extent.startTest("Child 2");
child2.log(LogStatus.INFO, "Info");
child2.log(LogStatus.PASS, "Pass");
test.appendChild(child1).appendChild(child2);
test.log(LogStatus.PASS, "After Step details");
extent.endTest(test);
extent.flush();
extent.close();生成的报告,您可以看到子节点消息是单独添加的。

https://stackoverflow.com/questions/49727221
复制相似问题