当前位置: 首页 > news >正文

Selenium 中的 JUnit 注解

JUnit 是一个基于 Java 的开源框架,可帮助测试人员执行单元测试。JUnit 主要用于测试应用程序的每个单元或组件,例如类和方法。它有助于编写和运行可重复的自动化测试,以确保项目代码按预期运行。还可以使用 JUnit 执行 Selenium 自动化测试用例,以测试 Web 应用程序或网站。

JUnit 是一个基于 Java 的开源框架,可帮助测试人员执行单元测试。JUnit 主要用于测试应用程序的每个单元或组件,例如类和方法。它有助于编写和运行可重复的自动化测试,以确保项目代码按预期运行。还可以使用 JUnit 执行 Selenium 自动化测试用例,以测试 Web 应用程序或网站。

在我们开始讨论 Selenium 中的 JUnit 注解之前,让我们快速回顾一下 JUnit 在测试人员社区中流行的原因。

为什么 JUnit 在测试人员中如此受欢迎

毫无疑问,JUnit 被认为是顶级 Java 测试框架之一。以下是JUnit 之所以流行的主要原因:

  • 开源框架
  • 提供与 Eclipse、IntelliJ 等 IDE 的集成,可以快速地测试运行代码。
  • 提供与 Jenkins、Teamcity 等 CI/CD 工具的集成,以帮助创建稳定的交付管道。
  • 提供丰富的断言能力以帮助验证结果是否为预期。
  • 提供多种注解以帮助您识别测试方法的类型。
  • 提供创建测试套件的工具,该套件还包括多个测试用例甚至其他测试套件。
  • 提供 Test Runner 来轻松执行测试套件。
  • 使测试代码更易读、更优雅并提高质量。
  • 提供 HTML 格式的 JUnit 测试报告生成。

什么是 JUnit 注解

正如上面的论述,Selenium 中的 JUnit Annotations 有助于识别我们在测试代码中定义的方法类型。为了使用 JUnit 执行 Selenium WebDriver 测试,有必要在脚本中添加 JUnit Annotations。

以下是Selenium 中常见的 JUnit 注解列表:

  • @BeforeClass
  • @Before
  • @Test
  • @After
  • @AfterClass
  • @Ignore

Selenium 中用于特定目的的 JUnit 注解列表:

  • @ParameterizedTest
  • @RunWith
  • @RepeatedTest
  • @Parameters

此 JUnit 认证为那些希望通过 JUnit 推进 Selenium 自动化测试事业的人建立了测试标准。

Selenium 中的 JUnit 注解

@BeforeClass

此注解用于初始化我们在运行测试用例中使用的对象。当我们在 BeforeClass 方法中初始化任何对象时,它只会被调用一次。

@BeforeClass
    public static void SetUpClass()
    {
            System.out.println("This is @BeforeClass annotation");
    }

@Before

当我们想在使用该方法时初始化任何对象时,都会使用此注解。假设我们有 5 个测试用例,Before 方法将在每个测试方法之前被调用,总计调用 5 次。因此,每次执行测试用例时都会调用它。此注解通常用于设置测试环境。

@Before
    public void SetUp()
    {   
            System.out.println("This is @Before annotation");
    }

@Test

该注解告诉 JUnit,它所附加的 public void method() 可以作为测试用例运行。此注解包括要测试的应用程序的测试方法。单个自动化测试脚本中可能包含许多测试方法。

@Test
    public void Addition()
    {   
            c= a+b;
            assertEquals(15,c);
            System.out.println("This is first @Test annotation method= " +c);
    }
 
    @Test
    public void Multiplication()
    {   
            c=a*b;
            assertEquals(50,c);
            System.out.println("This is second @Test annotation method= " +c);
    }

@After

无论我们在 @Before 注解方法中初始化了什么对象、资源,该初始化都应该在 @After 注解方法中释放。因此,每次测试方法之后都会执行此注解。@After 注解的主要目的是删除临时数据的过程。Teardown在这里插入代码片 方法也可用于定义默认值或清除测试环境。

@After
    public void TearDown()
    {
            c= null;
            System.out.println("This is @After annotation");
    }

@AfterClass

无论我们在 @BeforeClass 注解方法中初始化了什么,该初始化都应该在 @AfterClass 注解方法中释放。所以,这个注解只执行一次,它会在所有测试执行完毕后执行。

@AfterClass
    public static void TearDownClass()
    {
            System.out.println("This is @AfterClass annotation");
    }

@Ignore

这个注解告诉 JUnit 这个方法不应该被执行。在特定测试用例中我们的代码模块没有准备好的场景中,我们可以暂时将该代码模块放在 @Ignore 注解方法中以避免测试用例失败。JUnit 4 提供了强大的报告功能来帮助您了解被忽略的测试计数以及运行的测试计数和失败的测试计数。

@Ignore
    public void IgnoreMessage()
    {
       String info = "JUnit Annotation Blog" ;
       assertEquals(info,"JUnit Annotation Blog");
       System.out.println("This is @Ignore annotation");
    }

下面是一个案例,包含了以上所有注解:

package JUnitAnnotationBlog;
 
 
import static org.junit.Assert.assertEquals;
 
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test;
 
public class JUnitAnnotations {
 
    int a=10;
    int b=5;
    Object c;
    
    
    @BeforeClass
    public static void SetUpClass()
    {
            System.out.println("This is @BeforeClass annotation");
    }
 
    
    @Before
    public void SetUp()
    {   
            System.out.println("This is @Before annotation");
    }
 
    
    @Test
    public void Addition()
    {   
            c= a+b;
            assertEquals(15,c);
            System.out.println("This is first @Test annotation method= " +c);
    }
 
    @Test
    public void Multiplication()
    {   
            c=a*b;
            assertEquals(50,c);
            System.out.println("This is second @Test annotation method= " +c);
    }
    
    
    @After
    public void TearDown()
    {
            c= null;
            System.out.println("This is @After annotation");
    }
 
    
    @AfterClass
    public static void TearDownClass()
    {
            System.out.println("This is @AfterClass annotation");
    }
    
    @Ignore
    public void IgnoreMessage()
    {
       String info = "JUnit Annotation Blog" ;
       assertEquals(info,"JUnit Annotation Blog");
       System.out.println("This is @Ignore annotation");
    }
   
 
}  

JUnit 注解的执行顺序

JUnit Annotations 的基本流程图,可帮助理解测试流程。

图片

Junit注解流程图

JUnit 中用于特定目的的注解

在前面的部分中,我们介绍了 Selenium 中最基本的 JUnit 注解。现在分享一些高级 JUnit 注解及其特定用途。

@ParameterizedTest

这个注解有点类似于@Test注解,不同的是它是用来标识参数化的测试方法。我们还可以使用@ValueSource注解在注解测试方法后提供方法参数。参数的数据类型可以是任何类型,例如字符串或整数。在下面的示例代码中,作为参数传递的 String 类型的变量data从源注解中获取一个参数。

此注解的主要目的是使用不同的参数多次运行测试。

注意:在使用这些注解之前添加以下库

org.junit.jupiter.params.ParameterizedTest
org.junit.jupiter.params.provider.ValueSource

例子:

@ParameterizedTest
    @ValueSource(strings = {"LambdaTest", "JUnit", "Annotations", "Blog"})
    void ExampleCode(String data)
    {
       assertNotNull(data);
    }

@RepeatedTest

JUnit 5 中引入的这个注解用于根据需要多次运行测试方法。测试进行的重复次数可以作为参数传递给 @RepeatedTest 注解。

例子:

@Test
@RepeatedTest(5)
public void Addition()
{   
    int a=10;
    int b=5;
    Object c; 
    
    c= a+b;
    assertEquals(15,c);
    System.out.println("This is @RepeatedTest annotation method= " +c);
}

@RunWith

当一个类被 @RunWith 注解时,JUnit 调用被注解的类来执行测试。这个注解基本上与 @SuiteClasses 注解一起运行,它指定了一组要执行的许多类。套件中的每个类在执行之前运行的类之后执行。

例子:

@RunWith(Suite.class)               
@Suite.SuiteClasses({               
  TestSample1.class,
  TestSample2.class,
  TestSample3.class,
  TestSample4.class,
  TestSample5.class,  
})      

public class JunitTest {                
            
}

@Parameters

注意:不要混淆@ParameterizedTest注解和@Parameters注解。@Parameters 注解需要 @RunWith 注解来指定测试将使用参数化运行器运行。而在 @ParameterizedTest 注解中,@ValueSource 将用作传递参数的源注解。

在使用 @Parameters 注解时,我们使用 @RunWith 注解来指定测试将使用 Parameterized Runner 运行。运行程序寻找初始化测试的方法,为测试提供值并执行测试。在下面的代码中,值集定义为使用 @Parameters 注解的列表对象数组。参数化测试是一种常见的测试,它使用测试参数一次又一次地执行。这为开发人员使用不同的输入类型执行相同的测试节省了大量时间。

@RunWith(Parameterized.class)
public class Blog1 {

   String name, password;
   
   @Parameters
   public Object[][] getData()
   {
   Object[][] info = {{"ramit1","ramitd11"}, {"ramit2","ramitd22"}};
   return info;
   }
   
   public Blog1(String id, String pass)
   {
       this.name = id;
       this.password= pass;
       
   }
    
   @Test
   public void Sample()
   {
       SampleCode.login(name, password);
   }
}

以下是上述示例中使用的SampleCode类的代码:

public class SampleCode
{
    public static void login(String name, String password)
        {
            System.out.println(“Login credentials are ”  + name + password ) ;
         }
}

Selenium 中与 JUnit 注解组合使用的属性

JUnit 中的这些测试注解具有多个可用于我们的测试方法的属性:

timeout

为每个测试用例指定超时,在@Test注解中指定timeout属性。超时时间以毫秒为单位指定。

@Test(timeout=10000)
public void ExampleCode() throws InterruptedException
{
    System.setProperty("webdriver.chrome.driver","chromedriver.exe");
            WebDriver driver = new ChromeDriver();
    driver.get("https://www.****.com");
    driver.manage().window().maximize();
    ***省略步骤细节***
    Thread.sleep(2000);  //Password
    
    driver.quit();
}

如果您想为多个测试用例设置相同的超时时间,则无需在脚本中指定的每个 @Test 注解中添加超时属性。在这种情况下可以使用 @Rule 注解来定义适用于脚本的每个 @Test 方法注解的全局超时。

例子:

@Rule
public Timeout globalTimeout = Timeout.seconds(10); //设置 10s 的全局超时

expected

这是 JUnit 4 引入的一个特殊功能,它提供了跟踪执行特定代码时预期的异常的工具。运行代码时可能会出现不同类型的异常,例如 NoSuchMethodException、ArithmeticException、IndexOutOfBoundsExceptions 等。例如,当特定数字除以零时,您希望代码发生异常,在这种情况下,需要将使用 ArithmeticException。如果没有发生异常异常,则测试执行将失败。

例子:

@Test(expected= ArithmeticException.class)
public void ExampleCode() 
  {
        int a= 10,b=0,c;
        
        c=a/b;
        
        System.out.println("Value= " +c);
}

现在我邀请你进入我们的软件测试学习交流群:746506216】,备注“入群”, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路。

喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一 键三连哦!

在这里插入图片描述

在这里插入图片描述

相关文章:

  • ES6中的set、map
  • 基python的毕业设计题目超市进存销系统
  • 云计算基础
  • C语言文件基本操作
  • 2022年全球及中国疏水阀行业头部企业市场占有率及排名调研报告
  • java6.2 springCloud
  • 第6章Linux实操篇-开机、重启和用户登录注销
  • 大学网课答案微信公众号接口使用方法
  • 第5章Linux实操篇-Vi和Vim编辑器
  • java6.1 springboot
  • Linux高性能服务器之I/O复用之实例 ET AND LT(图像理解)(14)
  • 计算机毕业设计django基于python大学生心理健康系统(源码+系统+mysql数据库+Lw文档)
  • java计算机毕业设计个性化推荐的扬州农业文化旅游管理平台源码+数据库+系统+lw文档+mybatis+运行部署
  • C#进阶03——常用泛型数据结构类
  • 第4章Linux实操篇-远程登录到Linux服务器
  • 30秒的PHP代码片段(1)数组 - Array
  • CEF与代理
  • CSS选择器——伪元素选择器之处理父元素高度及外边距溢出
  • egg(89)--egg之redis的发布和订阅
  • Essential Studio for ASP.NET Web Forms 2017 v2,新增自定义树形网格工具栏
  • js写一个简单的选项卡
  • linux安装openssl、swoole等扩展的具体步骤
  • RxJS 实现摩斯密码(Morse) 【内附脑图】
  • Spark in action on Kubernetes - Playground搭建与架构浅析
  • Vim 折腾记
  • 开发了一款写作软件(OSX,Windows),附带Electron开发指南
  • 七牛云 DV OV EV SSL 证书上线,限时折扣低至 6.75 折!
  • 异常机制详解
  • 优秀架构师必须掌握的架构思维
  • 积累各种好的链接
  • 正则表达式-基础知识Review
  • ​中南建设2022年半年报“韧”字当头,经营性现金流持续为正​
  • #常见电池型号介绍 常见电池尺寸是多少【详解】
  • (5)STL算法之复制
  • (C语言)编写程序将一个4×4的数组进行顺时针旋转90度后输出。
  • (MonoGame从入门到放弃-1) MonoGame环境搭建
  • (NO.00004)iOS实现打砖块游戏(九):游戏中小球与反弹棒的碰撞
  • (笔试题)分解质因式
  • (差分)胡桃爱原石
  • (十六)串口UART
  • (转)3D模板阴影原理
  • .[hudsonL@cock.li].mkp勒索病毒数据怎么处理|数据解密恢复
  • .NET CF命令行调试器MDbg入门(三) 进程控制
  • .NET Core/Framework 创建委托以大幅度提高反射调用的性能
  • .net php 通信,flash与asp/php/asp.net通信的方法
  • .net 开发怎么实现前后端分离_前后端分离:分离式开发和一体式发布
  • .net 写了一个支持重试、熔断和超时策略的 HttpClient 实例池
  • .NET/C# 利用 Walterlv.WeakEvents 高性能地定义和使用弱事件
  • .NET/C# 使用 SpanT 为字符串处理提升性能
  • .Net+SQL Server企业应用性能优化笔记4——精确查找瓶颈
  • .vue文件怎么使用_vue调试工具vue-devtools的安装
  • [ linux ] linux 命令英文全称及解释
  • [ 云计算 | Azure 实践 ] 在 Azure 门户中创建 VM 虚拟机并进行验证
  • [AutoSar]BSW_Com07 CAN报文接收流程的函数调用
  • [BJDCTF2020]The mystery of ip1