本人在使用selenium做测试的时候,有时候需要去后台管理界面去设置一些测试数据,所以写了一些脚本,有一个比较有代表性的,因为这里的设置按钮和课程详情并不在一个页面,而是在列表页面。所以查找起来比较麻烦。先分享代码,供大家参考。
先放一下后台的页面和xml信息:
下面是我的代码:
//设置秒杀价public void setSeckillPriceByCourseId(int courseId, int price) throws InterruptedException {clickCourse();//点击进去课程列表clickFormalCourse();//选择班课列表int status = findCourseByIdAndSetSeckillPrice(courseId, price);//根据courseid查找班课设置秒杀价if (status != 2) {outpu(status, "设置秒杀价失败!");}}
下面是具体的方法:
/** 分页遍历课程,查找相应班课* 返回值1:找到该课程,2:设置秒杀价完成,3:已经开始秒杀,4前四页未找到该课程*/public int findCourseByIdAndSetSeckillPrice(int courseId, int price) throws InterruptedException {int times = 0;//标记页面int mark = 0;//标记状态sleep(0);while(true) {times++;List<WebElement> seckills = findElementsByPartialText("秒杀");//获取所有秒杀状态按钮集合for (int i = 0; i < seckills.size(); i++) {//遍历集合中所有元素//获取date_course_id,来判断是否是等于参数id,然后点击String course = (i).getAttribute("data-course_id");//获取该元素对应课程idif (course.equals(courseId+"")) {//比较idmark = 1;//更改标记,表示发现课程String status = (i).getText();//获取秒杀状态
// output(status);if (status.equals("开始秒杀")) {(i));//滚动到该元素(i));//通过js点击sleep(0);findElementByIdAndClearSendkeys("input-modal_promotion_price", price);//设置秒杀价findElementByIdAndClick("btn-ok-product_promotion");//确定boolean key = true;while(key){//等待保存完毕,再次确认if (exists(By.xpath("/html/body/div[7]/h2")) && getTextByXpath("/html/body/div[7]/h2").equals("操作成功")) {key = false;break;}}clickSure();output("设置秒杀价成功!");mark = 2;//更改标记,表示已经完成秒杀} else if (status.equals("结束秒杀")) {output("该课程已经开始秒杀了!");mark = 3;//标记,表示已经在秒杀了output("已经开始秒杀!");}}}//遍历结束if (mark != 0) {return mark;}if (times > 2) {output("未找到该课程!");mark = 4;//更改标记,表示未找到return mark;}}}
中间js滚动到 某个元素的方法:
//滚动到某个元素public void scrollToElement(WebElement element) {JavascriptExecutor js = (JavascriptExecutor) uteScript("arguments[0].scrollIntoView(true);", element);}
中间js点击某个元素的方法:
//通过js点击public void clickByJs(WebElement element) {JavascriptExecutor js = (JavascriptExecutor) uteScript("arguments[0].click();", element);//第二种点击方法
// ((JavascriptExecutor) driver).executeScript("arguments[0].click()", question);}
转载于:
本文发布于:2024-02-01 11:41:04,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170675886436344.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |