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)的更多相关文章

  1. WebDriver高级应用实例(10)

    10.1控制HTML5语言实现的视频播放器 目的:能够获取html5语言实现的视频播放器视频文件的地址.时长.控制进行播放暂停 被测网页的网址: http://www.w3school.com.cn/ ...

  2. WebDriver高级应用实例(9)

    9.1封装操作表格的公用类 目的:能够使自己编写操作表格的公用类,并基于公用类进行表格中的元素的各类操作 被测网页的网址的HTML代码: <html> <body> <t ...

  3. WebDriver高级应用实例(8)

    8.1使用Log4j在测试过程中打印日志 目的:在测试过程中,使用Log4j打印日志,用于监控和后续调试测试脚本 被测网页的网址: http://www.baidu.com 环境准备: (1)访问ht ...

  4. WebDriver高级应用实例(7)

    7.1在测试中断言失败的步骤进行屏幕截图 目的:在测试过程中,在断言语句执行失败时,对当前的浏览器进行截屏,并在磁盘上新建一个yyyy-mm-dd格式的目录,并在断言失败时新建一个已hh-mm-ss格 ...

  5. WebDriver高级应用实例(6)

    6.1精确比较网页截图图片 目的:对于核心界面进行截屏,并且使用测试过程中的截图和以前测试过程中的截图进行比较.确认页面是否发生了改变 被测网页的网址: http://www.baidu.com Ja ...

  6. WebDriver高级应用实例(4)

    4.1操作web页面的滚动条 被测网页的网址: http://v.sogou.com Java语言版本的API实例代码 import org.testng.annotations.Test; impo ...

  7. WebDriver高级应用实例(3)

    3.1自动化下载某个文件 被测网页的网址: https://pypi.org/project/selenium/#files Java语言版本的API实例代码 import java.util.Has ...

  8. WebDriver高级应用实例(2)

    2.1在日期选择器上进行日期选择 被测网页的网址: https://www.html5tricks.com/demo/Kalendae/index.html Java语言版本的API实例代码 impo ...

  9. WebDriver高级应用实例(1)

    1.1使用JavaScriptExecutor单击元素 被测网页的网址: http://www.baidu.com Java语言版本的API实例代码 import org.testng.annotat ...

随机推荐

  1. 2019.01.02 poj3046 Ant Counting(生成函数+dp)

    传送门 生成函数基础题. 题意:给出nnn个数以及它们的数量,求从所有数中选出i∣i∈[L,R]i|i\in[L,R]i∣i∈[L,R]个数来可能组成的集合的数量. 直接构造生成函数然后乘起来f(x) ...

  2. 2018.11.07 NOIP模拟 分糖果(贪心)

    传送门 考虑 n = 2 时的情况:假定两个人分别为(a, b),(c, d),则当且仅当min(a,d) ≤ min(b,c)时,把(a, b)放在前面更优,否则把(c, d)放在前面更优 然后把n ...

  3. hdu6365 2018 Multi-University Training Contest 6 1004 Shoot Game

    http://acm.hdu.edu.cn/showproblem.php?pid=6365 细节处理 unique返回的是最后一位的后一位,因此从1开始的数组要减去(p+1) 结构体可以用unqiu ...

  4. matlab2016b和c# .net4.0混合编程

    参考:https://www.cnblogs.com/eniac12/p/4390845.html 主要想用c#写软件界面,利用matlab绘图,或者用里面的遗传算法. 我的环境是:Win10 64位 ...

  5. VS2013利用ajax访问不了json文件——VS2013配置webconfig识别json文件

    这两天用VS2013开发工具来访问json文件,老是报404文件,我根据网上来设置IIS添加MIME重启IIS和VS2013还是失败,无法访问json文件,但是奇怪的是可以访问txt文件 查询了很多方 ...

  6. C#-VS发布网站-准备待发布网站-摘

    通过使用“发布网站”工具部署网站项目 准备网站源文件 在vs生成发布文件 配置IIS   .NET Framework 4 其他版本 Visual Studio 2008 Visual Studio ...

  7. linux-CentOS初学terminal命令(3)rm、chmod、mkdir、who、w、id、systemctl、

    PS 1:windows不允许出现字母相同,但是大小写不同的文件名,因为在windows下会将它们认作是同名. 但是linux允许出现字母相同,大小写不同的文件名. ps 2:prompt 提示 1. ...

  8. _ZNote_Qt_对话框_模态非模态

    QDialog(及其子类,以及所有Qt::Dialog类型的类)的对于其 parent 指针都有额外的解释:如果 parent 为 NULL,则该对话框会作为一个顶层窗口,否则则作为其父组件的子对话框 ...

  9. web-day3

    第3章WEB03- JS篇 今日任务 使用JS完成图片轮播效果 使用JS完成页面定时弹出广告 使用JS完成表单的校验 使用JS完成表格的隔行换色 使用JS完成复选框的全选效果 使用JS完成省市联动效果 ...

  10. Lombok自定义annotation扩展含Intellij插件

    Lombok简介 Lombok(https://projectlombok.org/)  提供了以注解的形式为java对象增加属性和方法,这使得原来冗长的java源文件变的简洁(不需要再使用ide去生 ...