WebDriver高级应用实例(5)
5.1对象库(UI Map)
目的:能够使用配置文件存储被测试页面上的元素的定位方式和定位表达式,做到定位数据和程序的分离。方便不具备编码能力的测试人员进行修改和配置。
被测网页的网址:
http://www.baidu.com
Java语言版本的API实例代码
首先实现ObjectMap工具类,供测试程序调用
import java.io.FileInputStream;
import java.io.IOException;
import java.util.Properties; import org.openqa.selenium.By; public class ObjectMap {
Properties properties;
public ObjectMap(String propFile){
properties = new Properties();
try {
FileInputStream in = new FileInputStream(propFile);
properties.load(in);
in.close();
} catch (IOException e) {
System.out.println("读取对象文件出错");
e.printStackTrace();
}
}
public By getLocator(String ElementNameInpropFile) throws Exception{
//根据变量ElementNameInpropFile,从属性配置文件中读取对象 String locator = properties.getProperty(ElementNameInpropFile);
//将配置文件中的值存储至locatorType及locatorValue
String locatorType = locator.split(":")[0];
String locatorValue = locator.split(":")[1];
//输出locatorType变量值和locatorValue变量值,验证是否赋值正确
System.out.println("获取的定位类型:"+locatorType+"\t获取的定位表达式"+locatorValue);
//根据localtorType的变量值内容判断返回何种定位方式的By对象
if(locatorType.toLowerCase().equals("id"))
return By.id(locatorValue);
else if(locatorType.toLowerCase().equals("name"))
return By.name(locatorValue);
else if((locatorType.toLowerCase().equals("classname")) || (locatorType.toLowerCase().equals("class")))
return By.className(locatorValue);
else if((locatorType.toLowerCase().equals("tagname")) || (locatorType.toLowerCase().equals("tag")))
return By.className(locatorValue);
else if((locatorType.toLowerCase().equals("linktext")) || (locatorType.toLowerCase().equals("link")))
return By.className(locatorValue);
else if(locatorType.toLowerCase().equals("partiallinktext"))
return By.name(locatorValue);
else if((locatorType.toLowerCase().equals("cssselector")) || (locatorType.toLowerCase().equals("css")))
return By.className(locatorValue);
else if(locatorType.toLowerCase().equals("xpath"))
return By.name(locatorValue);
else
throw new Exception("输入的locator type 未在程序中被定义:"+locatorType);
}
public static void main(String[] args) { } }
建立ObjectMap.properties存储元素表达式的资源文件
Baidu.HomePage.search = id:kw
Baidu.HomePage.button = id:su
在测试类中调用ObjectMap工具类的方法实现测试逻辑
import org.testng.annotations.Test;
import org.testng.annotations.BeforeMethod;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.support.ui.WebDriverWait;
import org.testng.Assert;
import org.testng.annotations.AfterMethod; public class testSohuMailLoginByObjectMap {
WebDriver driver;
String url = "https://www.baidu.com/";
private ObjectMap objectMap;
@Test
public void testSohuMailLogin()throws Exception {
try {
//声明一个objectMap对象实例,路径为ObjectMap的绝对路径
objectMap = new ObjectMap("E:\\project\\WebDriverAPIProj\\src\\cn\\api1\\ObjectMap.properties");
} catch (Exception e) {
System.out.println("生成ObjectMap对象失败");
}
WebDriverWait wait = new WebDriverWait(driver, 10);
//调用objectMap的getLocator方法获取元素位置
WebElement search = driver.findElement(objectMap.getLocator("Baidu.HomePage.search"));
WebElement button = driver.findElement(objectMap.getLocator("Baidu.HomePage.button"));
//在搜索框中输入要搜索的内容
search.sendKeys("selenium");
//单击搜索按钮
button.click();
//断言判断页面上是否显示了selenium
Assert.assertTrue(driver.getPageSource().contains("selenium"));
}
@BeforeMethod
public void beforeMethod() {
System.setProperty("webdriver.chrome.driver", "D:\\WebDriver\\chromedriver_win32\\chromedriver.exe");
driver = new ChromeDriver();
driver.manage().window().maximize();
driver.navigate().to(url);
} @AfterMethod
public void afterMethod() {
driver.quit();
} }
5.2操作富文本框(方法一)
目的:能定位到页面的富文本框,使用JavaScript语句实现富文本框中的HTML格式内容输入
被测网页的网址:
https://mail.sohu.com
Java语言版本的API实例代码
import org.testng.annotations.Test;
import org.testng.annotations.BeforeMethod;
import org.openqa.selenium.By;
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.support.ui.ExpectedConditions;
import org.openqa.selenium.support.ui.WebDriverWait;
import org.testng.Assert;
import org.testng.annotations.AfterMethod; public class testMailSendMail {
WebDriver driver;
String url = "https://mail.sohu.com";
@Test
public void testQQMailWriteEMail() throws InterruptedException {
//设置显示等待15秒 用于判断元素是否加载成功 防止因加载问题找不到元素
WebDriverWait wait = new WebDriverWait(driver, 15);
//使用显示等待出现用户名输出框
wait.until(ExpectedConditions.presenceOfElementLocated(By.xpath("//*[@id='theme']/form/div[1]/div[1]/input")));
//找到用户名输入框
WebElement userName = driver.findElement(By.xpath("//*[@id='theme']/form/div[1]/div[1]/input"));
//找到密码框
WebElement password = driver.findElement(By.xpath("//*[@id='theme']/form/div[2]/div[1]/input"));
//找到登录按钮
WebElement loginButton = driver.findElement(By.xpath("//*[@id='theme']/form/div[5]/input"));
//输入用户名
userName.sendKeys("******@sohu.com");
//输入密码
password.sendKeys("****");
//单击登录按钮
loginButton.click();
//显示等待写信按钮的出现
wait.until(ExpectedConditions.presenceOfElementLocated(By.xpath("//*[@id='addSkinClass']/div[4]/div/ul/li[1]")));
//找到写信按钮
WebElement writeMailButton = driver.findElement(By.xpath("//*[@id='addSkinClass']/div[4]/div/ul/li[1]"));
//单击写信按钮
writeMailButton.click();
//显示等待写信界面出现
wait.until(ExpectedConditions.presenceOfElementLocated(By.xpath("//div[@class='subject']/input")));
//找到接收人输入框
WebElement receipiets = driver.findElement(By.xpath("//*[@id='mailContent']/div/div[1]/div[1]/div[1]/div[1]/div/span/input"));
//找到主题输入框
WebElement subject = driver.findElement(By.xpath("//*[@id='mailContent']//div[@class='subject']/input"));
//输入接收人
receipiets.sendKeys("cyw894452087@sohu.com");
//选中主题框
subject.click();
//输入主题
subject.sendKeys("发给自己的测试邮件");
//跳转至富文本框的iframe中
driver.switchTo().frame("ueditor_0");
//声明JavaScriptExecutor对象来执行JavaScript脚本
JavascriptExecutor js = (JavascriptExecutor)driver;
//获取富文本框的编辑对象使用编辑对象的innerHtml属性设定任意HTML格式的文字内容
js.executeScript("document.getElementsByTagName('body')[0].innerHTML ='<b>邮件要发送的内容<b>'");
//返回默认的页面
driver.switchTo().defaultContent();
//找到发送按钮
WebElement sendMailButton = driver.findElement(By.xpath("//*[@id='mailContent']/div/div[2]/span[1]"));
//单击发送
sendMailButton.click();
Thread.sleep(1000);
//断言判断页面上是否存在发送成功
Assert.assertTrue(driver.getPageSource().contains("发送成功"));
}
@BeforeMethod
public void beforeMethod() {
System.setProperty("webdriver.chrome.driver", "D:\\WebDriver\\chromedriver_win32\\chromedriver.exe");
driver = new ChromeDriver();
driver.manage().window().maximize();
driver.get(url);
} @AfterMethod
public void afterMethod() {
driver.quit();
} }
Java语言版本的API实例代码(方法二)
import org.testng.annotations.Test;
import org.testng.annotations.BeforeMethod; import java.awt.AWTException;
import java.awt.Robot;
import java.awt.Toolkit;
import java.awt.datatransfer.StringSelection;
import java.awt.event.KeyEvent; import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.support.ui.ExpectedConditions;
import org.openqa.selenium.support.ui.WebDriverWait;
import org.testng.Assert;
import org.testng.annotations.AfterMethod; public class testSohuMailSendMail {
WebDriver driver;
String url = "https://mail.sohu.com";
@Test
public void testSendMail() throws InterruptedException {
//设置显示等待15秒
WebDriverWait wait = new WebDriverWait(driver, 15);
//显示等待用户名输入框出现后执行之后语句
wait.until(ExpectedConditions.presenceOfElementLocated(By.xpath("//input[@placeholder='请输入您的邮箱']")));
//找到用户名输入框
WebElement userName = driver.findElement(By.xpath("//input[@placeholder='请输入您的邮箱']"));
//找到密码输入框
WebElement password = driver.findElement(By.xpath("//input[@placeholder='请输入您的密码']"));
//找到登录按钮元素
WebElement loginButton = driver.findElement(By.xpath("//input[@value='登 录']"));
//输入邮箱名
userName.sendKeys("****@sohu.com");
//输入密码
password.sendKeys("****");
//单击登录
loginButton.click();
//显示等待页面跳转出现写邮件
wait.until(ExpectedConditions.presenceOfElementLocated(By.xpath("//li[text()='写邮件']")));
//找到写邮件元素
WebElement writeMailButton = driver.findElement(By.xpath("//li[text()='写邮件']"));
//单击写邮件
writeMailButton.click();
//显示等待写信窗口出现
wait.until(ExpectedConditions.presenceOfElementLocated(By.xpath("//div[@class='subject']/input")));
//找到接收方输入框元素
WebElement recipients = driver.findElement(By.xpath("//input[@class='noshadow ng-pristine ng-valid']"));
//找到主题输入框元素
WebElement subject = driver.findElement(By.xpath("//div[@class='subject']/input"));
//输入接收方邮箱
recipients.sendKeys("cyw894452087@sohu.com");
//调用函数,按下tab键跳至主题输入框
pressTabKey();
//输入主题
subject.sendKeys("发送给自己的邮件");
subject.click();
Thread.sleep(1500);
//调用函数跳转至富文本框编辑区域
pressTabKey();
Thread.sleep(1500);
//调用粘贴函数将内容粘贴至富文本框中
setAndctrlVClipboardData("邮件正文内容");
//找到发送元素
WebElement sendMailButton = driver.findElement(By.xpath("//span[text()='发送']"));
//点击发送文件
sendMailButton.click();
Thread.sleep(1500);
//断言判断页面上是否出现发送成功字样
Assert.assertTrue(driver.getPageSource().contains("发送成功"));
}
public void setAndctrlVClipboardData(String string) {
StringSelection stringSelection = new StringSelection(string);
Toolkit.getDefaultToolkit().getSystemClipboard().setContents(stringSelection, null);
Robot robot = null;
try {
robot = new Robot();
} catch (AWTException e) {
e.printStackTrace();
}
//调用keyPress方法实现按下ctrl键
robot.keyPress(KeyEvent.VK_CONTROL);
//调用keyPress方法实现按下v键
robot.keyPress(KeyEvent.VK_V);
//调用keyRelease方法松开v键
robot.keyRelease(KeyEvent.VK_V);
//调用keyRelease方法松开ctrl键
robot.keyRelease(KeyEvent.VK_CONTROL);
}
public void pressTabKey() {
Robot robot =null;
try {
robot = new Robot();
} catch (AWTException e) {
e.printStackTrace();
}
robot.keyPress(KeyEvent.VK_TAB);
robot.keyRelease(KeyEvent.VK_TAB);
}
@BeforeMethod
public void beforeMethod() {
System.setProperty("webdriver.chrome.driver", "D:\\WebDriver\\chromedriver_win32\\chromedriver.exe");
driver = new ChromeDriver();
driver.manage().window().maximize();
driver.get(url);
} @AfterMethod
public void afterMethod() {
driver.quit();
} }
两种方法比较如下:
方法1优点:可以支持HTML格式的文字内容作为富文本框的文字输入内容
方法1的缺点:因为各种网页产品的富文本框实现机制不同,定位到富文本框的文本编辑区域较难,对fram的进出方式和html代码的含义需比较熟悉,对定位能力要求较高
方法2的优点:不管何种类型的富文本框,只要找到它上面的紧邻元素,通过按tab键均可进入富文本框编辑区域
方法2的缺点:不能在富文本框编辑区域进行HTML格式的文本输入
以上两种方法各有利弊,只要能稳定的完成富文本框文字内容的输入即可
WebDriver高级应用实例(5)的更多相关文章
- WebDriver高级应用实例(10)
10.1控制HTML5语言实现的视频播放器 目的:能够获取html5语言实现的视频播放器视频文件的地址.时长.控制进行播放暂停 被测网页的网址: http://www.w3school.com.cn/ ...
- WebDriver高级应用实例(9)
9.1封装操作表格的公用类 目的:能够使自己编写操作表格的公用类,并基于公用类进行表格中的元素的各类操作 被测网页的网址的HTML代码: <html> <body> <t ...
- WebDriver高级应用实例(8)
8.1使用Log4j在测试过程中打印日志 目的:在测试过程中,使用Log4j打印日志,用于监控和后续调试测试脚本 被测网页的网址: http://www.baidu.com 环境准备: (1)访问ht ...
- WebDriver高级应用实例(7)
7.1在测试中断言失败的步骤进行屏幕截图 目的:在测试过程中,在断言语句执行失败时,对当前的浏览器进行截屏,并在磁盘上新建一个yyyy-mm-dd格式的目录,并在断言失败时新建一个已hh-mm-ss格 ...
- WebDriver高级应用实例(6)
6.1精确比较网页截图图片 目的:对于核心界面进行截屏,并且使用测试过程中的截图和以前测试过程中的截图进行比较.确认页面是否发生了改变 被测网页的网址: http://www.baidu.com Ja ...
- WebDriver高级应用实例(4)
4.1操作web页面的滚动条 被测网页的网址: http://v.sogou.com Java语言版本的API实例代码 import org.testng.annotations.Test; impo ...
- WebDriver高级应用实例(3)
3.1自动化下载某个文件 被测网页的网址: https://pypi.org/project/selenium/#files Java语言版本的API实例代码 import java.util.Has ...
- WebDriver高级应用实例(2)
2.1在日期选择器上进行日期选择 被测网页的网址: https://www.html5tricks.com/demo/Kalendae/index.html Java语言版本的API实例代码 impo ...
- WebDriver高级应用实例(1)
1.1使用JavaScriptExecutor单击元素 被测网页的网址: http://www.baidu.com Java语言版本的API实例代码 import org.testng.annotat ...
随机推荐
- 2018.11.01 loj#2319. 「NOIP2017」列队(线段树)
传送门 唉突然回忆起去年去noipnoipnoip提高组试水然后省二滚粗的悲惨经历... 往事不堪回首. 所以说考场上真的有debuffdebuffdebuff啊!!!虽然当时我也不会权值线段树 这道 ...
- hdu6365 2018 Multi-University Training Contest 6 1004 Shoot Game
http://acm.hdu.edu.cn/showproblem.php?pid=6365 细节处理 unique返回的是最后一位的后一位,因此从1开始的数组要减去(p+1) 结构体可以用unqiu ...
- 二叉搜索树、AVL平衡二叉搜索树、红黑树、多路查找树
1.二叉搜索树 1.1定义 是一棵二叉树,每个节点一定大于等于其左子树中每一个节点,小于等于其右子树每一个节点 1.2插入节点 从根节点开始向下找到合适的位置插入成为叶子结点即可:在向下遍历时,如果要 ...
- Linux+mysql+apache+php
1.1.1 所需软件 cmake ncourse mysql apr apr-util pcre apache php 1.1.2 解压缩软件 ...
- C# 编码标准(三)
一.代码注释 1.文档型注释 该类注释采用.Net已定义好的Xml标签来标记,在声明接口.类.方法.属性.字段都应该使用该类注释,以便代码完成后直接生成代码文档,让别人更好的了解代码的实现和接口.[示 ...
- castapp.js颜色配置
1 修改head的背颜色 (1) header添加class publicHead <header class="mui-bar mui-bar-nav publicHead&qu ...
- (转)memcached注意事项
转自:http://www.kaifajie.cn/kaiyuan_qita/8656.html 1. key值最大长度? memcached的key的最大长度是250个字符. 注意250是mem ...
- phpwind部署问题
1. 提示"PDO_Mysql 未安装" wamp安装后,首选确保在wamp/php/ext/目录下存在"php_pdo.dll"和"php_pdo_ ...
- 20169207《Linux内核原理与分析》第七周作业
这周作业基本分为两个方面,第一方面,阅读学习教材「Linux内核设计与实现 (Linux Kernel Development)」第教材第9,10章.第二方面.学习MOOC「Linux内核分析」第五讲 ...
- android 增量更新原理
原理如下:服务器端设计增量表,记录数据操作顺序id,和增删改查信息.在进行数据库表操作的时候同时进行将信息保存在增量表. android客户端在请求的时候上传最后保存的id.服务端判断最后的id,返回 ...