开发者测试-采用精准测试工具对Spring Boot应用进行测试

简介:本文主要介绍把现今主流的springboot框架项目和精准测试工具进行结合和应用,经过精准测试的数据穿透、数据采集、测试用例与代码的双向追溯、数据分析等一系列精准测试的特有功能,达到对项目质量的保证。  html

本次环境搭建分为基础环境准备、springboot环境搭建、精准测试环境搭建、精准测试与springboot环境对接等一整套完整的配置过程,用户能够经过下图中的流程图确认本身所部署过程当中进行到的阶段点,从而排查部署中可能碰见的问题。java

一,Spring Boot配置流程node

1,使用工具mysql

1, Eclipse Java Photongit

2, Spring Bootgithub

3, JDK 1.8web

4, MySQL 5.7redis

5, Navicat for MySQLspring

6, apache-maven-3.5.4sql

7, zoa-agent-1.6.2

8, J2EE_Enterprise_key_64bit0614

9, 项目:Moxi(github.com/daleiwang/m…

2, 配置所需的安装

1,安装Eclipse、JDK、MySQL、Nodejs

注:Eclipse和JDK的安装和安装包就用本身现有的就能够,星云测试将提供MySQL和Nodejs的安装包,但必须前提是用户本身的本机上 不存在安装的MySQL和Nodejs

脚本安装mysql和nodejs

一、解压星云提供的mysql-5.7.16-winx64安装包和nodejs安装包到服务器根目录中(例如D盘根目录)。  

二、右键以管理员身份运行星云提供的自动化安装工具mysql_nodejs_install.exe  

三、输入nodejs的目录,回车。以下图所示:

四、输入mysql的绝对路径(到bin),而后回车。等程序运行完毕,mysql的root密码被修改为root就能够手动关闭程序。

2,安装Spring Boot插件

Eclipse安装Spring Boot插件,Help-Eclipse Marketplace,搜索Spring Tools安装STS,如图:

也能够经过 下载地址:spring.io/tools/sts/a… 进行下载,

下载之后安装,Eclipse——Help——Install new Sofware,下一步、下一步安装便可。  

3,安装Maven

Eclipse自己会带Maven,可是不如本身安装的灵活,解压apache-maven-3.5.4.zip(例如:E:\apache-maven-3.5.4),配置系统变量添加变量名:

MAVEN_HOME变量值= E:\apache-maven-3.5.4,

Path添加变量值= %MAVEN_HOME%\bin,cmd测试用mvn -v以下即安装成功。

1,Eclipse替换自带为本地Maven

Windows-Preferences-Maven-Installations-Add,路径指向 E:\apache-maven-3.5.4,加载完成后勾选新的apache-maven-3.5.4,Apply。

2,定义本地Maven依赖库

修改E:\apache-maven-3.5.4\conf\settings.xml,添加以下一行代码定义,例如: C:\Users\luxper.m2\repository,C:\Users\luxper.m2\repository是个人本地maven仓库地址。

Eclipse:Windows-Preferences-Maven-User Settings-Global Settings,Browse= E:\apache-maven-3.5.4\conf\settings.xml,Apply。  

3,新建工程和运行工程

选择Spring Starter Project

工程名字,定义为moxi,工程选择Web下面的Web,而后Finesh,接下来会初始化下载Maven管理的相关jar包。

工程结构大体以下:

工程——右键——Run As——Spring Boot App

添加调试:

为了解决每次修改代码还要从新启动工程, 工程——右键——Spring Tools——Add Boot Devtools,那么每次修改类文件就会自动编译了。  

4,整合Mybatis

刚才已经下载好了MySQL,如今咱们添加pom.xml文件 build标签加一行compile以下

而后是mybatis和mysql:

<!-- mybatis -->

&emsp;<dependency>

&emsp;&emsp;<groupId>org.mybatis.spring.boot</groupId>

&emsp;&emsp;<artifactId>mybatis-spring-boot-starter</artifactId>

&emsp;&emsp;<version>1.2.0</version>

</dependency>



&emsp;<!-- mysql -->

&emsp;<dependency>

&emsp;&emsp;<groupId>mysql</groupId>

&emsp;&emsp;<artifactId>mysql-connector-java</artifactId>

&emsp;&emsp;<scope>runtime</scope>

</dependency>
复制代码

在application.properties文件中添加数据源配置:、

Navicat链接本地mysql,新建数据库moxi,查询执行项目git页面列出来的sql语句自动创建该项目须要的数据库内容。

能够经过建立Model、Service和Controller验证数据库是否链接成功  

5,整合thymeleaf

添加thymeleaf依赖

配置application.properties

引入文件:如图,引入相应的样式、图片和js文件,引入页面文件:

引入html:注demo和news里面也是html文件

6,运行程序

Eclipse环境运行:Run As——Spring Boot App

打包运行:右键项目Maven-Maven install,项目目录target文件夹生成jar包,cmd运行。项目初次运行会下载所需依赖库,消耗时间较长。

在Eclipse环境运行成功之后界面是这样的:

二,测试项目

1, 下载工具及工具配置

2, 从官网上下载星云测试工具:www.teststars.cc/

下载之后进行配置:  

2,星云测试服务端的配置

TTLangage.config配置项说明:

一、 运行下的星云测试server目录中ThreadingTestServer.exe,在右下的图表中点注册信息,查看其时间,星云测试有两个月的体验,如果超过两个月,发生KEY过时,请联系星云测试的工做人员,并提交服务端中的序列码

二、联系星云工做人员获取当前服务器的key.key文件,替换到星云的server目录下;  

三、启动server目录下的ThreadingTestServer.exe后会自动打开同级目录下的ThreadingTestServerFront.exe,看到自动弹出下面窗口后,表示链接正常。

3,星云测试客户端的配置

注:星云测试在线客户端的链接须要访问端口17262/17263.登录以前须要保证网络链接不存在限制。

打开客户端以前须要修改TTClient文件夹下的Server.cfg文件,配置localIP项为能够与服务端正常数据通讯的本机IP地址。配置这个localIP的缘由是,在客户端须要接收来自服务端传来的动态数据,配置本地的IP地址服务端才能把数据传到客户端中来。

配置IP地址完成后双击运行TTClient/TT.exe文件进入星云测试客户端。选择文件->登陆,输入星云测试服务端的IP地址以及本身的用户名和密码便可登陆。以下图所示。

4,星云测试云报表平台服务启动

一、 运行星云测试TTWeb目录下的bin\redis-2.4.5-win32-win64\32bit中的redis-server.exe

二、运行星云测试TTWeb目录下的startTTwebserver.bat

访问网页报表网页IP地址:3000

2,建立工程和版本并编译

1, 登陆客户端

2, 选中待插装的空版本,版本处于解锁状态(解锁状态:右键-解锁状态)

3, javaForWindows目录下的Server.cfg配置文件,[SERVER] ip填写实际ip地址,修改[PROPERTY]字段,与客户端目录下的Server.cfg同步

四、修改javaForWindows目录下的ComplierPath.xml配置文件

同一个版本下可添加多个子模块即proname,proname不能重复,一个子模块下能够配置多个工程路径

ProName:子模块名称

Project_path:测试程序源码文件路径

Class_path:测试程序class文件路径

五、修改javaForWindows目录下tt_windows文件夹下Server.ini配置文件 Ip设置为客户端的ip地址。

六、在命令行运行autoCompiler.jar进行编译

jre\bin\java.exe -jar autoCompile.jar -e

D:\J2EE_Enterprise_key_64bit0803\CompileToolsPkg\javaForWindows

注:-e后面的参数为ComplierPath.xml文件的目录

7、在客户端查看数据,记得必须点击从新加载文件

因为测试的时候须要运行咱们插装后的代码(编译完成后会在java目录同层生成src-instru目录,src-instru目录即为编译插装后的源码);

具体操做:先将源码目录下未插装的java目录重命名为pre_java,再将编译插装生成的src-instru目录命名为java。  

而且插桩代码的运行须要咱们的jar包,所以须要修改客户的pom.xml文件来引入咱们的jar服务,加入到两个之间,加入的代码以下:

systemPath须要按JavaParser-j2ee.jar 和jeromq-0.3.0-SNAPSHOT.jar的绝对路径填写

<dependency>

&emsp;&emsp;<groupId>com.zoa</groupId>

&emsp;&emsp;<artifactId>JavaParser-ZMQ</artifactId>

&emsp;&emsp;<version>1.0</version>

&emsp;&emsp;<scope>system</scope>

&emsp;&emsp;<systemPath>/D:/J2EE/client/MQ/JavaParser-J2EE.jar</systemPath>

</dependency>

<dependency>

&emsp;&emsp;<groupId>com.zoa</groupId>

&emsp;&emsp;<artifactId>jeromq</artifactId>

&emsp;&emsp;<version>1.0</version>

&emsp;&emsp;<scope>system</scope>

&emsp;&emsp;<systemPath>/D:/J2EE/client/MQ/jeromq-0.3.0-

SNAPSHOT.jar</systemPath>

</dependency>
&emsp;
复制代码

在pom文件修改完成后便可打包发布  

编译之后达成jar包(具体的打包方法参考6,运行项目)

打包完成,为使函数覆盖率可视视图代码部分显示正常,须要手动修改源码路径:右键版本,点击修改源码路径,选择到pre_java目录便可。

3,测试前准备

一、添加数据传输配置文件

数据传输配置文件是保证运行的数据能够回传到星云服务器的。配置方法是在具体的客户测试环境下的usr/local/bin文件夹下新建配置文件config.cfg 文件内容以下:

state=1

IP=(IP值写星云测试服务端IP,注意要大写) (若是发布环境是windows环境,须要在C盘根目录下配置上述文件)

2,agent启动项目

cmd输入命令:

java -javaagent:E:\zoa-agent-1.6.2\zoa-agent-1.6.2.jar -jar E:\moxi-0.0.1-SNAPSHOT.jar

E:\zoa-agent-1.6.2\zoa-agent-1.6.2.jar =agent路径 E:\moxi-0.0.1-SNAPSHOT.jar =项目路径 出现这样的界面表示运行成功:

3,设置cookie

1,项目URL后面加teststars.jsp,访问teststars.jsp页面进行cookie设置

2,点击setcookie进行设置,设置成功页面以下:

注:为了区分测试,咱们在设置的用户姓名与星云客户端当前登陆用户一致,

4,编写测试用例

点击添加:

5,项目测试

访问地址:http://localhost:8080/admin/login

页面登录进去之后,假如测试内容管理的文章管理的测试用例,则选择内容管理的文章管理的用例,点击开始,在页面上点击内容管理的文章管理,就会有相应的测试数据传输过来(具体的展现见后面测试结果的第一个标题:示波器的展现),数据接收完之后点击中止,本条用力测试完毕

三,测试结果

1,示波器波形展现

先选中测试用例,再点击开始后就能够进行相应的测试工做了,测试的时候示波器能够收到动态数据并以波形图的方式展现出来。

注:采集的动态数据保存在服务端目录下的VersionData文件夹下,对应版本的动态数据保存在相应的版本号目录下(版本号可在数据库management表的version表中查看)  

2,缺陷管理

为了让测式人员更好的对缺陷进行管理,采用测试用例、代码、BUG相关联方式,精准测试云平台使用了历史BUG追查功能,这使得在版本迭代过程当中,同一个测试用例全部的BUG状况一目了然,避免了因人员变更或版本变更致使的相同的BUG的排查时间,以及重复提交未被解决的BUG。

             图表 缺陷提交与管理

             图表 bug信息一目了然        

3,覆盖率

覆盖率可视化针对函数sc0、True、false 、both、Branch、C/DC 、MC/DC 7种覆盖率给出可视化展现下面针对每一种覆盖率展现界面给出说明:(以sc0为例)

sc0为语句块覆盖,其颜色区分对象为基本语句块(包括隐含不可见语句块)其中绿色标示被覆盖的语句块。蓝色是未覆盖到的语句块。 计算方法为:覆盖到块/应统计块

用红色的标出来的表示sc0覆盖率,函数列表右方为覆盖率的展现:

4,双向追溯

双向追溯是指经过运行测试用例,实现测试用例与被测源码间相互追溯。根据测试用、

查看相关被测源码为正向追溯,根据被测源码查看相关测试用例为逆向追溯。在测试用例列表中选择测试用例,能够追溯到该测试用例的内容描述信息,在模块调用图中显示被测试到的函数;也能够在模块调用图中,点击相关的函数,也能够追溯到相关的测试用例。该追溯技术方便了用户查看和设计测试用例。

双向追溯功能能够运行的前提是,测试用例已经被运行过,而且示波器收到了波形采集到了动态数据。

1,正向追溯 正向追溯是指:将测试用例和海量的代码执行信息自动关联,可精确到函数级别及代码块级别;经过正向追溯可直接在代码级定位测试现场故障和缺陷逻辑,并提供最后运行的时序数据;经过正向追溯自动记录产生功能对应的详细设计实现,辅助软件解耦和架构分析。

正向追溯的优点是:迅速定位缺陷对应的代码执行逻辑,帮助开发快速修复缺陷,可追踪难复现缺陷;精确、详尽的记录测试用例运行的状况,为精准软件测试提供大量原生分析性数据;能够进行过后的缺陷分析、追踪,辅助开发进行功能实现确认。

如图:点击测试用例追溯到这个成而是用例运行过得函数,选中一个函数,追溯到这个函数运行过得控制流程图的逻辑分支 如下是正向追溯到代码和函数调用图:

2,反向追溯

反向追溯是指:分析代码关联的功能,为研发分析系统和进行一致性修改以及回归测试分析提供精确数据。

反向追溯过程:点击须要查看的函数或函数中的某行代码,自动列出能够测试到该函数或者程序分支的测试用例

选择函数追溯到运行过该函数的测试用例,查看该函数的控制流程图和代码

点击代码,追溯到运行过该代码的测试用例  

5,简易流程图的展现

前置条件:版本有数据,关联源码可在代码视图有显示源码,而且在简易控制流

程图的分支块有具体语句显示,有覆盖率数据,可在简易控制流程图显示当前覆盖到的块信息  

简易控制流程图功能,以语句块的形式清晰的展现函数内部的控制逻辑,界面上能够直观的看出控制流各节点的测试覆盖状况,在展现中,简易控制流程图还能够经过颜色对每一个程序块进行覆盖率标识,在缩略图中整个模块的覆盖率很是直观。(背景色为绿色表示有测试用例覆盖到该块:以SC0覆盖为参考标准)

6,报表的展现

选择客户端所编译的项目和版本:

显示所选取编译项目的一些基本信息,包括:

项目指标信息、项目信息、版本信息、测试汇总信息、测试过程监控趋势图、测试设备组成和分布图、版本覆盖率汇总图、复杂度统计图

项目汇总:

包含项目信息:项目的详情信息

版本信息:版本的详情信息

测试汇总信息:测试用例经过率:无BUG的测试用例

BUG累计:测试用例运行完毕后提交的BUG数

当前版本覆盖率(SC0):(执行过可见段数/可见段数)*100%的比例

覆盖率增加:相比前一天的SC0增加差值

高复杂度预警函数个数:高复杂度的函数个数

测试用例列表:

显示制做的测试用例的详细信息,包括测试用例的名称、建立时间、执行时间、关联函数、覆盖率占比、运行状态、测试人员等  

覆盖率按日增加曲线图:

覆盖率按日增加曲线图,让管理者更好的把握测试过程  

测试漏洞列表:

在一个程序中,每每有成百上千的函数,这些函数有的是关联整个程序核心、有的则是开发人员弃而不用,但一直保留迟迟不愿删除的,针对这些大量的函数,“精准测试”采用经过静态、动态指标的综合分析,在大量的程序函数中,经过计算直接筛选潜在的高危的测试漏洞,经过报表给予展现。

 经过复杂度和覆盖率进行计算

 经过函数调用上下文和覆盖率进行计算 

相关文章
相关标签/搜索