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

问题
    我是使用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参数:


   
    设置后再执行测试用例,发现还是乱码!


    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,运行测试用例,终于看到我梦寐以求的正常中文了:


猜你喜欢

转载自stamen.iteye.com/blog/1897286