2016-08-25 122 views
0

我的TestNg腳本使用DataProvider使用來自Excel的輸入數據。當我從Eclipse運行testng.xml文件時,它工作正常。 但是,當我嘗試從.bat文件運行同樣的功能時,它不起作用。它嘗試打開Excel文件時失敗。 請幫忙。TestNG腳本無法從.bat文件運行時打開Excel

這是我的DataProvider類:

@DataProvider(name="DataProvider") 
public static Object[][] passExcelData(Method m) throws BiffException, IOException 
{ 
    String sheetName = m.getName(); 
    config = new ExcelDataConfig("inputData.xlsx", sheetName); 
    int rows = config.getRowCount(sheetName); 
    int cols = config.getColCount(sheetName); 
    Object[][] data = new Object[rows][cols]; 

    for(int i=0; i<rows; i++) 
    { 
     for(int j=0; j<cols; j++) 
     { 
      data[i][j] = config.getData(sheetName, i, j); 
     } 
    } 
    return data; 
    } 

而且下面是BeforeClass和測試調用的DataProvider:

@BeforeClass 
public void setup() throws InterruptedException 
{ 
    System.setProperty("webdriver.chrome.driver", rootFolder +"Drivers\\chromedriver.exe"); 
    driver = new ChromeDriver(); 
    driver.manage().timeouts().implicitlyWait(30, TimeUnit.SECONDS); 
    driver.manage().window().maximize(); 
    System.out.println("setup done"); 
} 

@Test(priority = 7, dataProvider="DataProvider") 
public void EmailAlerts(String Product, String URL, String username, String password) throws InterruptedException 
{ 
    functionName = Product + "_EmailAlerts_" +username; 
    HomePage(URL); 
    Login.loginProcess(username, password); 
    EmailAlerts.EmailAlerts_Process(); 
    Logout(); 
} 

它沒有經過任何錯誤本身。 BeforeClass運行沒有問題。它打開瀏覽器並顯示「安裝完成」消息。它甚至調用DataProvider類,但無法打開excel文件。 只有從.bat文件運行時纔會出現此問題。如果我從excel部分讀取數據並在DataProvider類中對輸入數據進行硬編碼 - 同一個bat文件工作正常。


我已經簡化我的劇本和冗長設置爲10。下面是最新的:

public class Master { 
@Test 
public void sample() throws Exception 
{ 
    System.out.println("INSIDE SAMPLE"); 
    FileInputStream fis = new FileInputStream ("C:\\Automation\\Test\\inputData.xlsx"); 
    System.out.println("FILE"); 
    XSSFWorkbook wb = new XSSFWorkbook(fis); 
    System.out.println("WORKBOOK"); 
    wb.getSheet("MyDetails"); 
    System.out.println("SHEET"); 

    System.out.println(wb.getActiveSheetIndex()); 
} 

}

下面是bat文件運行時日誌:

C:\Automation\Test>cd C:\Automation\Test 

C:\Automation\Test>set ProjectPath=C:\Automation\Test 

C:\Automation\Test>echo C:\Automation\Test 
C:\Automation\Test 

C:\Automation\Test>set classpath=C:\Automation\Test\bin;C:\Automation\Test\lib\* 


C:\Automation\Test>echo C:\Automation\Test\bin;C:\Automation\Test\lib\* 
C:\Automation\Test\bin;C:\Automation\Test\lib\* 

C:\Automation\Test>java org.testng.TestNG C:\Automation\Test\testng.xml 
... 
... TestNG 6.8beta 20120825_1010 by C?dric Beust ([email protected]) 
... 

[TestRunner] Running the tests in 'Test' with parallel mode:false 
[RunInfo] Adding method selector: [email protected] 
priority: 10 
[TestClass] Creating TestClass for [ClassImpl class=Master.Master] 
[TestClass] Adding method Master.sample()[pri:0, instance:null] on TestClass cla 
ss Master.Master 
[XmlMethodSelector] Including method Master.sample() 
[TestNG] Running: 
    C:\Automation\Test\testng.xml 

[SuiteRunner] Created 1 TestRunners 
[TestRunner] Running test Test on 1 classes, included groups:[] excluded group 
s:[] 
===== Test class 
Master.Master 
    @Test Master.sample()[pri:0, instance:[email protected]] 
====== 
[Invoker 6738746] Invoking Master.Master.sample 
INSIDE SAMPLE 
FILE 
===== Invoked methods 
    Master.sample()[pri:0, instance:[email protected]] 18154549 
===== 
Creating C:\Automation\Test\test-output\Suite\Test.html 
Creating C:\Automation\Test\test-output\Suite\Test.xml 
FAILED: sample 
java.lang.NoClassDefFoundError: org/apache/poi/xssf/usermodel/XSSFWorkbook 
     at Master.Master.sample(Master.java:79) 
     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
     at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
     at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
     at java.lang.reflect.Method.invoke(Unknown Source) 
     at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocat 
ionHelper.java:80) 
     at org.testng.internal.Invoker.invokeMethod(Invoker.java:714) 
     at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:901) 
     at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1231) 
     at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWork 
er.java:127) 
     at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111) 
     at org.testng.TestRunner.privateRun(TestRunner.java:767) 
     at org.testng.TestRunner.run(TestRunner.java:617) 
     at org.testng.SuiteRunner.runTest(SuiteRunner.java:334) 
     at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:329) 
     at org.testng.SuiteRunner.privateRun(SuiteRunner.java:291) 
     at org.testng.SuiteRunner.run(SuiteRunner.java:240) 
     at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52) 
     at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86) 
     at org.testng.TestNG.runSuitesSequentially(TestNG.java:1198) 
     at org.testng.TestNG.runSuitesLocally(TestNG.java:1123) 
     at org.testng.TestNG.run(TestNG.java:1031) 
     at org.testng.TestNG.privateMain(TestNG.java:1338) 
     at org.testng.TestNG.main(TestNG.java:1307) 
Caused by: java.lang.ClassNotFoundException: org.apache.poi.xssf.usermodel.XSSFW 
orkbook 
     at java.net.URLClassLoader.findClass(Unknown Source) 
     at java.lang.ClassLoader.loadClass(Unknown Source) 
     at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source) 
     at java.lang.ClassLoader.loadClass(Unknown Source) 
     ... 24 more 


=============================================== 
    Test 
    Tests run: 1, Failures: 1, Skips: 0 
=============================================== 


=============================================== 
Suite 
Total tests run: 1, Failures: 1, Skips: 0 
=============================================== 

Creating C:\Automation\Test\test-output\old\Suite\toc.html 
Creating C:\Automation\Test\test-output\old\Suite\Test.properties 
Creating C:\Automation\Test\test-output\old\Suite\index.html 
Creating C:\Automation\Test\test-output\old\Suite\main.html 
Creating C:\Automation\Test\test-output\old\Suite\groups.html 
Creating C:\Automation\Test\test-output\old\Suite\methods.html 
Creating C:\Automation\Test\test-output\old\Suite\methods.html 
Creating C:\Automation\Test\test-output\old\Suite\methods.html 
Creating C:\Automation\Test\test-output\old\Suite\methods-alphabetical.html 
Creating C:\Automation\Test\test-output\old\Suite\methods-alphabetical.html 
Creating C:\Automation\Test\test-output\old\Suite\methods-alphabetical.html 
Creating C:\Automation\Test\test-output\old\Suite\classes.html 
Creating C:\Automation\Test\test-output\old\Suite\reporter-output.html 
Creating C:\Automation\Test\test-output\old\Suite\methods-not-run.html 
Creating C:\Automation\Test\test-output\old\Suite\testng.xml.html 
Creating C:\Automation\Test\test-output\old\index.html 
[TestNG] Time taken by [email protected]: 53 ms 
[TestNG] Time taken by [email protected]: 3 ms 
Creating C:\Automation\Test\test-output\junitreports\TEST-Master.Master.xml 
[TestNG] Time taken by [email protected]: 4 ms 
Creating C:\Automation\Test\test-output\testng-failed.xml 
Creating C:\Automation\Test\test-output\Suite\testng-failed.xml 
[TestNG] Time taken by [FailedReporter passed=0 failed=0 skipped=0]: 6 ms 
Creating C:\Automation\Test\test-output\index.html 
[TestNG] Time taken by [email protected]: 40 ms 
Creating C:\Automation\Test\test-output\testng-results.xml 
[TestNG] Time taken by [email protected]: 6 ms 

C:\Automation\Test>pause 
Press any key to continue . . . 
+0

請提供有關您的信息的更多信息。請編輯您的問題以包含您使用的腳本以及顯示的錯誤消息(如果有)。 –

回答

0

數據提供者方法不應該拋出異常。將它們管理到你的方法中,你就會明白你的代碼有什麼問題。

我敢打賭,你有一個類路徑問題,並且inputData.xlsx不適用於與bat文件一起運行的預期位置。

+0

感謝您的回覆。 –

+0

下面是我的bat文件: –

+0

cd C:\ DCE \ Automation set ProjectPath = C:\ DCE \ Automation set classpath =%ProjectPath%\ bin;%ProjectPath%\ lib \ * java org.testng.TestNG% ProjectPath%\ testng.xml pause –

0

是的,現在已經解決了。我的poi文件位於項目文件夾\ lib \ poi文件夾中。我已將它們移至項目文件夾\ lib。它的工作原理。 謝謝@Julien Herr。