欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

关于Idea testng单元测试乱码的解决

程序员文章站 2022-04-15 20:29:06
...
问题
    我是使用intellij idea的,项目使用UTF-8编码,但发现一个奇怪的乱码问题,病征如下:
  • 执行public static void main(){}的程序时,打印的中文是正常的;
  • 执行单元测试用例(testng),打印出的中文却是乱码的;
  • 使用Maven的命令执行测试用例,中文显示出是正常的(注:Maven执行的中文乱码解决,参见:http://budairenqin.iteye.com/blog/1336314


分析
  
   1)由于执行main()是正常的,而执行测试用例却是错误的,说明compile是没有问题的,否则main()执行时就不会正常显示中文了,因此可以不去管compile的VM参数(注:如果是compile期出了问题,则需要为javac设置"-encoding UTF-8 "参数,在idea中,是通过ctrl+alt+s-compiler>java compiler->additional command line parameters设置);

   2)main()执行正常,说明通过java运行代码的编码是正常的。通过Maven执行单元测试也是正常的,说明通过Maven显示给testng指定了编码,单元测试就正常了。现在直接通过idea调用testng执行测试用例就乱码了,所以问题应该出在idea没有正确给testng执行器传递正常的项目编码,因此乱码就产生了。在idea中运行测试用例时,其命令可以通过控制台输出的命令查看:
引用

...
com.intellij.rt.execution.application.AppMain org.testng.RemoteTestNGStarter
...

   所以,我推测问题应该是出在org.testng.RemoteTestNGStarter上,它执行测试用例时,编码使用了系统默认的GB2312,而没有正确地采用UTF-8.

解决

    1)问题清楚了,首先想到的是有没有办法显示给org.testng.RemoteTestNGStarter指定编码类型呢,我尝试通过更改测试的运行配置来设置VM参数:
    Run->Edit configuration->TestNG->对应的测试用例,添加VM参数:

关于Idea testng单元测试乱码的解决
            
    
    博客分类: 09_构建及版本05_程序测试02_企业应用
   
    设置后再执行测试用例,发现还是乱码!


    2)那没有辙了,我只是使出杀手锏--更改idea的启动VM参数了:
    
    到<idea_home>\bin下找到idea64.exe对应的idea64.exe.vmoptions(注:如果你使用idea.exe启动idea,则去改idea.exe.vmoptions),打开之:
-Xms128m
-Xmx1024m
-XX:MaxPermSize=350m
-XX:ReservedCodeCacheSize=96m
-XX:+UseCodeCacheFlushing
-ea
-Dsun.io.useCanonCaches=false
-Djava.net.preferIPv4Stack=true
-Dfile.encoding=UTF8

   添加如上的
引用
-Dfile.encoding=UTF8
在末尾,重新启动idea,运行测试用例,终于看到我梦寐以求的正常中文了:

关于Idea testng单元测试乱码的解决
            
    
    博客分类: 09_构建及版本05_程序测试02_企业应用
  • 关于Idea testng单元测试乱码的解决
            
    
    博客分类: 09_构建及版本05_程序测试02_企业应用
  • 大小: 90.9 KB
  • 关于Idea testng单元测试乱码的解决
            
    
    博客分类: 09_构建及版本05_程序测试02_企业应用
  • 大小: 114.1 KB

上一篇: Mockito

下一篇: HMAC简介