自动化测试框架的实现、背景为什么要做自动化测试?1.提高测试效率和降低测试成本2.实现快速的回归测试,加快测试进度从而加快产品发布进度3.更多的测试,提高测试覆盖率4.提高测试的可靠性,避免人为因素为什么要做自动化测试框架实现自动化就是为了能够提升测试效率,不具备可维护性、复用性差将成为告知自动化测试失败的最致命因素,付出巨大代价但起到的效果甚微。
基于以上因素并结合行业发展思路,在正式实施自动化之前,必须搭建一套适合的自动化测试框架,将脚本能够有效的组织、连贯应用起来,提高测试脚本的可维护性和可读性。
二、实现思路1、分层设计进行测试的时候,首先保证基本功能点走通,验证页面功能点,然后测试系统流程的正确性,最后保证符合系统满足业务要求。
对于自动化脚本,采用分层的思想,先实现最底层的操作组件,通过调用操作组件进行组合,实现对业务流程的验证。
不同的业务流程,对于底层的操作组件是可以复用的,只是调用的业务逻辑的差异,或者是测试数据的差异性。
例如,可以将摸个模块的增加操作作为一个底层的操作组件,实现流程测试的时候,可以将这些操作组件组合起来。
尽可能做到各脚本之间具备独立性,不相互依赖,便于进行各种基本场景的组合运行。
2、脚本分离设计对某个功能进行自动化测试,实际上就是对这个功能涉及的对象进行操作,输入测试数据来验证其结果的正确性,复杂的验证点需要编写业务逻辑。
如果全部用脚本的方式编写,针对每一条测试数据就需要编写一份脚本,脚本量相当巨大,同时任何改动(程序、测试用例、GUI对象)都需要调整大量的脚本。
为了达到可维护性、可复用性,将对象、操作、测试数据、业务逻辑剥离、分开管理,通过调用关系去组合实现不同的测试用例。
3、封装基础函数、基本的业务逻辑通过对基本业务逻辑的封装、调用,实现快速的脚本开发,如每个脚本都需要连接数据库,或读取CSV,或给出测试报告,这些基础函数,可以封装起来,不同的页面需要调用的时候,只需要传入这个页面相应的对象名称,调用封装的函数执行即可。
可以大大减少脚本量,也更易于维护。
又如一个模块不同页面,都包含增删改查,可以将这些基本的业务逻辑封装起来,脚本中重复调用的时候,也是可以调用对象名,实现重复的操作,这样可以大大减少脚本量,也更易于维护。
4、执行体系有效的执行体系可以批量、定制执行、自动运行,自动化测试真正达到提升测试效率,需要实现无人的情况下批量自动执行,并且可以定制执行。
5、异常处理脚本执行过程中,因程序错误或环境问题、脚本自身问题经常会出现非预期的错误:如意料外的弹出窗口、发现错误的数据、未找到对象等,有些情况下当前用例出错,并不影响后续用例的执行,需要支持异常处理机制,终止执行或者终止当前用例,继续后续用例的执行,亦或者跳过当前步骤,继续执行后续操作,并输出当前的错误报告。
6数据还原自动化测试执行后,需要不断循环,执行测试后,应该将测试数据删除,恢复到初始状态,不影响接下来的测试工作。
7、脚本管理自动化脚本比较多,需要进行脚本管理,随着版本的更新,自动化脚本也需要不断的增加和更新,这样需要对脚本进行管理。
8、测试数据调用由于自动化测试需要反复执行,调用大量的测试数据,通过读取CSV的方式,批量的调用测试数据,从而实现数据的参数化。
9、结果体系针对每个测试用例,输出测试用例内容和执行结果,也可以考虑输出执行日志,从而能更详细的看到执行过程三、自动化测试框架模型流程I.ecii pse来写测试代码2.提交svn (测试代码check,可选)3.hudson会检测(svn是否有更新),检测到更新就通过同步更新到其它slave 机器(也可以每天定时执行。
4.maven执行test5.grid把test分发到各个slave测试机(有不同的浏览器)6.报告显示在指定的html页面,包括测试用例,测试结果,测试时间等信息。
机器部署□nS ■ n\?r(-li|LJ :狗PJC 狀:T F 亿F i 2fq •诵」-h "E 宀乳皿m M Gri rJ ■'^nt *M"v<;n支持的系统平台和浏览器 MUMnSU 机:SVN, HudsoT■X.fiS ;HVV 4)12. ---棚烧瞪:II II -H 1 卜'\ Ef0K 込[:hrcime, Stifci ril! Cr I 站Elrowscr Selenium lUC I ijcfo* Record 3hd »s»f rrfoi J Record 2nd pfuFtMth tc3i3f refox iTr 1 <vrrMrio-T 尸vie 5已込T.E-fiC*IE TTffjp cKrtiuHon only via cel^.m BC *Te^f fK^Mhen "片 g S 雯E RC*S.'fflrii 4Tfflt f ifrriijiUftT rn^.沁 Mr n-fiC Tfi ■-占K*Guhi>r *n(vMTjn=RC■-)!14* *KYunfcw firth 2had* I im-pf•■屮 rfPCIMhftri poly Vk"(Jifctne l*sr ^tf^uhon rm 片 vi# 伸nd©罔T K * ** jftf im rjm-KC四、编写测试代码「f找 1]览器;「匚也 Fi refoxZ* Oircxiic, ® ■Giill 'At 1(. tSLiviMiselenium nc Olpcrabnq Sy 口口 msiurt Drc**^flr iw 严ndews. jjnujCf t«益 HJ 匚5tort JjTCft-cr run iWridcws, JRJX.testP JCgrt brcw^cr nj/n严n*w 乩 _iz*mtsMJC5l3iT her w-?-^r rvrbI'/VflxfcWTtfliESBrt bfcim^er mn Wndew?teslsSr^rt i5<r Iw?*r nin W G 电 w?t4CCESr3rt 肮料峠#t, inm 籽詬cTOCBSMrt brf 删■•:出r 呎』MAChtsrr Me 丹jnR MjrtecsSMrt rrd wfiflr^ nm鬥 nW 叱 J izh” 1«SC9心CGrM 吸丹吗*匸n«rt11 ifttn.testsLatsrsrT hrr^'Aj'r mm严刖册曲iiin«E,tiltsMac sr^Rft 曰■” nmfftnflrw*TestsP 打Z =iipp*irtpOCEIiDtC^*1.用firefox中的selenium IDE录制最初的脚本,然后导出为JAVA代码,在Jun it里进行进一步的开发;2.编写代码打开测试站点P ublic void setU p( throws Exce pti on {//打开测试站点addr代表服务器地址port代表端口号browser代表服务器web 代表测试站点地址sele nium = new DefaultSele nium( “addr", port.“ browser",“web";//打开测试站点sele niu m.start(;Case测试搜索功能,打开网站,输入hello,点击搜索,验证打开页面标题是否正确。
P ublic void testHello( throws Exce ptio nsele nium.open ("/";sele niu m.click("kw";sele nium.ty pe("kw", "hello";sele nium.click("su";assertEquals( “ hello ”,sele niu m.getTitle(;3.测试数据测试数据通过读取CSV的方式,解决数据的参数化。
4.代码分层将页面抽象出来,与测试用例分离,以减少页面改动,要大量修改代码的情况。
5.提交svn在提交svn前一定脚本测试通过五、测试执行I.Hudson上新建一个job曲需眛 hdllDJjJerr.c@ Qurild a free ■ty■匕uftwarc projectThii腥Iht Q«iitriil Atu'« oP Hudion. Hudtori 网II bjid your z^ojecxi comb"'M'rething e&'-fif thar huil'di.J〕HiiiM ft maven J ppojrrtGuiH fl rrvBvwiZ prg;e d■ RudsnSioEncu vour PCM files arnJ d-a:£4、an "耳*v:Trl*Ql j勺b'Tki ME of job die At be I^cord ;lie lyxeuL^ticp 屮runouWEtun uit Hucstn est a ceihbod'd of vDur cx.^irb9 =ulci^ etion iyitcm_ S = ^ :O Build muHi-cfxiFiquration projecl (diplid}Suitable fw prujeczs thai rwd A laroe numttr of differfent 匚onfiour^tK戸etc. 选择执行机器及项目的svn,如下图所标I £A:iR L s SR执行,观察命令行输出六、测试报告测试结果保存到数据库中,以html 形式 展现,打开网页,即可看到测试运行结果,包括测试用例,测试结果,浏览器,执行时间等。
七、自动化测试方法自动化应该在回归测试或者软件基本功能或者流程已经成型的条件下而且以后变动不 大的情况下,开始进行的。
1、自动化单元 测试自动化测试可以模拟手工测试,进行单元测试,验证页面功能点是否通过, 执行用例,覆盖系统的各个功能点,但是考虑自动化做单元测试,相比手工进 行,会花费更多的时间, 所以我们不使用自动化来做单元测试,而是做到使用自动化可以进行冒烟测试, 保证基本功 能点是跑的通,就可以了。
2、自动化系统 测试自动化将用来执行流程用例, 可以自动化团队自行编写流程用例, 用自动化来执行系统流程测试,可以提高测试效率,降低测试成本。