spring boot单元测试

 

spring boot单元测试

 

CONTENT

01/

02/

断言assertThat

单元测试

03/

04/

单元测试覆盖率

 

controller单元测试

05/

jenkins测试报告

 

01

单元测试

 

PART ONE

幻灯片4

单元测试包引入

Spring Boot中引入单元测试很简单,依赖如下:

    org.springframework.boot

    spring-boot-starter-test

    test

引入spring-boot-starter-test后,有如下几个库:

 

- JUnit — The de-facto standard for unit testing Java applications.

- Spring Test & Spring Boot Test — Utilities and integration test support for Spring Boot applications.

- AssertJ — A fluent assertion library.

- Hamcrest — A library of matcher objects (also known as constraints or predicates).

- Mockito — A Java mocking framework.

- JSONassert — An assertion library for JSON.

- JsonPath — XPath for JSON.

幻灯片5

02

断言assertThat

 

PART TWO

幻灯片6

assertThat 的基本语法

assertThat 的基本语法如下:

 

清单 1 assertThat 基本语法

 

assertThat( [value], [matcher statement] );

 

    

 

 value 是接下来想要测试的变量值;

    matcher statement 是使用 Hamcrest 匹配符来表达的对前面变量所期望的值的声明,如果 value 值与 matcher statement 所表达的期望值相符,则测试成功,否则测试失败。

幻灯片7

assertThat优点

 

    优点 1:以前 JUnit 提供了很多的 assertion 语句,如:assertEquals,assertNotSame,assertFalse,assertTrue,assertNotNull,assertNull 等,现在有了 JUnit 4.4,一条 assertThat 即可以替代所有的 assertion 语句,这样可以在所有的单元测试中只使用一个断言方法,使得编写测试用例变得简单,代码风格变得统一,测试代码也更容易维护。

    优点 2:assertThat 使用了 Hamcrest 的 Matcher 匹配符,用户可以使用匹配符规定的匹配准则精确的指定一些想设定满足的条件,具有很强的易读性,而且使用起来更加灵活。如清单 2 所示:

 

// 想判断某个字符串 s 是否含有子字符串 "developer" 或 "Works" 中间的一个

// JUnit 4.4 以前的版本:assertTrue(s.indexOf("developer")>-1||s.indexOf("Works")>-1 );

// JUnit 4.4:

assertThat(s, anyOf(containsString("developer"), containsString("Works")));

// 匹配符 anyOf 表示任何一个条件满足则成立,类似于逻辑或 "||", 匹配符 containsString 表示是否含有参数子

// 字符串,文章接下来会对匹配符进行具体介绍

 

    优点 3:assertThat 不再像 assertEquals 那样,使用比较难懂的“谓宾主”语法模式(如:assertEquals(3, x);),相反,assertThat 使用了类似于“主谓宾”的易读语法模式(如:assertThat(x,is(3));),使得代码更加直观、易读。

    优点 4:可以将这些 Matcher 匹配符联合起来灵活使用,达到更多目的。如清单 3 所示:

    清单 3 Matcher 匹配符联合使用

幻灯片8

字符相关匹配符

/**equalTo匹配符断言被测的testedValue等于expectedValue,

* equalTo可以断言数值之间,字符串之间和对象之间是否相等,相当于Object的equals方法

*/

assertThat(testedValue, equalTo(expectedValue));

/**equalToIgnoringCase匹配符断言被测的字符串testedString

*在忽略大小写的情况下等于expectedString

*/

assertThat(testedString, equalToIgnoringCase(expectedString));

/**equalToIgnoringWhiteSpace匹配符断言被测的字符串testedString

*在忽略头尾的任意个空格的情况下等于expectedString,

*注意:字符串中的空格不能被忽略

 

*/

assertThat(testedString, equalToIgnoringWhiteSpace(expectedString);

/**containsString匹配符断言被测的字符串testedString包含子字符串subString**/

assertThat(testedString, containsString(subString) );

幻灯片9

/**endsWith匹配符断言被测的字符串testedString以子字符串suffix结尾*/

assertThat(testedString, endsWith(suffix));

/**startsWith匹配符断言被测的字符串testedString以子字符串prefix开始*/

assertThat(testedString, startsWith(prefix));

一般匹配符

/**nullValue()匹配符断言被测object的值为null*/

assertThat(object,nullValue());

/**notNullValue()匹配符断言被测object的值不为null*/

assertThat(object,notNullValue());

/**is匹配符断言被测的object等于后面给出匹配表达式*/

assertThat(testedString, is(equalTo(expectedValue)));

/**is匹配符简写应用之一,is(equalTo(x))的简写,断言testedValue等于expectedValue*/

assertThat(testedValue, is(expectedValue));

/**is匹配符简写应用之二,is(instanceOf(SomeClass.class))的简写,

*断言testedObject为Cheddar的实例

*/

assertThat(testedObject, is(Cheddar.class));

/**not匹配符和is匹配符正好相反,断言被测的object不等于后面给出的object*/

幻灯片10

assertThat(testedString, not(expectedString));

/**allOf匹配符断言符合所有条件,相当于“与”(&&)*/

assertThat(testedNumber, allOf( greaterThan(8), lessThan(16) ) );

/**anyOf匹配符断言符合条件之一,相当于“或”(||)*/

assertThat(testedNumber, anyOf( greaterThan(16), lessThan(8) ) );

数值相关匹配符

/**closeTo匹配符断言被测的浮点型数testedDouble在20.0¡À0.5范围之内*/

assertThat(testedDouble, closeTo( 20.0, 0.5 ));

/**greaterThan匹配符断言被测的数值testedNumber大于16.0*/

assertThat(testedNumber, greaterThan(16.0));

/** lessThan匹配符断言被测的数值testedNumber小于16.0*/

assertThat(testedNumber, lessThan (16.0));

/** greaterThanOrEqualTo匹配符断言被测的数值testedNumber大于等于16.0*/

assertThat(testedNumber, greaterThanOrEqualTo (16.0));

/** lessThanOrEqualTo匹配符断言被测的testedNumber小于等于16.0*/

assertThat(testedNumber, lessThanOrEqualTo (16.0));

集合相关匹配符

 

幻灯片11

 

/**hasEntry匹配符断言被测的Map对象mapObject含有一个键值为"key"对应元素值为"value"的Entry项*/

assertThat(mapObject, hasEntry("key", "value" ) );

/**hasItem匹配符表明被测的迭代对象iterableObject含有元素element项则测试通过*/

assertThat(iterableObject, hasItem (element));

/** hasKey匹配符断言被测的Map对象mapObject含有键值“key”*/

assertThat(mapObject, hasKey ("key"));

/** hasValue匹配符断言被测的Map对象mapObject含有元素值value*/

assertThat(mapObject, hasValue(value));

 

03

Controller单元测试

 

PART TWO

 

单元测试官网参考

可以参考:

 

https://spring.io/guides/gs/testing-web/

@WebMvcTest(SignController.class)可以只跑一个controller;它只能跑动controller等注释,无法跑动下面的component等注释;所以它的service里有bean注释都可能失败。

@SpringBootTest启动了整个springbootApplication

 

TestRestTemplate的使用

 

vscode里查看打印。ctrl shift p,选择java显示测试输出,或者“打开测试运行日志”(这个太大)

 

 

05

单元测试覆盖率

 

PART FIVE

bug解决: http://www.itdaan.com/blog/2013/08/07/8d1f01cf4d2c4a8560193c14b650d856.html

工程与jenkins安装 : https://ningyu1.github.io/site/post/77-jenkins-sonarqube-jacoco-junit/

幻灯片15

幻灯片16

06

使用AllureReport生成测试报告

 

PART SIX

工程使用:https://www.jianshu.com/p/b5a6e902c9d4

jenkins使用:https://blog.csdn.net/MenofGod/article/details/80858416

幻灯片17

幻灯片18

THANK YOU

 

你可能感兴趣的:(JAVA,服务容器)