Python自動化測試系列[v1.0.0][數據驅動DDTTUPLE]

# 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()
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章