#coding=utf-8
from selenium import webdriver
import unittest,time
import logging,traceback
import ddt
from selenium.common.exceptions import NoSuchElementException
logging.basicConfig(
#日志级别
level = logging.INFO,
#日志格式
#时间、代码所在文件名、代码行号、日志级别、日志信息
format = '%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
#打印日志的时间
datefmt = '%a, %d %b %Y %H:%M:%S',
#日志存放文件
filename = 'report.log',
#日志打开方式
filemode = 'w'
)
#使用ddt数据驱动
@ddt.ddt
class TestDemo(unittest.TestCase):
def setUp(self):
self.driver = webdriver.Chrome(executable_path = "e:\\chromedriver")
#定义测试数,元组的元素是列表
@ddt.data([u"测试开发",u"测试开发"],
[u"疯狂动物城",u"古德温"],
[u"光荣之路",u"光荣之路"])
#解包测试数据,每个列表的数据分别对应下面的testdat、expectdata,每个数据会执行一次测试脚本
@ddt.unpack
def test_dataDriven(self,testdata,expectdata):
url = "https://www.baidu.com"
self.driver.get(url)
#隐式等待
self.driver.implicitly_wait(10)
try:
self.driver.find_element_by_id("kw").send_keys(testdata)
self.driver.find_element_by_id("su").click()
time.sleep(3)
self.assertTrue(expectdata in self.driver.page_source)
except NoSuchElementException,e:
logging.error(u"查找的页面元素不存在,异常:" +str(traceback.format_exc()))
except AssertionError,e:
logging.info(u"搜索 %s ,期望%s,失败" %(testdata,expectdata))
except Exception,e:
logging.error(u"错误信息: " + str(traceback.format_exc()))
else:
logging.info(u"搜索 %s ,期望%s,通过" %(testdata,expectdata))
def tearDown(self):
self.driver.quit()
if __name__ == "__main__":
unittest.main()