最近在慕课网报名参加了一门web自动化测试课程,使用的是java语言,对于习惯了python的自己来说,学习起来有点吃力,但好在语言相通,勉强能听懂课程,早上在学习文件上传,是关于慕课网头像更换。
更换头像的按钮,其实是个隐藏元素,需要将鼠标悬停在元素上才能显示,老师使用了偷懒的方式,执行js脚本,手动修改了元素的位置,使其不被隐藏。想想还是觉得不妥,一来很多人可能刚接触自动化,js还不熟悉,这总方法未免有点吃力;二来selenium提供了鼠标悬停API,相比js,更快入手,所以就自己研究了一下,参考网上的教程,顺利的实现了这个用例.
public class ActionSelect {
public WebDriver driver;
/**
* 初始化driver,并且打开测试地址
*/
public void initDriver() {
System.setProperty("webdriver.chrome.driver", "C:\\\\Program Files\\\\Java\\\\chromedriver_win32\\\\chromedriver.exe");
driver = new ChromeDriver();
driver.get("http://www.imooc.com/user/newlogin/from_url");
driver.manage().window().maximize();
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
*登陆
*/
public void inputBox() {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
driver.findElement(By.name("email")).sendKeys("kongsiwen0818@163.com");
driver.findElement(By.name("password")).sendKeys("lkp11104077ksw");
driver.findElement(By.className("btn-red")).click();
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
* 上传文件
* @param args
*/
public void upFile() {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
driver.get("http://www.imooc.com/user/setprofile");
//定位头像元素
WebElement img = driver.findElement(By.className("avator-img"));
Actions builder = new Actions(driver);
//将鼠标移动到头像上面
Action mouserOverlogin = builder.moveToElement(img).build();
mouserOverlogin.perform();
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//定位隐藏的更换头像元素并点击
driver.findElement(By.className("js-avator-link")).click();
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//本地头像文件路径
String filePath = "D:\\Program Files\\Eclipse\\java-oxygen\\workspace\\Demo\\src\\file\\xiongbenxiogn.jpeg";
//上传文件
driver.findElement(By.id("upload")).sendKeys(filePath);
//保存
driver.findElement(By.linkText("确定")).click();
}
public static void main(String[] args) {
// TODO Auto-generated method stub
ActionSelect action = new ActionSelect();
action.initDriver();
action.inputBox();
action.upFile();
}}
主要包括初始化、登陆、更换头像这三个用例,在upFile()方法中,模拟的操作是,先将鼠标移动到头像上,点击头像下方出现的“更换头像”按钮,再定位弹出框的元素,最终实现头像上传并成功保存。