单元测试
1.引入依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency>
2.创建业务
@Repository public class UserDaoImpl implements UserDao { @Override public void insertUser() { System.out.println("-------userDao 方法执行了------"); } }
@Service public class UserServiceImpl implements UserService { @Resource private UserDao userDao; @Override public void insertUser() { userDao.insertUser(); } }
3.单元测试
@RunWith(SpringRunner.class) // 指定启动器 @SpringBootTest(classes = {SpringbootExceptionApplication.class}) public class SpringbootExceptionApplicationTests { @Resource private UserService userService; @Test public void contextLoads() { userService.insertUser(); } }
注意SpringRunner继承自SpringJUnit4ClassRunner
测试效果
4. Junit基本注解介绍
注解 | 说明 |
---|---|
@BeforeClass | 在所有测试方法前执行一次,一般在其中写上整体初始化的代码 |
@AfterClass | 在所有测试方法后执行一次,一般在其中写上销毁和释放资源的代码 |
@Before | 在每个测试方法前执行,一般用来初始化方法(比如我们在测试别的方法时,类中与其他测试方法共享的值已经被改变,为了保证测试结果的有效性,我们会在@Before注解的方法中重置数据) |
@After | 在每个测试方法后执行,在方法执行完成后要做的事情 |
@Test(timeout = 1000) | 测试方法执行超过1000毫秒后算超时,测试将失败 |
@Test(expected = Exception.class) | 测试方法期望得到的异常类,如果方法执行没有抛出指定的异常,则测试失败 |
@Ignore(“not ready yet”) | 执行测试时将忽略掉此方法,如果用于修饰类,则忽略整个类 |
@Test | 编写一般测试用例 |
@RunWith | 在JUnit中有很多个Runner,他们负责调用你的测试代码,每一个Runner都有各自的特殊功能,你要根据需要选择不同的Runner来运行你的测试代码。如果我们只是简单的做普通Java测试,不涉及Spring Web项目,你可以省略@RunWith注解,这样系统会自动使用默认Runner来运行你的代码。 |
文章来源: https://blog.csdn.net/qq_38526573/article/details/90289160