• 12
  • 12
分享

一、单元测试的目的

       单元测试是编写测试代码,用以检测特定的、明确的、细颗粒的功能! 严格来说,单元测试只针对功能点进行测试,不包括对业务流程正确性的测试。现在一般公司都会进行业务流程的测试,这也要求测试人员需要了解需求! 测试人员也不好过啊~~

       目前开发所用的单元是Junit框架,在大多数java的开发环境中已经集成,可以方便开发自己调用!

       注意:单元测试不仅仅是要保证代码的正确性,一份好的单元测试报告,还要完整地记录问题的所在和缺陷以及正确的状态,方便后面代码的修复,重构和改进!

二、单元测试做什么

       一般来说,一份单元测试主要包括以下几个方面:

       1.接口功能性测试

       接口功能的正确性,即保证接口能够被正常调用,并输出有效数据!

(1) 是否被顺利调用

(2)参数是否符合预期

       2.局部数据结构测试

       保证数据结构的正确性

(1)变量是否有初始值或在某场景下是否有默认值

(2)变量是否溢出

       3.边界条件测试

(1)变量无赋值(null)

(2)变量是数值或字符

(3)主要边界:最大值,最小值,无穷大

(4) 溢出边界:在边界外面取值+/-1

(5)临近边界:在边界值之内取值+/-1

(6)字符串的边界,引用 "变量字符"的边界

(7)字符串的设置,空字符串

(8)字符串的应用长度测试

(9)空白集合

(10) 目标集合的类型和应用边界

(11) 集合的次序

(12)变量是规律的,测试无穷大的极限,无穷小的极限

       4.所有独立代码测试

       保证每一句代码,所有分支都测试完成,主要包括代码覆盖率,异常处理通路测试

(1)语句覆盖率:每个语句都执行到了

(2)判定覆盖率:每个分支都执行到了

(3)条件覆盖率:每个条件都返回布尔

(4)路径覆盖率:每个路径都覆盖到了

       5.异常模块测试、后续处理模块测试:

       是否包闭当前异常或者对异常形成消化,是否影响结果!

三、JAVA的单元测试JUNIT4

       1.业务流程的一般是按照需求的预期效果,跑完整个业务流程,包括以前开发的流程

(1)是否实现了预期

(2) 是否影响到了以前的流程

(3)全流程是否顺利

(4)数据是否符合预期

       2.代码测试:

@BeforeClass 全局只会执行一次,而且是第一个运行
@Before 在测试方法运行之前运行
@Test 测试方法
@After 在测试方法运行之后允许
@AfterClass 全局只会执行一次,而且是最后一个运行
@Ignore 忽略此方法

       JUNIT4是以org.junit为框架进行的测试,以注解的形式来识别代码中需要测试的方法!

       注意:

       对于每一个测试,我们都应该保持独立测试,以确保测试结果是有意义的。在程序中,经常会出现,当测试完一个方法后,其参数已经被系统保持或持久化下来。无疑会造成下一次的测试测试数据或者状态的不合理性!为了解决问题,对于此类场景,我们的测试代码必须具备初始化和收尾的能力。也即是@Before和@After的意义所在!

       同理@AfterClass和BeforeClass即是为了满足测试中,那些体积非常大,但只要一次初始化的代码块!

       3.断言测试与及常用断言:

       assertEquals:

Assert.assertEquals("此处输出提示语", 5, result);
 
===================================================================================================================
解析:"此处输出提示语" 为错误时你个人想要输出的错误信息; 5  是指你期望的值;result 是指你调用程序后程序输出给你的结果
 
@Test(expected = NullPointerException.class)  
解析:在注解的时候添加expected 为忽略此异常
@Test(timeout  =   5000 ):超时设置
@Test(expected  =  XXXXException. class):期望出现异常,如果出现该异常则成功,否则测试失败
@Ignore() :用户方法之上,被注解的方法会被成功需忽略
===================================================================================================================
 
fail("Not yet implemented")
解析:放在方法中,如果我顺利地执行,我就报失败出来。就是说按道理不应该执行到这里的,但是偏偏执行了,说明程序有问题
===================================================================================================================
Assert.assertTrue("msg",boolean)与Assert.assertFalse("msg",boolean)
解析:如果和预期一样为true则成功,否则失败输出msg;如果和预期一样为false则成功,否则失败并输出

       assertNull("msg",boolean)与assertNotNull("msg",boolean)

       解析:assertNull与assertNotNull可以验证所测试的对象是否为空或不为空,如果和预期的相同则测试成功,否则测试失败!

       主要常用方法 :

       断言列表:

(1)assertTrue(String message, boolean condition)

       要求condition == true

(2)assertFalse(String message, boolean condition)

       要求condition == false

(3)assertEquals(String message, XXX expected,XXX actual)

       要求expected期望的值能够等于actual

(4)assertArrayEquals(String message, XXX[] expecteds,XXX [] actuals)

       要求expected.equalsArray(actual)

(5)assertNotNull(String message, Object object)

       要求object!=null

(6)assertNull(String message, Object object)

       要求object==null

(7)assertSame(String message, Object expected, Object actual)

       要求expected == actual

(8)assertNotSame(String message, Object unexpected,Object actual)

       要求expected != actual

(9)assertThat(String reason, T actual, Matcher matcher)

       要求matcher.matches(actual) == true

(10)fail(String message)

       要求执行的目标结构必然失败,同样要求代码不可达,即是这个方法在程序运行后不会成功返回,如果成功返回了则报错

       4.运行器指定

       单元测试中,每个类都是由于JUNIT4框架中的Runner运行器来执行的。一般情况下,在没有指定运行器的时候,是由系统默认选择(TestClassRunner)的运行器执行。包括类中的所有方法都是由该运行器负责调用和执行。当我们需要指定的时候,则通过类级别注解 @Run Wirth(xxxxxx)进行选择,一般是根据不同类型选择不同执行器,可以提高效率也可以应用于某种特殊场景!

       5.参数化测试

@RunWith(Parameterized. class )
 public   class  TestParam {
 
     private   static  Calculator calculator  =   new  Calculator(); //需要测试的类
     private   int  param; 
     private   int  result;
 
     @Parameters
     public   static  Collection data(){
    return  Arrays.asList(new  Object[][] {{ 11 ,  17 } , { xx1 ,  xx} } );
     } 
     //有参构造,在实例的时候实现参数初始化
     public  TestParam( int  param,  int  result){
     this .param  =  param;
     this .result  =  result;
     } 
     @Test
     public  void  TestResult(){
    calculator.square(param);
     assertEquals(result, calculator.getResult()); 
     } 
}

       参数化测试的目标是为了一次性完成同类型测试,将相同类型的数据按照一定的顺序批量地传入测试方法,并得出结论!其本质是一个批量的化的操作,只是为了方便我们测试而进行了封装。我们只有提供测试的方法以及按照一定的顺序进行设置则可以。

(1)进行类注解:@RunWith(Parameterized.class),为了测试类指定一个ParameterizedRunner运行器

(2)进行参数设置:将测试结果和期望结果,以每一组都是一个数组的形式存放以形成二维数组,转化为list返回并注解。

(3)参数初始化:设置测试方法要入参的参数,并按照"参数设置"的顺序利用构造方法进行初始化的赋值!

(4)测试调用:写一个测试方法进行调用,将参数传递到要测试的类的方法中并返回数据

       注意:参数化测试需要创建一单独用于测试的测试类。并定义两个变量用于接受测试结果和预期目标。数据存放以二维数组的方式,两个为一组。接着便是通过构造方法进行数据初始化。 构造方法入参的顺序要和二维数组中国每一组存放的数据顺序保持一致。

       6.打包测试

@RunWith(Suite. class )
@Suite.SuiteClasses( {CalculatorTest. class ,SquareTest. class } )
public   class  AllCalculatorTests  {
    //to do something;
} 
==========================================================================================================================
解析:将有需要的一起执行程序一起打包,然后执行
运行器:Suite. class

       我们把需要打包一起测试的测试类作为参数传递给该注解。然后直接运行代码,此处的测试类可以直接设置为空,只需要添加注解便OK 。


作者:mcxbl

原文链接:https://www.cnblogs.com/mcxbl/p/13765360.html

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 输入框1、字符型输入框:单行文本输入框:英文全角、英文半角、数字、空或者空格、特殊字符“~!@#¥%……&*?[]{}”,特别要注意单引号和&符号。如果禁止直接输入特殊字符时,使用“粘贴、拷贝”功能尝试输入;长度检查:最小长度、最大长度、最小长度-1、最大长度+1、输入超过字符比如把整个文章拷贝过去;空格检查:输入的字符间有空格、字符前有空格、字符后有空格、字符前后有空格;多行文本框输入:允许回车换行、保存后再显示能够保存输入的格式、仅输入回车换行,检查能否正确保存(若能,检查保存结果,若不能,查看是否有正常提示);安全性检查:输入特殊字符串(null,NULL ,javasc...
            12 14 3857
            分享
          • 这个面试题碰到过很多次,再次总结下来。具体需求:有一个登陆页面,上面有2个textbox,一个提交按钮。请针对这个页面设计30个以上的testcase。此题的考察目的:面试者是否熟悉各种测试方法,是否有丰富的Web测试经验,是否了解Web开发,以及设计Testcase的能力。这个题目还是相当有难度的,一般的人很难把这个题目回答好。阅读目录功能测试(Functiontest)输入正确的用户名和密码,点击提交按钮,验证是否能正确登录;输入错误的用户名或者密码,验证登录会失败,并且提示相应的错误信息;登录成功后能否能否跳转到正确的页面;用户名和密码,如果太短或者太长,应该怎么处理;用户名和密码,中有...
            13 13 1602
            分享
          •   前言  在此之前我搜集一些关于测试用例的知识,后来在我们的QQ群里专门定了一期讨论,来探讨测试用例,毕竟这是一个很大的话题,很难做到面面俱到,但我会尽量全面,用通俗的语言来说测试用例。  1、测试用例(test cases)的概念是什么?  测试用例是一组有条件的用例,QA可以依靠这些条件来确定应用程序、软件系统或某些功能是否按预期执行。  测试用例是QA执行的单个可执行测试。它指导QA完成测试的步骤。你可以将测试用例看作是一组按部就班的指令,以验证某些功能是否符合需求。  2、设计测试用例的步骤  Step 1:定义测试流程目标  首先,你需要了解软件需求规范。  当开始为软件的功能特性...
            0 0 1492
            分享
          • 当项目已经上线并且趋于稳定,测试人员就不会每天对版本做一轮又一轮的回归测试。这时,开发在迭代版本中改动一点代码,没有告知测试人员,那么测试人员很难发现由改动引发的BUG。   这种情况下,测试人员确实无奈:产品也好、开发也罢,不主动告知改动内容,测试人员会把它默认成为上一个稳定版本,不会整天放精力在这类版本的回归测试中。再者,测试人员每天都对所有项目做手工的回归测试也不现实。这造成测试人员很被动。测试人员若想提高产品质量只能寄希望于高效的团队管理,加上与产品、开发人员的及时沟通、提醒。   测试人员能不能改变这种被动的局面,全权掌握版本的...
            5 2 2994
            分享
          • Newman 是 Postman 推出的一个 nodejs 库,直接来说就是 Postman 的json文件可以在命令行执行的插件。 Newman 可以方便地运行和测试集合,并用之构造接口自动化测试和持续集成。1、下载Node.js并安装 检查是否安装成功:打开cmd,输入node -v如果输出node的版本信息,则证明安装成功。2、安装Newman,输入npm install -g newman注意:newman必须要跟nodejs处于一个文件当中,才可以安装成功,否则会报错,检查newman是否安装成...
            0 0 1708
            分享
      • 51testing软件测试圈微信