如何将数据从csv文件获取到DataProvider

时间:2019-07-12 16:39:08

标签: java jquery qa

我需要从csv.file中获取数据(用户名和密码),并使用它使用Selenium中的DataProvider注册一些新用户。我已经使Reader可以读取此文件,但是我不能正确地将此数据放入DataProvider中。请帮助我。

我创建了一种读取csv文件的方法,并与提供程序进行了测试以进行工作。

我的方法 公共静态列表用户= new ArrayList <>();

public static Object openCSVReader() throws IOException {

    CSVReader reader = new CSVReader(new FileReader(System.getProperty("user.dir") + "\\src\\test\\resources\\users.csv"), ',');

    // read line by line
    String[] record = null;

    while ((record = reader.readNext()) != null) {
        User user = new User("username", "password");
        user.setUsername(record[0]);
        user.setPassword(record[1]);
        users.add(user);
    }


    reader.close();
    return users;

}

我的测试

@Test(dataProvider = "registration")
    public void registerCSVFiles(String username, String password) throws IOException {
        registerPage.writeInForm(user);
        registerPage.writeFile(user);
        registerPage.selectUserAndRegister();
    }
}
    @DataProvider(name = "registration")
    public static Object[][] credentials() throws IOException {
        return new Object[][]{
                {users.get(0)},{users.get(1)}
        };
    }

我无法从openCSVReader中获取数据。帮助请

1 个答案:

答案 0 :(得分:0)

也许可以采用以下方法来满足您的要求。

csv文件的示例内容如下。 (users.csv)

  

user1,password1

     

user2,password2

测试类的组成如下;

@DataProvider(name = "userDetails")
public static Object[][] readCsv() throws IOException {
    CSVReader csvReader = new CSVReader(new FileReader(System.getProperty("user.dir")+"/src/test/resources/users.csv"),',');
    List<String[]> csvData=csvReader.readAll();
    Object[][] csvDataObject=new Object[csvData.size()][2];
    for (int i=0;i<csvData.size();i++) {
        csvDataObject[i]=csvData.get(i);
    }
    return  csvDataObject;
}

@Test(dataProvider = "userDetails")
public void userLoginTest(String userName,String password){
    System.out.println(userName+" "+password);
}

注意: DataProvider方法应位于测试方法所在的同一类中,或者应位于其基类中

使用的库:OpenCSV