Junit
pom文件中引入junit依赖,如
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
<scope>test</scope>
</dependency>
</dependencies>
https://mvnrepository.com/
在 src/test/ 下创建包和测试类。
要求:
- 测试方法上必须使用@Test
- 测试方法必须使用 public void进行修饰
- 测试类的包应该和被测试类的包一样
- 测试单元中的每个方法一定要能够独立测试,其方法不能有任何依赖
import org.junit.Test;
public class GargantuaTest {
@Test
public void test1(){
assert(1 == 0);
}
}
其他注解:
- @BeforeClass:修饰的方法会在所有方法被调用前执行,且该方法是静态的,当测试类被加载后就接着运行它,且在内存中只会存在一份实例。针对所有测试,只执行一次(他比较适合加载配置文件,建立数据库连接等 )
- @AfterClass:所修饰的方法会在所有测试结束后执行,针对当前运行的所有测试,只执行一次 。(通常用来对资源管理,如关闭数据库连接,关闭流)
- @Before和@After 会在每个测试方法前后各自动执行一次
- @Ignore:忽略的测试方法
测试结果中 Failure和error
-
Failure 一般由测试单元使用断言方法判断失败引起的,这个报错,说明测试点发现了问题,即程序输出的结果和我们预期的不一样 -
error 是由代码异常引起的,它可以产生代码本身的错误,也可以是测试代码中的一个隐藏bug
Spring Boot 整合 Junit
pom文件中引入junit依赖,如
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<version>2.1.1.RELEASE</version>
<scope>test</scope>
</dependency>
其中依赖了 Junit 4.13.2
在 src/test/ 下创建包和测试类。
要求:(对上述 Junit 的补充) 由于一个项目中会写很多很多测试类,而测试类上面是需要以下几个注解的,每建一个类都去补注解,太麻烦,我们就在这个类中加上注解,作为BaseTest,其他测试类直接继承这个类就好了。
import org.junit.After;
import org.junit.Before;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.test.context.web.WebAppConfiguration;
/**
* 单元测试基类
*/
@RunWith(SpringRunner.class)
@SpringBootTest(classes = Application.class)
@WebAppConfiguration //对于Web项目,Junit需要模拟ServletContext,因此我们需要给我们的测试类加上
public class BaseTest
{
@BeforeClass
public void init() {
System.out.println("获取数据库连接----------------");
}
@AfterClass
public void destory() {
System.out.println("关闭连接----------------");
}
}
测试类要求如Junit 中要求和使用都一致
public class GargantuaTest extends BaseTest {
@Autowired
private MyService myService;
@Test
public void test1(){
assert(1 == myService.count());
}
}
|