22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 1 | package com.example.myproject.controller; |
| 2 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 3 | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| 4 | import com.example.myproject.entity.User; |
| 5 | import com.example.myproject.service.EmailService; |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 6 | import com.example.myproject.service.UserService; |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 7 | import com.example.myproject.mapper.UserMapper; |
| 8 | import com.example.myproject.mapper.VerificationTokenMapper; |
| 9 | import com.example.myproject.common.base.Result; |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 10 | import org.junit.jupiter.api.BeforeEach; |
| 11 | import org.junit.jupiter.api.Test; |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 12 | import org.mockito.*; |
| 13 | import org.springframework.http.ResponseEntity; |
| 14 | import org.springframework.security.authentication.AuthenticationManager; |
| 15 | import org.springframework.security.core.Authentication; |
| 16 | import org.springframework.security.core.AuthenticationException; |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 17 | |
22301138 | 1c35910 | 2025-06-03 15:19:59 +0800 | [diff] [blame] | 18 | import static org.junit.jupiter.api.Assertions.*; |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 19 | import static org.mockito.Mockito.*; |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 20 | |
| 21 | class UserControllerTest { |
| 22 | |
| 23 | @InjectMocks |
| 24 | private UserController userController; |
| 25 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 26 | @Mock |
| 27 | private UserService userService; |
| 28 | @Mock |
| 29 | private UserMapper userMapper; |
| 30 | @Mock |
| 31 | private EmailService emailService; |
| 32 | @Mock |
| 33 | private AuthenticationManager authenticationManager; |
| 34 | @Mock |
| 35 | private VerificationTokenMapper verificationTokenMapper; |
| 36 | |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 37 | @BeforeEach |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 38 | void setup() { |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 39 | MockitoAnnotations.openMocks(this); |
| 40 | } |
| 41 | |
| 42 | @Test |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 43 | void loginController_success() { |
| 44 | String username = "testuser"; |
| 45 | String password = "testpass"; |
| 46 | User mockUser = new User(); |
| 47 | mockUser.setUsername(username); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 48 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 49 | Authentication mockAuth = mock(Authentication.class); |
| 50 | when(authenticationManager.authenticate(any())).thenReturn(mockAuth); |
| 51 | when(userMapper.selectOne(any(QueryWrapper.class))).thenReturn(mockUser); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 52 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 53 | Result result = userController.loginController(username, password); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 54 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 55 | assertEquals("200", result.getCode()); |
| 56 | assertEquals(mockUser, result.getData()); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 57 | } |
| 58 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 59 | |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 60 | @Test |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 61 | void loginController_failure() { |
| 62 | String username = "user"; |
| 63 | String password = "wrongpass"; |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 64 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 65 | // 模拟认证失败,抛出 Bad credentials 异常 |
| 66 | when(authenticationManager.authenticate(any())) |
| 67 | .thenThrow(new AuthenticationException("Bad credentials") {}); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 68 | |
| 69 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 70 | // 调用登录接口 |
| 71 | Result result = userController.loginController(username, password); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 72 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 73 | // 断言返回的状态码和消息 |
| 74 | assertEquals("401", result.getCode()); |
| 75 | assertTrue(result.getMsg().contains("登录失败")); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 76 | } |
| 77 | |
| 78 | @Test |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 79 | void registerController_emailExists() { |
| 80 | User user = new User(); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 81 | user.setEmail("test@example.com"); |
| 82 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 83 | when(userService.checkEmailExists(user.getEmail())).thenReturn(true); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 84 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 85 | Result result = userController.registerController(user); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 86 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 87 | assertEquals("邮箱冲突", result.getCode()); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 88 | } |
| 89 | |
| 90 | @Test |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 91 | void registerController_success() { |
| 92 | User user = new User(); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 93 | user.setEmail("test@example.com"); |
| 94 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 95 | when(userService.checkEmailExists(user.getEmail())).thenReturn(false); |
| 96 | when(userService.preRegisterUser(user)).thenReturn(true); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 97 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 98 | Result result = userController.registerController(user); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 99 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 100 | assertEquals("200", result.getCode()); |
| 101 | assertEquals(user.getEmail(), ((User) result.getData()).getEmail()); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 102 | } |
| 103 | |
| 104 | @Test |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 105 | void verifyEmailCode_success() { |
| 106 | when(userService.verifyEmail("test@example.com", "123456")).thenReturn(true); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 107 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 108 | UserController.VerificationRequest request = new UserController.VerificationRequest(); |
| 109 | request.setEmail("test@example.com"); |
| 110 | request.setCode("123456"); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 111 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 112 | Result result = userController.verifyEmailCode(request); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 113 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 114 | assertEquals("200", result.getCode()); |
| 115 | } |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 116 | |
22301115 | 90135d7 | 2025-06-03 17:11:40 +0800 | [diff] [blame^] | 117 | @Test |
| 118 | void verifyEmailCode_failure() { |
| 119 | when(userService.verifyEmail("test@example.com", "000000")).thenReturn(false); |
| 120 | |
| 121 | UserController.VerificationRequest request = new UserController.VerificationRequest(); |
| 122 | request.setEmail("test@example.com"); |
| 123 | request.setCode("000000"); |
| 124 | |
| 125 | Result result = userController.verifyEmailCode(request); |
| 126 | |
| 127 | assertEquals("验证失败", result.getCode()); |
| 128 | } |
| 129 | |
| 130 | @Test |
| 131 | void checkPassword_success() { |
| 132 | when(userService.checkPassword(1L, "abc123")).thenReturn(true); |
| 133 | |
| 134 | Result<String> result = userController.checkPassword(1L, "abc123"); |
| 135 | |
| 136 | assertEquals("200", result.getCode()); |
| 137 | assertEquals("原始密码输入正确", result.getMsg()); |
| 138 | } |
| 139 | |
| 140 | @Test |
| 141 | void checkPassword_failure() { |
| 142 | when(userService.checkPassword(1L, "wrong")).thenReturn(false); |
| 143 | |
| 144 | Result<String> result = userController.checkPassword(1L, "wrong"); |
| 145 | |
| 146 | assertEquals("305", result.getCode()); |
| 147 | assertEquals("原始密码输入错误", result.getMsg()); |
| 148 | } |
| 149 | |
| 150 | @Test |
| 151 | void sendVerificationEmail_userNotFound() { |
| 152 | UserController.EmailRequest request = new UserController.EmailRequest(); |
| 153 | request.setEmail("notfound@example.com"); |
| 154 | |
| 155 | when(userMapper.selectOne(any())).thenReturn(null); |
| 156 | |
| 157 | ResponseEntity<Result> response = userController.sendVerificationEmail(request); |
| 158 | |
| 159 | assertEquals(400, response.getStatusCodeValue()); |
| 160 | assertEquals("1", response.getBody().getCode()); |
22301115 | cf6dba2 | 2025-03-25 19:06:21 +0800 | [diff] [blame] | 161 | } |
| 162 | } |