- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Python在数据库测试中的应用探索.doc
Python在数据库测试中的应用探索教育资源库
Python(派森)语言是一种面向对象的用途非常广泛的编程语言,具有非常清晰的语法特点,适用于多种操作系统,可以在#39;);
rc=tb1.exec_sql_ignore(droptableaa;);#执行drop语句而不关心是否执行成功
rc=tb1.exec_sql(createtableaa(cint););#执行create语句且预期成功
rc=tb1.exec_sql_failed(createtableaa(cint););#再次执行该语句,预期失败
k=((1,1),(1,1));
#执行select且预期结果集与上面定义的k相同
rc=tb1.exec_sql_e,idfromsystables;,k);
rc=tb1.disconnect();
dmserver1.stopserver();
可以看到,如上所示,编写用例的人员完全不需关心connect,exec_sql_ignore,tb1.exec_sql_failed此类的操作细节如何实现,他们只要使用并给出测试的逻辑就可以了。而测试开发人员则要实现例如上面这几个接口的odbc版本、jdbc版本、和ado.版本。
位于测例与支持库之间的是一个Testloader程序,这个程序完成这几件事情:
1、读取根据要执行的测试的配置文件,确定解释器的位置和将要使用哪种驱动;
2、读取测试用例的内容,并将对支持类的引用改为对应驱动,比如上面的脚本中的:
from dbop import * 可能会被改为:from dbop_jdbc import *
3、调用对应的解释器执行这个测试用例。
一个比较简单的例子如下:
cfg.ini:
py_path=D:ACTIVEPythonpython.exe
jy_path=C:jython2.2.1dmjython.bat
ny_path=C:python-2.0-alpha2python-2.0-alpha2python2.5-UCS2python.exe
#driver=dot
driver=odbc
#driver=jdbc
Testloader:
importos
importstring
importsys
defexeascript(sc,driver):
read_script(sc)
replace_lib_include(sc,driver)
p_script();
cmd=get_executer_path()++temp.py
nep.py,(cmd);
os.remove(temp.py)
mode=
scriptfile=
lstfile=
123下一页 这篇文章来自..,。arg=sys.argv[1]
tempdriver=sys.argv[2]
ifstring.upper(arg[arg.rfind(#39;.#39;)+1:len(arg)])==PY:
mode=py
scriptfile=arg
elifstring.upper(arg[arg.rfind(#39;.#39;)+1:len(arg)])==LST:
mode=lst
lstfile=arg
jyp=;
nyp=;
cyp=;
ininame=cfg.ini
dataList=[]
caseList=[]
gbldriver=odbc
readini(ininame)
forlineindataList:
getini();
ifmode==lst:
#toloopexecutetestcase
elifmode==py:
exeascript(scriptfile,tempdriver)
else:
printNotsupport
借助上面的这个脚本,测试执行人员执行用例只需要用
D:pytestloadergt;testloader.py Testcase1.py jdbc
这样类似的格式就可以自己指定驱动来执行测试用例了。
如果有大量的用例,可以将这种命令写成批处理文件来执行。而不需要人工干预。
从上面的可以看到,对于功能或者单项SQL性能,基于Python的测试用例可以提供平台无关的简单的脚本编写环境,同时由于Python本身是一门完整的脚本语言,测例编写人员自己也可以在测试用例中编写出各种结构的程序,正所谓可繁可简。
对
您可能关注的文档
最近下载
- 做香囊(课件)-三年级上册劳动.pptx VIP
- 新思路大学英语基础教程第一册.docx VIP
- 2025年新疆阿勒泰地区布尔津县高校毕业生“三支一扶”计划招募11人笔试模拟试题及答案解析.docx VIP
- 2025年【合成氨工艺】考题(含答案) .docx VIP
- 重庆市人民小学四年级数学竞赛试卷及答案_学科竞赛.pdf VIP
- PC(装配式)结构施工监理实施细则.doc VIP
- 民警心理健康辅导课件.pptx VIP
- 考古与文物 讲座7-2元、明、清时期的瓷器.ppt VIP
- 考古与文物 讲座6-3中国古代青铜器的作伪与辨伪.ppt VIP
- 期末综合题训练-统编版七年级下册历史(含答案).docx VIP
文档评论(0)