MockIto插桩常规单元测试

文章目录

业务场景

针对MessageSendServiceImpl完成相关方法的单元测试用例

常规service方法

常规sercive方法 implements MessageSendService,没有继承MybatisServiceImpl,因为成员变量都是被final修饰,Test方法中通过new构造函数的方法完成注入

java 复制代码
@Slf4j
@Service
@AllArgsConstructor
public class MessageSendServiceImpl implements MessageSendService {
    
    /**
     * 消息渠道管理服务.
     */
    private final MessagexxxManager messagexxManager;
    
    /**
     * 消息模板管理服务.
     */
    private final MessageyyeManager messageyyManager;
    
    /**
     * kafka操作template.
     */
    private final KafkaTemplate<String, String> kafkaTemplate;
    
   
    @Override
    public ApiResultDto<String> sendMessage(MessageSendDto messageSendDto) {
        log.info("receive a request to send message with parameter : {}", messageSendDto);
        
        // 必要参数非空验证.
        if (!necessaryNotNull(messageSendDto)) {
            return ApiResultDto.failed(ApiErrorCode.VALID_FAILED, "消息参数错误");
        }
        xxx
        return ApiResultDto.success(kafkaParam.getBatchId());
    }
}

单元测试

java 复制代码
@Slf4j
@ExtendWith(MockitoExtension.class)
@SuppressWarnings("checkstyle:all")
class MessageSendServiceImplTest {
    
    /**
     * 消息渠道管理服务.
     */
    @Mock
    private MessagexxxManager messagexxxManager;
    
    /**
     * 消息模板管理服务.
     */
    @Mock
    private MessageyyyManager messageyyyManager;
    
    /**
     * kafka操作template.
     */
    @Mock
    private KafkaTemplate<String, String> kafkaTemplate;
   
    /**
     * 消息发送Service.
     */
    private MessageSendServiceImpl messageSendService;
 
    @BeforeEach
    void initialMessageSendService() {
        this.messageSendService = new MessageSendServiceImpl(messageChannelManager, messageTemplateManager, kafkaTemplate);
    }

      @Test
    @DisplayName("测试发送消息")
    void testSendByMessageId_Success_thirdParty() {
        // Arrange
        MessageChannelEntity messageChannel = JacksonUtils.tryStr2Bean("xxx", MessageChannelEntity.class);
        MessageTemplateEntity messageTemplate = JacksonUtils.tryStr2Bean("xx", MessageTemplateEntity.class);
        Mockito.doReturn(messageChannel).when(messageChannelManager).getById(any());
        Mockito.doReturn(messageTemplate).when(messageTemplateManager).getById(any());
        Mockito.doReturn(new ThirdPartyApiProcessor(apiCallService, callChainService)).when(processorFactory).getMessageProcessor(any());
        // Act
        MessageSendDto messageSendDto = getThirdPartyMessageSendDto();
        messageSendDto.setTemplateId(UUID.randomUUID());
        ApiResultDto<String> result = messageSendService.sendMessage(messageSendDto);
        // Assert
        assertThat(result.getEr()).isEqualTo(ApiErrorCode.SUCCESS.getCode());
    }
  }
相关推荐
LUCIAZZZ35 分钟前
简单的SQL语句的快速复习
java·数据库·sql
komo莫莫da1 小时前
寒假刷题Day19
java·开发语言
小小虫码1 小时前
项目中用的网关Gateway及SpringCloud
spring·spring cloud·gateway
S-X-S2 小时前
算法总结-数组/字符串
java·数据结构·算法
linwq82 小时前
设计模式学习(二)
java·学习·设计模式
桦说编程2 小时前
CompletableFuture 超时功能有大坑!使用不当直接生产事故!
java·性能优化·函数式编程·并发编程
@_@哆啦A梦3 小时前
Redis 基础命令
java·数据库·redis
字节全栈_rJF3 小时前
性能测试 —— Tomcat监控与调优:status页监控_tomcat 自带监控
java·tomcat
圣心4 小时前
Kafka 使用说明(kafka官方文档中文)
分布式·kafka·linq
圣心4 小时前
Kafka中文文档
分布式·kafka