我的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 . . .
請提供有關您的信息的更多信息。請編輯您的問題以包含您使用的腳本以及顯示的錯誤消息(如果有)。 –