1、借助IED录制脚本

2、导出脚本,选择用Python语言

将脚本导出,保存为 baidu.py ,通过 python IDLE 编辑器打开

引入unittest框架解释,见代码的的注释

# -*- coding: utf-8 -*-
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select
from selenium.common.exceptions import NoSuchElementException
from selenium.common.exceptions import NoAlertPresentException
import unittest, time, re #引入unittest框架 class Baidu(unittest.TestCase):
#setUp 用于设置初始化的部分,在测试用例执行前,这个方法中的函数将先被调用。这里将浏览器的调用和 URL 的访问放到初始化部分
def setUp(self):
self.driver = webdriver.Firefox()
self.driver.implicitly_wait(30)
self.base_url = "http://start.firefoxchina.cn/"
self.verificationErrors = [] #脚本运行时,错误的信息将被打印到这个列表中
self.accept_next_alert = True #test_baidu 中放置的就是我们的测试脚本了,因为我们执行的脚本就在这里
def test_baidu(self):
driver = self.driver
driver.get(self.base_url + "/")
driver.find_element_by_id("search-key").clear()
driver.find_element_by_id("search-key").send_keys("selenium webdriver")
driver.find_element_by_id("search-submit").click() #is_element_present 函数用来查找页面元素是否存在,在这里用处不大,通常删除。因为判断页面元素是否存在一般都加在 testcase 中
def is_element_present(self, how, what):
try: self.driver.find_element(by=how, value=what)
except NoSuchElementException as e: return False
return True #对异常弹出窗口的处理
def is_alert_present(self):
try: self.driver.switch_to_alert()
except NoAlertPresentException as e: return False
return True #关闭警告和对得到文本框的处理
def close_alert_and_get_its_text(self):
try:
alert = self.driver.switch_to_alert()
alert_text = alert.text
if self.accept_next_alert:
alert.accept()
else:
alert.dismiss()
return alert_text
finally: self.accept_next_alert = True #tearDown 方法在每个测试方法执行后调用,这个地方做所有清理工作,如退出浏览器等
def tearDown(self):
self.driver.quit()
#这个是难点,对前面 verificationErrors 方法获得的列表进行比较;如查verificationErrors 的列表不为空,输出列表中的报错信息。
#而且,这个东西,也可以将来被你自己更好的调用和使用,根据自己的需要写入你希望的信息
self.assertEqual([], self.verificationErrors) #unitest.main()函数用来测试 类似以 test 开头的测试用例
if __name__ == "__main__":
unittest.main()

  

最新文章

  1. [译]Godot系列教程四 - 编写脚本
  2. 用kryonet时kryo报buffer underflow错误
  3. 分离式模型separation model
  4. python(三)set集合
  5. (整理)streamWriter、streamReader与FileStream
  6. WF4 持久化 <第四篇>
  7. Bootstrap_组件
  8. mysql数据库表中判断字段是否存在,如果不存在则创建该字段
  9. Android UI ActionBar功能-ActionBarSherlock 的使用
  10. javascript Function.prototype.bind
  11. 请问如何在PS中将一张图标里的各个小图标分离成一个个图标?
  12. 【二分图裸题】poj1325机器调度
  13. 学习Opencv Chat3
  14. aptitude与apt-get的区别和联系
  15. mysql创建数据库命令
  16. 876. Middle of the Linked List
  17. 【转】C++中substr的用法
  18. MD5算法工具类
  19. leetcode1027
  20. 《Inside C#》笔记(九) 表达式和运算符

热门文章

  1. ACM 韩信点兵 、n的另一种阶乘、6174的问题
  2. Why won't JRockit find my classes
  3. Java多线程设计模式(三)
  4. 洛谷P4234 最小差值生成树(lct动态维护最小生成树)
  5. linux 挂载和使用文件系统
  6. linux fdisk分区工具
  7. Backup--如何快速截断日志
  8. border使用小技巧
  9. C++静态成员和非静态成员的区别和使用
  10. HAOI2014 遥感监测