# encoding = utf-8
"""
__title__ = ''
__author__ = 'davieyang'
__mtime__ = '2018/4/21'
"""
from selenium import webdriver
import unittest
import time
import logging
import 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='F:\\DataDriven\\TestResults\TestResults.TestResults',
# 打開日志的方式
filemode='w'
)
@ddt.ddt
class DataDrivenDDT(unittest.TestCase):
def setUp(self):
self.driver = webdriver.Chrome(executable_path="F:\\automation\\webdriver\\chromedriver.exe")
@ddt.data([u"阿裡巴巴", u"騰訊"], [u"美團外賣", u"百度"], [u"餓了麼", u"螞蟻金服"])
@ddt.unpack
def test_dataDrivenByDDT(self, testdata, expectdata):
url = "http://www.baidu.com"
self.driver.get(url)
self.driver.implicitly_wait(30)
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 as e:
logging.error(u"查找的頁面元素不存在,異常堆棧資訊:" + str(traceback.format_exc()))
except AssertionError as e:
logging.info(u"搜尋 '%s',期望 '%s' ,失敗" % (testdata, expectdata))
except Exception as 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()