搭建框架的几点思考:
- 需要框架实现什么功能
- 前期需要做数据与业务分离,方便维护
- 测试用例集管理要方便,便于异常时重新Run单条用例
- 用例设计需要尽可能简单,多提供公共方法
- 目前设计框架如下图:
- CommonLibrary 用于存放公共库
- TestCasesRepository 用于存放测试用例
- TestData 用于存放与测试用例有关的测试数据文档
- TestRun_xxx 是测试过程中生成的测试结果,内含测试报告和日志
- AutoRunTest.py 用于从用例列表中读取需要执行的测试用例文件,及测试结束后测试报告的发送
- testcases.txt 用于存放用例表
2. 其中公共库中大致有Appium的操作、Excel档的操作、手机信息的配置、测试用例信息的收集、测试结果文件夹的生产 、测试报告的写入、邮件发送等公共方法
目录如下:
如Appiumserver大致如下设计:
#! /usr/bin/env python
#coding=utf-8
import os,time
def start_appiumServer(port11,port12,deviceuuid):
os.system("cd C:\\Program Files (x86)\\Appium\\ && start node node_modules\\appium\\lib\\server\\main.js --address 127.0.0.1 --port "+port11+ " -bp "+port12+" -U "+deviceuuid)
time.sleep(2)
def kill_appiumServer(port13):
# 查找对应端口的pid
cmd_find = 'netstat -aon | findstr %s' % port13
print(cmd_find)
result = os.popen(cmd_find)
text = result.read()
pid = text[-5:-1]
# 执行被占用端口的pid
cmd_kill = 'taskkill -f -pid %s' % pid
print(cmd_kill)
os.popen(cmd_kill)
if __name__ == '__main__':
#start_appiumServer('4729','4728','BIBI5LEU6PRCDIIV')
#start_appiumServer('4727','4724','75a2daf1')
#time.sleep(10)
kill_appiumServer(4729)
kill_appiumServer(4727)
EmailUtils结构如下:
#! /usr/bin/env python
#coding=utf-8
import smtplib
from os.path import basename
from email.mime.application import MIMEApplication
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.utils import COMMASPACE,formatdate
from datetime import datetime
import ResultFolder
from email.header import Header
import zipfile,os
import decode_pwd
def send_email(send_from,send_to,subject,text,files1,files2,server="smtp.163.com"):
#assert(isinstance(send_to,list),"Send To email should be a list")
msg = MIMEMultipart()
msg['From'] = send_from
msg['To'] = send_to
msg['Date'] = formatdate(localtime = True)
msg['Subject'] = Header(subject, 'utf-8')
my_password = "7A68656E676A696E6731313238"
my_pass = decode_pwd.decode_pwd(my_password)
msg.attach(MIMEText(text,'html'))
with open(files1,"rb") as f:
part1 = MIMEApplication(f.read())
part1["Content-Type"] = 'application/octet-stream'
part1["Content-Disposition"] = 'attachment; filename="TestResult.html"'
msg.attach(part1)
with open(files2,"rb") as g:
part2 = MIMEApplication(g.read())
part2["Content-Type"] = 'application/octet-stream'
part2["Content-Disposition"] = 'attachment; filename="Test.log"'
msg.attach(part2)
smtp = smtplib.SMTP_SSL(server,465)
smtp.login(send_from,my_pass)
smtp.sendmail(send_from,send_to,msg.as_string())
smtp.quit()
def zip_report(startdir,file_news):
print startdir
z = zipfile.ZipFile(file_news,'w',zipfile.ZIP_DEFLATED)
for dirpath, dirnames, filenames in os.walk(startdir):
fpath = dirpath.replace(startdir, '') # 这一句很重要,不replace的话,就从根目录开始复制
fpath = fpath and fpath + os.sep or '' # 这句话理解我也点郁闷,实现当前文件夹以及包含的所有文件的压缩
for filename in filenames:
z.write(os.path.join(dirpath, filename), fpath + filename)
print ('压缩成功')
z.close()
def send_report():
send_f = "xxxxx@163.com"
send_t = "xxxxxx@163.com"
subject = "Software test Report_"+ str(datetime.today())
files1 = ResultFolder.GetRunDirectory()+"\\TestResult.html"
print "zip log is start"
zipdir = ResultFolder.GetRunDirectory()+"\\"
file2_news = zipdir + 'TestLog.zip'
zip_report(zipdir,file2_news)
files2 = ResultFolder.GetRunDirectory() + "\\TestLog.zip"
with open(files1,'r') as f:
text = f.read()
send_email(send_f,send_t,subject,text,files1,files2)
if __name__=='__main__':
send_report()
其他模块就不一一列举。