java – 在spring boot中使用testNG进行单元测试需要时间来构建项目

我在 spring

-boot中创建了一个Web应用程序.我正在使用testNG为我的业务层编写单元测试.

我创建了Application类

@SpringBootApplication
public class TestApplication
{
    public static void main(String[] args)
    {
        SpringApplication.run(TestApplication.class, args);
    }

    @Bean
    Mapper mapper()
    {
        List<String> mappingFiles = new ArrayList<String>();
        mappingFiles.add("dozer-mappings.xml");
        return new DozerBeanMapper(mappingFiles);
    }
}

我的测试类看起来像

@ContextConfiguration(classes = { TestApplication.class })
public class CommissionRuleServiceTest extends AbstractTestNGSpringContextTests
{
     @InjectMocks
     @Autowired
     MyService

     @Mock
     MyDAO;

     @BeforeMethod
     public void initMock()
     {
          MockitoAnnotations.initMocks(this);
     }

     @Test(dataProvider = "....")
     ......
     ......
}

当我运行项目时,它会显示休息登录控制台,只需几次小测试就需要20.00秒.

日志中的一些语句是,

DEBUG o.s.c.i.s.PathMatchingResourcePatternResolver – Searching directory  DEBUG o.s.c.a.ConfigurationClassPostProcessor  DEBUG o.s.c.a.ClassPathBeanDefinitionScanner  DEBUG o.s.c.i.s.PathMatchingResourcePatternResolver  DEBUG o.s.b.f.s.DefaultListableBeanFactory  DEBUG o.a.c.b.converters.ArrayConverter  DEBUG org.dozer.loader.xml.XMLParser  DEBUG org.hibernate.cfg.SettingsFactory  DEBUG o.h.cfg.annotations.CollectionBinder  DEBUG o.h.cfg.annotations.TableBinder  DEBUG o.h.p.w.spi.MetamodelGraphWalker – Visiting attribute path : MyEntity  DEBUG o.s.b.f.s.DefaultListableBeanFactory  DEBUG org.hibernate.SQL

为什么要这么“休”时间?我该怎么办?

调查:

@SpringBootApplication注释等效于以下带有默认属性的注释:

> @Configuration – 表示该类包含一个或多个@Bean方法.与@ComponentScan一起播放.

> @EnableAutoConfiguration – 将尝试猜测并配置您可能需要的bean.根据您的应用程序,这可能会导致性能下降.

> @ComponentScan – 配置组件扫描.由于未定义包,因此将使用此注释从类的包中进行扫描.

如果没有更多的代码,就无法给出准确的猜测,但我认为大多数性能损失是由Spring Boot初始化引起的.

翻译自:https://stackoverflow.com/questions/30480046/unit-test-with-testng-in-spring-boot-takes-time-to-build-project

原文 

https://codeday.me/bug/20190111/507007.html

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » java – 在spring boot中使用testNG进行单元测试需要时间来构建项目

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址