前段时间介绍过UI自动化后起之秀的playwright录制脚本,那么作为UI自动化的前辈的Selenium肯定也应该具有录制脚本的功能,今天它来了就是Selenium的三大组件之一的Selenium IDE。
步骤 1: 使用 Selenium IDE 录制测试
- 安装 Selenium IDE:首先,需要在你的浏览器上安装 Selenium IDE。对于 Chrome 或 Firefox,可以从相应的扩展/插件商店下载并安装。下载插件地址:国内下载地址:https://www.crx4chrome.com/crx/77585/
- 录制测试:
- 打开 Selenium IDE。
- 创建一个新的项目,命名为 “百度测试”。
- 在浏览器点击Selenium IDE ,创建一个测试项目,并命名
- 如果选择第一个,创建好项目后就会直接让你输入地址
- 如果选择创建一个项目,不立刻录制的话就进入项目里面点击 '录制' 按钮,打开百度网站(
https://www.baidu.com
)。
- 在搜索框中输入“测试”,然后点击“百度一下”按钮。
- 记录下搜索结果页面,然后返回插件页面停止录制。
步骤 2: 导出 Python 脚本
- 导出脚本:
- 在 Selenium IDE 中,选择你刚才录制的测试用例。
- 点击 “文件”> “导出” > “选择 Python(pytest)”。
- 保存生成的 Python 脚本文件。
Python 脚本示例:导出的 Python 脚本如下所示:
# Generated by Selenium IDE
import pytest
import time
import json
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.support import expected_conditions
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
class TestBaidutest():
def setup_method(self, method):
self.driver = webdriver.Chrome()
self.vars = {}
def teardown_method(self, method):
self.driver.quit()
def test_baidutest(self):
self.driver.get("https://www.baidu.com/")
self.driver.set_window_size(1050, 652)
actions = ActionChains(self.driver)
actions.move_to_element(element).perform()
self.driver.find_element(By.ID, "kw").click()
self.driver.find_element(By.ID, "kw").send_keys("selenium")
self.driver.find_element(By.ID, "kw").send_keys(Keys.ENTER)
element = self.driver.find_element(By.CSS_SELECTOR, "section:nth-child(1) section:nth-child(3) .cover-img-boder_1-OG1")
actions = ActionChains(self.driver)
actions.move_to_element(element).perform()
步骤 3: 导出 Java 脚本并使用 TestNG
- 导出 Java 脚本:
- 重复上述 Python 脚本的导出步骤,但选择 “Java Junit)” 作为导出选项。
// Generated by Selenium IDEimport org.junit.Test;import org.junit.Before;import org.junit.After;import static org.junit.Assert.*;import static org.hamcrest.CoreMatchers.is;import static org.hamcrest.core.IsNot.not;import org.openqa.selenium.By;import org.openqa.selenium.WebDriver;import org.openqa.selenium.firefox.FirefoxDriver;import org.openqa.selenium.chrome.ChromeDriver;import org.openqa.selenium.remote.RemoteWebDriver;import org.openqa.selenium.remote.DesiredCapabilities;import org.openqa.selenium.Dimension;import org.openqa.selenium.WebElement;import org.openqa.selenium.interactions.Actions;import org.openqa.selenium.support.ui.ExpectedConditions;import org.openqa.selenium.support.ui.WebDriverWait;import org.openqa.selenium.JavascriptExecutor;import org.openqa.selenium.Alert;import org.openqa.selenium.Keys;import java.util.*;import java.net.MalformedURLException;import java.net.URL;public class BaidutestTest { private WebDriver driver; private Map<String, Object> vars; JavascriptExecutor js; @Before public void setUp() { driver = new ChromeDriver(); js = (JavascriptExecutor) driver; vars = new HashMap<String, Object>(); } @After public void tearDown() { driver.quit(); } @Test public void baidutest() { driver.get("https://www.baidu.com/"); driver.manage().window().setSize(new Dimension(1050, 652)); driver.findElement(By.id("kw")).click(); driver.findElement(By.cssSelector(".bdsug-s")).click(); { WebElement element = driver.findElement(By.cssSelector(".weather-icon")); Actions builder = new Actions(driver); builder.moveToElement(element).perform(); } driver.findElement(By.id("kw")).click(); driver.findElement(By.id("kw")).sendKeys("selenium"); driver.findElement(By.id("kw")).sendKeys(Keys.ENTER); { WebElement element = driver.findElement(By.cssSelector("section:nth-child(1) section:nth-child(3) .cover-img-boder_1-OG1")); Actions builder = new Actions(driver); builder.moveToElement(element).perform(); } }}
修改为 TestNG:
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.testng.Assert;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;
public class BaiduTest {
private WebDriver driver;
@BeforeTest
public void setUp() {
driver = new ChromeDriver();
}
@Test
public void testSearch() {
driver.get("http://www.baidu.com");
WebElement element = driver.findElement(By.name("wd"));
element.sendKeys("测试");
element.submit();
Assert.assertTrue(driver.getTitle().contains("测试"));
}
@AfterTest
public void tearDown() {
driver.quit();
}
}
- 如果不想用Junit可以将 JUnit 相关的代码部分改写为使用 TestNG。
- 示例代码可能如下:
配置 Maven 的 pom.xml:
<dependencies>
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-java</artifactId>
<version>4.1.0</version>
</dependency>
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>7.4.0</version>
<scope>test</scope>
</dependency>
</dependencies>
- 为了使用 TestNG 和 Selenium,需要在 Maven 的
pom.xml
文件中添加相应的依赖:
本次分享到此结束,录制完成剩下的也就是修修改改,删删减减,这也节省了许多时间,有什么问题大家可以一起交流
版权归原作者 是阿尘呀 所有, 如有侵权,请联系我们删除。