案例3-数据驱动测试-从excel导入数据

excel:测试数据.xlsx
在这里插入图片描述
python获取excel中的数据方法,excelutil.py

#encoding =utf-8
# -*- coding:utf-8 -*-
from openpyxl import load_workbook
class pexcel(object):
    def __init__(self,excelPath,sheetName):
        self.wb=load_workbook(excelPath)
        self.sheet=self.wb.get_sheet_by_name(sheetName)
        self.maxRowNum=self.sheet.max_row
    def getdatas(self):
        datalist=[]
        for line in self.sheet.rows[1:]:
            tmplist=[]
            tmplist.append(line[1].value)
            tmplist.append(line[2].value)
            datalist.append(tmplist)

        return datalist
if __name__=="__main__":
    execelPath=u"C:\\测试数据.xlsx"
    sheetName=u"Sheet1"
    for i in pexcel(execelPath,sheetName).getdatas():
        print i[0],i[1]

从excel导入测试数据.py

#encoding =utf-8
# -*- coding:utf-8 -*-
from selenium import webdriver
import unittest,time
import logging,traceback
import ddt
from reportHtml import htmlTemplate
from selenium.common.exceptions import NoSuchElementException
from excelutil import pexcel
logger = logging.getLogger('mylogger1')
logger.setLevel(logging.DEBUG)
# 创建一个handler,用于写入日志文件
fh = logging.FileHandler('C:/test.log')
fh.setLevel(logging.DEBUG)
# 再创建一个handler,用于输出到控制台
ch = logging.StreamHandler()
ch.setLevel(logging.DEBUG)
# 定义handler的输出格式
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
fh.setFormatter(formatter)
ch.setFormatter(formatter)
# 给logger添加handler
logger.addHandler(fh)
logger.addHandler(ch)

execelPath = u"C:\\测试数据.xlsx"
sheetName = u"Sheet1"
excel=pexcel(execelPath,sheetName)

@ddt.ddt
class Testdemo(unittest.TestCase):
    @classmethod
    def setUpClass(cls):
        Testdemo.trStr=""
    def setUp(self):
        self.driver=webdriver.Firefox(executable_path="C:\\webdriver\geckodriver")
        status=None
        flag=0
    @ddt.data(*excel.getdatas())
    def test_dataDriverByFile(self,value):
        testdata,expectdata=tuple(value)
        flagDict={0:'red',1:'#00AC4E'}
        url="http://www.baidu.com"
        self.driver.get(url)
        self.driver.maximize_window()
        # print value.decode('utf-8')
        self.driver.implicitly_wait(10)
        try:
            start=time.time()
            startTime=time.strftime("%Y-%m-%d %H:%M:%S",time.localtime())
            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:
            logger.error(u"找不到页面元素")
            status='fail'
            flag=0
        except AssertionError,e:
            logger.info(u"搜索失败")
            status='fail'
            flag=0
        except Exception,e:
            logger.info(u"未知错误")
            status='fail'
            flag=0
        else:
            logger.info(u"搜索成功")
            status='pass'
            flag=1
        wasteTime=time.time()-start-3
        Testdemo.trStr += u'''
        <tr>
            <td>%s</td>
            <td>%s</td>
            <td>%s</td>
            <td>%.2f</td>
            <td style="color:%s">%s</td>
        </tr><br/>'''%(testdata,expectdata,startTime,wasteTime,flagDict[flag],status)
    def tearDown(self):
        self.driver.quit()
    @classmethod
    def tearDownClass(cls):
        htmlTemplate(Testdemo.trStr)

if __name__=='__main__':
    unittest.main()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值