ResourceManager : unable to find resource 'C:\Test\TestConfig\overview.vm' in any resource loader.
org.apache.velocity.exception.ResourceNotFoundException: Unable to find resource 'C:\Test\TestConfig\overview.vm'
at org.apache.velocity.runtime.resource.ResourceManagerImpl.loadResource(ResourceManagerImpl.java:474)
at org.apache.velocity.runtime.resource.ResourceManagerImpl.getResource(ResourceManagerImpl.java:352)
at org.apache.velocity.runtime.RuntimeInstance.getTemplate(RuntimeInstance.java:1533)
at org.apache.velocity.runtime.RuntimeInstance.getTemplate(RuntimeInstance.java:1514)
at org.apache.velocity.app.VelocityEngine.getTemplate(VelocityEngine.java:373)
at baseReport.GenerateReporter.generateReport(GenerateReporter.java:28)
at org.testng.TestNG.generateReports(TestNG.java:1076)
at org.testng.TestNG.run(TestNG.java:1001)
at org.testng.IDEARemoteTestNG.run(IDEARemoteTestNG.java:72)
at org.testng.RemoteTestNGStarter.main(RemoteTestNGStarter.java:123)html
致使的緣由是overview.vm路徑不正確java
換了一種寫法,註釋掉的是以前的,對比下apache
package baseReport; import org.apache.velocity.Template; import org.apache.velocity.VelocityContext; import org.apache.velocity.app.VelocityEngine; import org.testng.*; import org.testng.xml.XmlSuite; import java.io.*; import java.util.List; import java.util.Map; import java.util.Properties; public class GenerateReporter implements IReporter { @Override public void generateReport(List<XmlSuite> xmlSuites, List<ISuite> suites, String outputDirectory) { // TODO Auto-generated method stub try { // 初始化並取得Velocity引擎 VelocityEngine ve = new VelocityEngine(); Properties p = new Properties(); String fileDir=".//TestConfig/"; //p.setProperty("resource.loader", "class"); //p.setProperty("class.resource.loader.class", "org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader"); //ve.init(p); //Template t = ve.getTemplate("main/java/baseReport/overview.vm"); p.setProperty(ve.FILE_RESOURCE_LOADER_PATH, fileDir); //此處的fileDir能夠直接用絕對路徑來 ve.init(p); //初始化 Template t = ve.getTemplate("overview.vm");//此處只要指明文件名就能夠了. VelocityContext context = new VelocityContext(); for (ISuite suite : suites) { Map<String, ISuiteResult> suiteResults = suite.getResults(); for (ISuiteResult suiteResult : suiteResults.values()) { ReporterData data = new ReporterData(); ITestContext testContext = suiteResult.getTestContext(); // 把數據填入上下文 context.put("overView", data.testContext(testContext));//測試結果彙總信息 //ITestNGMethod[] allTests = testContext.getAllTestMethods();//全部的測試方法 //Collection<ITestNGMethod> excludeTests = testContext.getExcludedMethods();//未執行的測試方法 IResultMap passedTests = testContext.getPassedTests();//測試經過的測試方法 IResultMap failedTests = testContext.getFailedTests();//測試失敗的測試方法 IResultMap skippedTests = testContext.getSkippedTests();//測試跳過的測試方法 //IResultMap starttime=testContext.getStartDate(); //IResultMap endtime=testContext.getEndDate(); context.put("pass", data.testResults(passedTests, ITestResult.SUCCESS)); context.put("fail", data.testResults(failedTests, ITestResult.FAILURE)); context.put("skip", data.testResults(skippedTests, ITestResult.FAILURE)); } } // 輸出流 OutputStream out = new FileOutputStream("report.html"); Writer writer = new BufferedWriter(new OutputStreamWriter(out, "utf-8"));//解決亂碼問題 // 轉換輸出 t.merge(context, writer); //System.out.println(writer.toString()); writer.flush(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } }