Testng测试框架(3)-数据驱动TestNG@DataProvider

TestNG 是一个强大的 Java 测试框架,它提供了许多高级功能,如参数化测试、依赖注入、分组等。其中,@DataProvider 是 TestNG 中一个非常有用的注解,用于为测试方法提供数据。

@DataProvider 的作用

使用 @DataProvider 注解的方法可以为测试方法提供多组数据。这样,你就可以用同一组测试逻辑来测试不同的输入数据。

如何使用 @DataProvider

  1. 创建 @DataProvider 方法

这个方法应该返回一个 Object[][] 数组,其中每个内部数组代表一组测试数据。

@DataProvider(name = "testData")
public Object[][] createData() {
    return new Object[][] {
        {"input1", "expectedOutput1"},
        {"input2", "expectedOutput2"},
        // ... 更多数据
    };
}
  1. 在测试方法中使用 @TestdataProvider 属性

在测试方法上,使用 dataProvider 属性来指定要使用的数据提供器的名称。

@Test(dataProvider = "testData")
public void testMethod(String input, String expectedOutput) {
    // ... 测试逻辑
    // 使用 input 作为输入,并验证输出是否与 expectedOutput 匹配
}

注意事项

  • @DataProvider 方法可以是静态的或非静态的。
  • 如果 @DataProvider 方法返回 null 或空数组,则不会运行任何测试。
  • 如果 @Test 方法需要特定数量的参数,则 @DataProvider 返回的每个数组也必须有相同数量的元素。

示例

下面是一个简单的示例,展示如何使用 @DataProvider

import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;

public class MyTest {

    @DataProvider(name = "addNumbers")
    public Object[][] createData() {
        return new Object[][] {
            {2, 3, 5},
            {5, 7, 12},
            {-1, 1, 0}
        };
    }

    @Test(dataProvider = "addNumbers")
    public void testAdd(int a, int b, int expectedSum) {
        int actualSum = a + b;
        assert actualSum == expectedSum;
    }
}

示例登录场景

在这个示例中,createData 方法为 testAdd 方法提供了三组数据。testAdd 方法会对每组数据进行加法运算,并验证结果是否与预期一致。
举一个登录的场景,每种不同的输入都对应了不同的提示。

import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;

public class LoginTest {
    @Test(dataProvider = "data")
    public void testLogin(String username, String password,String prompt) {
        System.out.println("如果输入" + username + " password:" + password + " 提示:" + prompt);
    }
    @DataProvider(name = "data")
    public Object[][] dataProvider1() {
        return new Object[][]{
                {"admin", "123456", "登录成功"},
                {"admin", "1234567", "密码错误"},
                {"admin1", "123456", "用户名不存在"},
                {"admin", "123456", "登录成功"},
                {"admin", "123456", "登录成功"},
                {"admin", "123456", "登录成功"},
                {"admin", "123456", "登录成功"}
        };
    }
}

在这里插入图片描述
该函数是一个Java方法,用于提供测试数据。它使用了@Test注解,并指定了dataProvider的name为daa。这意味着在使用该测试数据时,需要在@Test注解中指定name为data。该方法返回一个Object二维数组,其中每个子数组代表一组测试数据,每个子数组的第一个元素是用户名,第二个元素是密码,第三个元素是预期结果。该函数提供了七组测试数据,包括了不同的用户名、密码和预期结果的情况

import org.testng.annotations.*;

public class DataProviderExampleTest {
    @Test(dataProvider = "data")
    public void testLogin(String username, String password,String prompt) {
        System.out.println("如果输入" + username + " password:" + password + " 提示:" + prompt);
    }
    @DataProvider(name = "data")
    public Object[][] dataProvider1() {
        return new Object[][]{
               new Object[] {"admin", "123456", "登录成功"},
                new Object[]  {"admin", "1234567", "密码错误"},
                new Object[]  {"admin1", "123456", "用户名不存在"}

        };
    }

}

在这里插入图片描述

并行运行

parallel如果设置为true,则使用此数据访问接口生成的测试将并行运行,默认值为false。

 @DataProvider(name = "data",parallel = true)
    public Object[][] dataProvider1() {
        return new Object[][]{
               new Object[] {"admin", "123456", "登录成功"},
                new Object[]  {"admin", "1234567", "密码错误"},
                new Object[]  {"admin1", "123456", "用户名不存在"}

        };
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值