• Selenium Video Tutorials

Selenium - Allure



Allure 可用于创建详细的自动化测试报告。它是一个开源框架,可以与 Selenium 测试集成并用于报告目的。

创建 Allure 报告的先决条件

在系统中安装 Java(版本高于 8)并使用命令检查它是否存在:java -version。如果安装成功完成,则将显示已安装的 Java 版本。可以使用链接 Java 下载 下载和安装 Java。

要了解更多关于 Java 设置的知识,请参阅以下链接 -

https://www.youtube.com/watch?v=bxIZ1GVWYkQ.

在系统中安装 Maven 并使用命令检查它是否存在:mvn -version。如果安装成功完成,则将显示已安装的 Maven 版本。可以使用链接 Apache Maven 下载和安装 Maven。

要了解更多关于 Maven 设置的知识,请参阅链接 Maven 环境搭建

安装 IntelliJ。要了解更多关于 IntelliJ 设置的知识,请参阅链接 Selenium IntelliJ

创建 Allure 报告的步骤

步骤 1 - 创建一个 Maven 项目,并将以下项目的依赖项添加到 pom.xml 文件中 -

  • 从链接 TestNG 添加 TestNG 依赖项。

  • 从链接 Selenium Java 添加 Selenium Java 依赖项

  • 从链接 Allure TestNG 添加 Allure TestNG 依赖项

  • 保存包含所有依赖项的 pom.xml 并更新 Maven 项目。

步骤 2 - 在系统中下载 Allure。对于 Mac 和 Linux,运行命令:brew install allure。如果系统中安装了 Homebrew,则此命令应该可以工作。对于 Windows,运行命令:scoop install allure。如果系统中安装了 Scoop,则此命令应该可以工作。使用命令检查 Allure 是否存在:allure –version。如果安装成功完成,则将显示已安装的 Allure 版本。

步骤 3 - 创建一个 TestNG 测试类,并注意以下示例。在欢迎页面上点击新建用户按钮

Selenium Allure 1

点击新建用户后,我们将进入注册页面,页面上显示欢迎,注册文本,如下面的图片所示。

Selenium Allure 2

代码实现

package Report;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.testng.annotations.*;
import java.util.concurrent.TimeUnit;
import static org.testng.Assert.assertEquals;

public class AllureTest {

   WebDriver driver;
   @BeforeTest
   public void setup(@Optional String browser) throws Exception{

      // Initiate browser driver
      driver = new ChromeDriver();
	  
      // adding implicit wait of 12 secs
      driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
	  
      // Opening the webpage
      driver.get("https://tutorialspoint.com/selenium/practice/login.php");
   }
   @Test(priority = 1)
   public void verifyWelcomePageHeading() {
   
      // identify header then get text
      WebElement header = driver.findElement
         (By.xpath("//*[@id='signInForm']/h1"));
      String text = header.getText();
	  
      // assertion to verify login page header
      assertEquals("Welcome, Login In", text);
   }
   @Test(priority = 2)
   public void moveToRegisterPage() {
   
      // identify button then click
      WebElement btn = driver.findElement
         (By.xpath("//*[@id='signInForm']/div[3]/a"));
      btn.click();
   }
   @Test(priority = 3)
   public void verifyRegisterPageHeading() {
   
      // identify header then get text
      WebElement heder = driver.findElement
         (By.xpath("//*[@id='signupForm']/h1"));
      String text = heder.getText();
	  
      // assertion to verify register page header
      assertEquals("Welcome,Register", text);
   }

   @AfterTest
   public void teardown() {
   
      // quitting browser
      driver.quit();
   }
}

testng.xml 文件中的配置。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="All Test Suite">
   <test verbose="2" preserve-order="true" name="AllureTest.java">
      <classes>
         <class name="Report.AllureTest">
            <methods>
               <include name="verifyWelcomePageHeading"/>
               <include name="moveToRegisterPage"/>
               <include name="verifyRegisterPageHeading"/>
            </methods>
         </class>
      </classes>
   </test>
</suite>

pom.xml 文件中的依赖项。

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>org.example</groupId>
   <artifactId>SeleniumJava</artifactId>
   <version>1.0-SNAPSHOT</version>
   
   <properties>
      <maven.compiler.source>16</maven.compiler.source>
      <maven.compiler.target>16</maven.compiler.target>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
   </properties>
   
   <!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-java -->
   <dependencies>
      <dependency>
         <groupId>org.seleniumhq.selenium</groupId>
         <artifactId>selenium-java</artifactId>
         <version>4.11.0</version>
      </dependency>
      
      <!-- https://mvnrepository.com/artifact/org.testng/testng -->
      <dependency>
         <groupId>org.testng</groupId>
         <artifactId>testng</artifactId>
         <version>7.9.0</version>
         <scope>test</scope>
      </dependency>
      
      <!-- https://mvnrepository.com/artifact/io.qameta.allure/allure-testng -->
      <dependency>
         <groupId>io.qameta.allure</groupId>
         <artifactId>allure-testng</artifactId>
         <version>2.25.0</version>
      </dependency>
   </dependencies>
</project>

以上实现的项目结构如下图所示 -

Selenium Allure 3

步骤 4 - 使用 testng.xml 运行测试。

它将显示以下输出 -

===============================================
All Test Suite
Total tests run: 3, Passes: 3, Failures: 0, Skips: 0
===============================================
Process finished with exit code 0

我们使用了 TestNG 框架来设计测试并获取页面标题,最后对其进行验证。

控制台中的结果显示总共运行的测试:3,因为有三个带有 @Test 注解的方法 - verifyWelcomePageHeading()、moveToRegisterPage() 和 verifyRegisterPageHeading()。

最后,收到消息通过:3进程已完成,退出代码为 0,表示代码执行成功。

步骤 5 - 刷新项目文件夹,一个名为allure-results的新文件夹应该会生成。

Selenium Allure 4

步骤 6 - 从项目文件夹位置运行命令:allure serve。这里,项目文件夹名称为 Selenium Java。运行命令后,服务器启动,同时 Allure 报告将在浏览器中打开,总测试方法(或用例)数为 3,通过率为 100%。

Selenium Allure 5

点击左侧的套件选项卡,我们将获得有关测试方法 moveToRegisterPage()、verifyPageHeading() 和 verifyWelcomePageHeading() 的执行持续时间及其结果的信息。

Selenium Allure 6

切换到左侧的图表选项卡,我们将获得有关状态、严重性、持续时间等的所有信息。

Selenium Allure 7

结论

这总结了我们对 Selenium Allure 教程的全面介绍。我们从描述 Allure 报告、设置 Allure 报告的先决条件开始,并逐步演示了如何使用示例创建 Allure 报告,说明了如何将其与 Selenium 一起使用。这使您能够深入了解 Allure。明智的做法是不断练习您所学到的知识,并探索与 Selenium 相关的其他内容,以加深您的理解并扩展您的视野。

广告