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格式的文本输入

以上两种方法各有利弊,只要能稳定的完成富文本框文字内容的输入即可

posted @ 2019-03-13 11:00  心生意动  阅读(242)  评论(0编辑  收藏  举报