9G WebDriver – 在 JUnit4 中运行 WebDriver 测试

原文: https://javabeginnerstutorial.com/selenium/9g-webdriver-running-tests-junit4/

欢迎来到我们的 WebDriver 系列中的另一篇有趣的文章! 今天它会很有趣(可能比吃自己喜欢的巧克力要有趣得多)。

您准备好将帽子戴上戒指了吗? 如果是,那就开始吧!

展望未来,我们所有的测试都将使用 JUnit 框架。 因此,是时候通过右键单击“项目->新建->包”(已设置 Selenium 和 junit)创建新包了。 我已将包命名为“com.blog.junitTests”。

我们的下一步是创建一个类。 右键单击“新创建的包 -> 新建 -> 类”。 给它起一个名字“FirstJunitTest.java”,然后单击“完成”。 您的 IDE 现在看起来应该与此类似,

JUnit implementation

现在我们已经准备好教程的文件了,让我们采用与“第一个测试脚本 – 通过启动 Firefox”帖子中相同的方案。

  1. 打开 Firefox 浏览器。
  2. 导航到“https://www.google.com/
  3. 将页面标题声明为“Google”。
  4. 根据声明结果在控制台上显示一条消息。
  5. 关闭浏览器。

选择相同方案的原因是代码说明保持不变。 无论有没有 JUnit 框架,这都将帮助您清楚地看到代码中的更改。

注意:这不是 JUnit 教程。 但是,将在需要时提供基本的解释,以使您有一个全面的了解。 有关详细和完整的信息,请参考 http://junit.org/junit4/

代码如下,

  1. package com.blog.junitTests;
  2. import org.junit.*;
  3. import org.openqa.selenium.WebDriver;
  4. import org.openqa.selenium.firefox.FirefoxDriver;
  5. public class FirstJunitTest {
  6. //Declaring variables
  7. private WebDriver driver;
  8. private String baseUrl;
  9. private String pageTitle;
  10. private String expectedTitle;
  11. @Before
  12. public void setUp() {
  13. //Selenium version 3 beta releases require system property set up
  14. System.setProperty("webdriver.gecko.driver",
  15. "E:\\Selenium\\geckodriver-v0.10.0-win64\\geckodriver.exe");
  16. // Create a new instance for the class FirefoxDriver
  17. // that implements WebDriver interface
  18. driver = new FirefoxDriver();
  19. // Assign the URL to be invoked to a String variable
  20. baseUrl = "https://www.google.com";
  21. pageTitle = "";
  22. expectedTitle = "Google";
  23. }
  24. @Test
  25. public void testPageTitle(){
  26. // Open baseUrl in Firefox browser window
  27. driver.get(baseUrl);
  28. // Get the page title and assign to a String variable
  29. pageTitle = driver.getTitle();
  30. // Check if obtained page title matches with the expected title
  31. // and print the console output accordingly
  32. if (pageTitle.equals(expectedTitle)) {
  33. System.out.println("Hello World! Result is as expected.");
  34. } else {
  35. System.out.println("Hello World! Assertion failed!");
  36. }
  37. }
  38. @After
  39. public void tearDown() throws Exception{
  40. // Close the Firefox browser
  41. driver.quit();
  42. }
  43. }

如果将此代码与实现 JUnit 之前的代码进行比较,将会有明显的变化,

  1. 注解:@Before@Test@After
  2. 方法:setUp()testPageTitle()tearDown()
  3. 类开头的私有变量声明
  4. 在新创建的方法下,将相同的代码分为几部分

这会使视力模糊吗? 不要担心! 让我们立即清除雾气!!

大字警报! 注意:这些将特定的含义传达给 JUnit。 他们告诉 JUnit,应该附加到它的public void方法,

@Test – 被当作测试方法运行。

@Before – 在指定的每种测试方法之前运行。 这用于各种目的。 读取或分配数据,初始化或如果多个测试需要先创建相似的对象才能执行,则最好在@Before注解的方法下进行指定。

@After – 在执行每种测试方法之后运行。 通常,会指定与环境清理相关的命令,例如,关闭打开的资源/数据库连接,删除临时数据,释放内存等。即使@Before@Test方法引发异常,也可以保证运行带after注解的方法。

键入这些注解,在它们下方会出现一条弯曲的线。 悬停时,Eclipse将建议所有可能的快速修复。 单击建议导入org.junit包的第一个修复程序。

JUnit import packages

在这三个注解下的方法公开的,返回类型为void。 在junit.framework.TestCase类下,我们有setUp()tearDown()方法。 最佳实践是覆盖这些方法,以分别编写初始化代码和清除代码。 这不仅可以防止内存泄漏,还可以使代码更易于阅读。 JUnit 首先调用setUp()方法,然后调用test方法,最后调用tearDown()方法。 对于附加到@Test的每个测试方法,都会发生这种情况。

要运行测试

右键单击“类 -> 运行方式 -> JUnit 测试”。

JUnit4 test execution

将打开一个新的 Firefox 浏览器窗口,并按照代码执行测试步骤。 结果将在 Eclipse IDE 的 JUnit 视图中打开,其中显示成功绿色条和错误红色条。

JUnit4 test success

显示测试用例名称。 发生错误时,将显示栈跟踪。 快捷方式可用于重新运行测试,仅显示失败,查看上一个和下一个失败的测试等。下面是显示错误的示例屏幕截图。

JUnit4 test error

我们到了这篇文章的结尾。 现在轮到您尝试一些实现 JUnit 框架的方案,并在评论部分留言,以防您遇到问题或得到澄清。

在另一个帖子中再见! 祝你今天愉快!