为了账号安全,请及时绑定邮箱和手机立即绑定

如何用不同的 csv 行循环这个测试?

如何用不同的 csv 行循环这个测试?

潇潇雨雨 2022-10-12 10:56:13
我是硒测试的初学者。我写了这段代码,它可以工作,但我需要用另一个 csv 行循环这个测试。我花了将近 10 个小时试图做到这一点。我正在尝试做的场景:网络浏览器正在打开 go to url从第一行使用 CSV 文件中的数据登录驱动程序正在重新启动并执行相同的操作,但使用 csv 文件中第二行的数据。我还尝试使用 aftermethod/afterclass 重新启动测试,但它不起作用。public class CSVdataread {    private WebDriver driver;    String baseUrl = "URL";    String CSV_file = "C:\\Users\\xxxxxxxxxxx\\Desktop\\TestData.csv";    @BeforeClass    public void openBrowser() {        System.setProperty("webdriver.chrome.driver", "C:\\Users\\xxxxxxxxxxxx\\Desktop\\webdriver\\chromedriver.exe");        driver = new ChromeDriver();        driver.navigate().to("URL");        driver.manage().timeouts().implicitlyWait(30, TimeUnit.SECONDS);    }    @Test    public void verify_Search() throws InterruptedException, IOException {        CSVReader reader = new CSVReader(new FileReader(CSV_file));        String[] cell;        while((cell = reader.readNext()) != null)             for (int i = 0; i < 1; i++) {                String name = cell[i];                String email = cell[i + 1];                String baseUrl = "http://xxxxx.xxx/xxxx/";                driver.findElement(By.xpath("//input[@id='useridFormField-inputEl']")).sendKeys(name);                driver.findElement(By.xpath("//input[@id='userpasswordFormField-inputEl']")).sendKeys(email);                {                    driver.quit();                }            }        }    } 
查看完整描述

3 回答

?
忽然笑

TA贡献1806条经验 获得超5个赞

JUnit 4 解决方案。这个会很大。。。


首先,让我们从CSVReader一些好的实践和代码可读性开始。在您的测试中,您读取 CSV 数据并在测试中使用它们。读取数据不是测试的责任。测试应该已经提供给它的所有数据。它被称为DataProvider。这个术语实际上是在TestNG测试框架中使用的,就像@user861594 建议的那样。


因此,您应该有一些东西可以为您的测试提供数据。但这已经是第 2 步了。由于您知道您将从 CSV 文件中逐行读取数据,因此您应该创建一个适当的类来从 CSV 中读取数据。


这是一个例子:


public class CSVReader {

    private static final String DEFAULT_SEPARATOR = ",";

    private BufferedReader reader;

    private List<String> lines;


    public CSVReader(File file) throws FileNotFoundException {

        this.reader = new BufferedReader(new FileReader(file));


        lines = this.reader.lines().collect(Collectors.toList());

    }


    public String[] getRow(int rowNumber) {

        return lines.get(rowNumber).split(DEFAULT_SEPARATOR);

    }


    public int getRowCount() {

        return lines.size();

    }

}

构造CSVReader函数接受 aFile作为参数并创建适当的对象以以特定方式读取数据(例如: read as String)。然后,读取 CSV 文件中的数据,就像在普通 TXT 文件中一样,将行保存在内存中以备后用。


然后我们创建2个方法。首先是getRowCount它给了我们行/数据集的总数。


其次是getRow从列表中收集特定行并将其保存到String[]数组中以备后用。


String[]数组有一个类似 1 Excel 行的演示文稿:


data index 0 | data index 1 | data index 2 | data index 3

我们有一个类可以让我们轻松读取文件。让我们创建DataProvider


为了向测试提供数据,我们需要使用@Parameters注解并返回Collection<Object[]>到我们的测试。我稍后会谈到这一点。


所以,让我们在我们的DataProvider

public class CSVDataProvider {


    public Collection<Object[]> getData() throws FileNotFoundException {

        CSVReader reader = new CSVReader(new File("C:\\Users\\xxxxxxxxxxx\\Desktop\\TestData.csv"));

        int rowCount = reader.getRowCount();

        Object[][] data = new Object[rowCount][2];


        for (int i = 0; i < rowCount; i++) {

            Object[] singleRow = reader.getRow(i);

            data[i][0] = singleRow[0];

            data[i][1] = singleRow[1];

        }


        return Arrays.asList(data);

    }

}

我假设您在 CSV 文件中只有登录名和密码。这就是我创建二维数组的原因new Object[rowCount][2]。rowCount我们通过提供它必须存储的元素数量来创建数组,并且我们知道变量中有多少行。2 表示我们每行只有 2 个数据。登录名和密码。如果你想使用额外的元素,例如 - 用户的角色,你可以修改为[3]


在for循环中,我们将数据从 CSV 文件转换为数组并将其返回以供以后使用。


现在,让我们谈谈我们的测试类。


@RunWith(Parameterized.class)

public class OurTest {

    private String login, password;


    public OurTest(String login, String password) {

        this.login = login;

        this.password = password;

    }


    @Parameterized.Parameters(name = "{index}: Login: ({0}) Password: ({1})")

    public static Collection<Object[]> data() throws FileNotFoundException {

        return new CSVDataProvider().getData();

    }


    @Test

    public void test() {

        System.out.println(String.format("login : %s | Password: %s", login, password));

    }

}

为了将参数传递DataProvider给我们的测试,我们需要 1. 用注释类@RunWith(Parameterized.class) 2. 创建一个返回 @Parameters 的方法Collection<Object[]> with annotation3. 创建一个构造函数来反映我们接受什么样的数据。


关于第 3 点,这就是为什么我用String loginand创建了一个 2 参数构造函数String password。我们正在传递这两个参数。OurTestJUnit 将为每个测试创建一个新实例并传递不同的行。


在test我刚刚打印的方法中,我们从DataProvider


我没有提供一个完全有效的解决方案,因为我希望你尝试调整你的测试来学习这种特定的方法。它也被称为Data-driven Testing。


我们只有一种测试方法,但 CSV 文件中的每一行都将作为单独的测试运行。


希望能帮助到你!


查看完整回答
反对 回复 2022-10-12
?
白板的微信

TA贡献1883条经验 获得超3个赞

看起来你想用一组测试数据迭代你的测试。在这种情况下,您应该使用 TestNG数据提供程序功能。


public class CSVdataread {

    private WebDriver driver;

    String baseUrl = "URL";

    String CSV_file = "C:\\Users\\xxxxxxxxxxx\\Desktop\\TestData.csv";


    @BeforeMethod

    public void openBrowser() {

        System.setProperty("webdriver.chrome.driver", "C:\\Users\\xxxxxxxxxxxx\\Desktop\\webdriver\\chromedriver.exe");

        driver = new ChromeDriver();

        driver.manage().timeouts().implicitlyWait(30, TimeUnit.SECONDS);

    }


    @Test(dataProvider="users-data")

    public void verify_Search(String name, String email) throws InterruptedException, IOException {

           String baseUrl = "http://xxxxx.xxx/xxxx/";

           driver.navigate().to(baseUrl);

           driver.findElement(By.xpath("//input[@id='useridFormField-inputEl']")).sendKeys(name);

           driver.findElement(By.xpath("//input[@id='userpasswordFormField-inputEl']")).sendKeys(email);

     }

     //This method will provide data to any test method that declares that its Data Provider

     @DataProvider(name = "users-data")

     public Iterator<Object[]> createDataFromCSV() {

       CSVReader reader = new CSVReader(new FileReader(CSV_file));

       List<Object[]> data = new ArrayList<Object[]>();

       //read csv data to list

       return data.iterator();

    }


    @AfterMethod

    public void closeBrowser() {

        driver.quit();

    }


 } 


您还可以利用可用的 data-provider-extension。例如,使用 qaf 您无需为驱动程序管理或数据提供者编写代码。您的测试类将如下所示:


public class CSVdataread  extends WebDriverTestCase{


    @QAFDataProvider(dataFile="resources/user-data.csv")

    @Test()

    public void verify_Search(String name, String email) throws InterruptedException, IOException {

           String baseUrl = "http://xxxxx.xxx/xxxx/";

           getDriver().navigate().to(baseUrl);

           getDriver().findElement(By.xpath("//input[@id='useridFormField-inputEl']")).sendKeys(name);

           //another way of finding element...

           getDriver().findElement("xpath=//input[@id='userpasswordFormField-inputEl']").sendKeys(email);

     }

 } 


查看完整回答
反对 回复 2022-10-12
?
HUH函数

TA贡献1836条经验 获得超4个赞

你的 while 循环看起来坏了。while 循环中的 for 循环似乎弄乱了您的登录过程。


while((cell = reader.readNext())!=null) { // iterate through csv file

  String name = cell[0]; // cell is current row, you need first column for name

  String email = cell[1]; // second column for email (as password?)

  // what do you want to do with baseUrl here?


  driver.findElement(By.xpath("//input[@id='useridFormField-inputEl']")).sendKeys(name);

  driver.findElement(By.xpath("//input[@id='userpasswordFormField-inputEl']")).sendKeys(email);


  // you need to check the successful login here

  // then logout and open main page

  // do not quit before you are finished 

}


// quit after the loop is finished

driver.quit();

如果不了解网站,就不可能告诉您如何检查成功登录和执行注销。


我可以建议您花一些精力来学习不太复杂的任务吗?您似乎在使用基本 Java 元素时遇到了很多麻烦。从未停止学习。


查看完整回答
反对 回复 2022-10-12
  • 3 回答
  • 0 关注
  • 135 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信