2015-07-02 5 views
1

Я занимаюсь автоматизацией Selenium Webdriver с использованием Java.Не удается найти элемент, хотя он виден в WebPage

. Вы найдете прилагаемый HTML-отрывок веб-страницы http://1drv.ms/1CMtRxd и найти пользовательский интерфейс того же http://1drv.ms/1JzXarv.

Из html следует понимать, что все элементы пользовательского интерфейса построены в таблице, и проблема, указанная здесь, не может найти элементы, которые присутствуют в правой стороне таблицы.

Однако нет проблем с размещением и использованием элементов, присутствующих в левой стороне таблицы, в сценариях автоматизации.

Не могли бы вы посоветовать, в чем разница между этими двумя таблицами и почему я не могу найти элементы правой стороны таблицы во время воспроизведения.

Кроме того, может кто-то любезно помочь мне решить эту проблему, пожалуйста.

Вы можете найти код экстракта:

(кодированный с Page Object Model)

В ПОМ Класс:

@Test(description = "Test to Track the Order") 
    public void searchOrder() throws Exception 
    { 
     SearchRequest searchReq = PageFactory.initElements(wd, SearchRequest.class); 


     wd.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS); 
     searchReq.enterTrackingID("161471"); 
     searchReq.clickSearchButton(); 

    } 

В Page Factory Класс:

public class SearchRequest 
{ 

    @FindBy(how = How.ID, using = "cpportal:searchByID") 
    public WebElement trackingID; 

    public void enterTrackingID(String trackingID) 
    { 
     this.trackingID.clear(); 
     this.trackingID.sendKeys(trackingID); 
    } 

    @FindBy(how = How.NAME, using = " cpportal:j_idt56 ") 
    public WebElement search; 

    public void clickSearchButton() 
    { 
     this.search.click(); 
    } 
} 

Исключение Метательное:

org.openqa.selenium.NoSuchElementException: Unable to locate element: {"method":"id","selector":"cpportal:searchByID"} 
Command duration or timeout: 10.12 seconds 
For documentation on this error, please visit: http://seleniumhq.org/exceptions/no_such_element.html 
Build info: version: '2.45.0', revision: '5017cb8', time: '2015-02-27 00:00:10' 
System info: host: 'inl-279930-1', ip: '10.13.136.53', os.name: 'Windows 7', os.arch: 'x86', os.version: '6.1', java.version: '1.7.0_55' 
*** Element info: {Using=id, value=cpportal:searchByID} 
Session ID: 3c404b65-ba64-435d-8395-53c262eff602 
Driver info: org.openqa.selenium.firefox.FirefoxDriver 
Capabilities [{platform=WINDOWS, acceptSslCerts=true, javascriptEnabled=true, cssSelectorsEnabled=true, databaseEnabled=true, browserName=firefox, handlesAlerts=true, nativeEvents=false, webStorageEnabled=true, rotatable=false, locationContextEnabled=true, applicationCacheEnabled=true, takesScreenshot=true, version=37.0.2}] 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:526) 
    at org.openqa.selenium.remote.ErrorHandler.createThrowable(ErrorHandler.java:204) 
    at org.openqa.selenium.remote.ErrorHandler.throwIfResponseFailed(ErrorHandler.java:156) 
    at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:599) 
    at org.openqa.selenium.remote.RemoteWebDriver.findElement(RemoteWebDriver.java:352) 
    at org.openqa.selenium.remote.RemoteWebDriver.findElementById(RemoteWebDriver.java:393) 
    at org.openqa.selenium.By$ById.findElement(By.java:214) 
    at org.openqa.selenium.remote.RemoteWebDriver.findElement(RemoteWebDriver.java:344) 
    at org.openqa.selenium.support.pagefactory.DefaultElementLocator.findElement(DefaultElementLocator.java:59) 
    at org.openqa.selenium.support.pagefactory.internal.LocatingElementHandler.invoke(LocatingElementHandler.java:37) 
    at com.sun.proxy.$Proxy8.clear(Unknown Source) 
    at com.cgi.hqn.liveref.pageobjects.SearchRequest.enterTrackingID(SearchRequest.java:17) 
    at com.cgi.hqn.liveref.test.CreateSOSL.searchOrder(CreateSOSL.java:176) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:606) 
    at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:84) 
    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(TestMethodWorker.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:1224) 
    at org.testng.TestNG.runSuitesLocally(TestNG.java:1149) 
    at org.testng.TestNG.run(TestNG.java:1057) 
    at org.testng.remote.RemoteTestNG.run(RemoteTestNG.java:111) 
    at org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:204) 
    at org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:175) 
Caused by: org.openqa.selenium.NoSuchElementException: Unable to locate element: {"method":"id","selector":"cpportal:searchByID"} 
For documentation on this error, please visit: http://seleniumhq.org/exceptions/no_such_element.html 
Build info: version: '2.45.0', revision: '5017cb8', time: '2015-02-27 00:00:10' 
System info: host: 'inl-279930-1', ip: '10.13.136.53', os.name: 'Windows 7', os.arch: 'x86', os.version: '6.1', java.version: '1.7.0_55' 
Driver info: driver.version: unknown 
    at <anonymous class>.FirefoxDriver.prototype.findElementInternal_(file:///C:/Users/SUBRAM~1/AppData/Local/Temp/anonymous5667416437314785176webdriver-profile/extensions/[email protected]/components/driver-component.js:10271) 
    at <anonymous class>.fxdriver.Timer.prototype.setTimeout/<.notify(file:///C:/Users/SUBRAM~1/AppData/Local/Temp/anonymous5667416437314785176webdriver-profile/extensions/[email protected]/components/driver-component.js:603) 

ответ

1

Это может быть Ajax элементом. Через некоторое время элемент виден.

Что такое возвращаемое значение OF-:

trackingID.isDisplayed(); 

Этого можно было бы избежать неявного ожидания

driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS); 

или WebDriver ждать

new WebDriverWait(driver, 10).until(ExpectedConditions.presenceOfElementLocated(trackingID)); 

Надежда, что помогает

Смежные вопросы