webdriver还是很有意思的,之前用过Ruby的watir的自动化测试框架,感觉selenium的这套框架更好一些,很容易就可以上手。我虽然不做自动化这块,不过先玩玩再说,多学点东西总之还是好一些的。

  

 # coding:utf-
import time
from selenium import webdriver
import unittest
from pythontest.commlib.baselib import * #引用封装后的日志系统
log = TestLog().getlog()
class BaiBu(unittest.TestCase):
u'''【百度.类】'''
def setUp(self):
self.browser = webdriver.Firefox()
self.browser.get("http://www.baidu.com")
self.browser.implicitly_wait()
#self.base = Screen(self.browser) def tearDown(self):
self.browser.quit() def test_search(self):
log.info("搜索前title:" + self.browser.title.encode("utf-8") ) #得到的title中文编码格式,非UTF-8格式,需要转码
#输入关键字,关键字任意
self.browser.find_element_by_class_name("s_ipt").send_keys(u"北京尚拓云测 软件测试外包公司")
self.browser.find_element_by_class_name("s_btn").submit() #此处class属性有三个值,中间使用空格隔开,取其中一值
#点击搜索结果
self.browser.find_element_by_xpath(".//*[@id='2']/h3/a").click() #根据xpath识别元素
time.sleep()
log.info("结果页:" + self.browser.title.encode("utf-8") ) #转码utf-
self.assertIn("软件测试",self.browser.title.encode("utf-8")) #断言,转码
time.sleep()
'''接下来的工作,是获取新页面的handler,以及循环点击搜索结果''' if __name__ == "__main__":
unittest.main()

明天有时间再优化,根据id进行随机数选取。可以参考我之前Ruby的一个自动化测试框架:http://www.cnblogs.com/zhuque/archive/2012/11/30/2796866.html

  优化: 1、导入random模块,随机打开页面搜索结果;

      2、获取新打开页面的页面句柄,并建立新结果页的断言

      3、建立while循环,每次打开新页面前,重新获取原来结果页面的句柄

 # coding:utf-
import time
from selenium import webdriver
import unittest
from pythontest.commlib.baselib import *
import random #引用封装后的日志系统
log = TestLog().getlog()
class BaiBu(unittest.TestCase):
u'''【百度.类】'''
def setUp(self):
self.browser = webdriver.Firefox()
self.browser.get("http://www.baidu.com")
self.browser.implicitly_wait()
#self.base = Screen(self.browser) def tearDown(self):
# self.browser.quit()
pass def test_search(self):
u'''接下来的工作,是获取新页面的handler,以及循环点击搜索结果'''
log.info("搜索前title:" + self.browser.title.encode("utf-8") ) #得到的title中文编码格式,非UTF-8格式,需要转码
#输入关键字,关键字任意
self.browser.find_element_by_class_name("s_ipt").send_keys(u"北京尚拓云测 软件测试外包公司")
self.browser.find_element_by_class_name("s_btn").submit() #此处class属性有三个值,中间使用空格隔开,取其中一值
i =
while i < : #打开两次搜索结果
randid = random.randint(,) #根据搜索结果页id属性,随机打开搜索结果
#点击搜索结果
self.browser.switch_to.window(self.browser.window_handles[]) #获取搜索结果页的页面句柄
print( ".//*[@id='%s']/h3/a"%(randid) ) #对print()进行格式化输出,%(randid)
self.browser.find_element_by_xpath( ".//*[@id='%s']/h3/a"%(randid) ).click() #根据xpath识别元素
time.sleep()
self.browser.switch_to.window(self.browser.window_handles[-]) #获取新打开结果页的页面句柄
log.info("结果页:" + self.browser.title.encode("utf-8") ) #转码utf-
self.assertIn("尚拓云测",self.browser.title.encode("utf-8")) #断言,转码
i = i +
time.sleep() if __name__ == "__main__":
unittest.main()

测试结果如下:

最新文章

  1. gif显示
  2. 如何使用 aspnetpager
  3. L#脚本语言,直接把DLL当脚本执行(图解说明)
  4. &quot;org.jboss.netty.internal.LoggerConfigurator&quot;.DESCRIBED is already registered 的解决办法
  5. 【一】我眼中的FeatureLayer
  6. glyphicons-halflings-regular.ttf 404
  7. iOS 面试题 总结
  8. webService(一)开篇
  9. BZOJ_3144_[Hnoi2013]切糕_最小割
  10. Abp框架之执行Update-Database 命令系列错误
  11. [Go] golang的接口合约
  12. js中的原型
  13. JavaScript高级特性-实现继承的七种方式
  14. gcc和gdb使用笔记
  15. bootStrap中的翻页效果
  16. windows下使用tftp工具下载文件到开发板(linux)
  17. JVM致命错误日志(hs_err_pid.log)分析(转载)
  18. CRM - 销售与客户
  19. PHP 函数功能参考
  20. 我爱Markdown (2)

热门文章

  1. 在oracle表中增加字段,并调整字段的顺序
  2. Vue—组件传值及vuex的使用
  3. 【刷题】【LeetCode】007-整数反转-easy
  4. CodeForces Round #555 Div.3
  5. Tomcat配置实例
  6. webpack code splitting
  7. python + django + echart 构建中型项目
  8. PHP细节,PHP手册中常见的一句话:该函数是二进制安全的
  9. PHP秒杀系统 高并发高性能的极致挑战(完整版)
  10. 深度解读Tomcat中的NIO模型(转载)