2016-07-25 10 views
0

Excelからドロップダウン値を読み取ってドロップダウン値を選択しようとしています。私は次のコードを試しましたが、Excelシートに記載されているデータごとに値を選択していません。私にとっては、ジェンダードロップを除いて、すべてのデータがそれぞれのフィールドに正しく入力されています。次Selenium Webドライバは、Excelシートからドロップダウン値を読み取ってドロップダウンからデータを選択します。

は、HTMLコードやUIのスクリーンショットです:後

UI Image

Xpath Information

HTML Code

は私のHTMLコードです:

<td class="codetable last-cell" headers="N224AA-4-2"> 
<div id="widget___o3id7" class="dijit dijitReset dijitInline dijitLeft codetable dijitTextBox dijitComboBox" lang="en-US" role="listbox" dir="ltr" widgetid="__o3id7" aria-expanded="false"> 
<div class="dijitReset dijitRight dijitButtonNode dijitArrowButton dijitDownArrowButton dijitArrowButtonContainer" role="presentation" data-dojo-attach-point="_buttonNode, _popupStateNode" popupactive="true"> 
<input class="dijitReset dijitInputField dijitArrowButtonInner" type="text" role="presentation" readonly="readonly" tabindex="-1" value="▼ "> 
</div> 
<div class="dijitReset dijitValidationContainer"> 
<input class="dijitReset dijitInputField dijitValidationIcon dijitValidationInner" type="text" role="presentation" readonly="readonly" tabindex="-1" value="Χ "> 
</div> 
<div class="dijitReset dijitInputField dijitInputContainer"> 
<input id="__o3id7" class="dijitReset dijitInputInner" type="text" aria-haspopup="true" role="textbox" data-dojo-attach-point="textbox,focusNode" autocomplete="off" aria-required="true" tabindex="0" title="Gender Mandatory" size="1" value="Male" aria-owns="__o3id7_popup" aria-activedescendant="__o3id7_popup1"> 
<input type="hidden" name="__o3id7" value="SX1"> 
</div> 
</div> 
</td> 

私はpopulat続き

UserName password123 100000005 Elena Sawyerehde Female 

は私のコードです:

package com.access; 

import org.openqa.selenium.*; 
import org.openqa.selenium.chrome.ChromeDriver; 
import org.openqa.selenium.support.ui.Select; 
import org.testng.Assert; 
import org.testng.annotations.*; 
import java.io.FileInputStream; 
import jxl.Sheet; 
import jxl.Workbook; 

public class Registration { 

    static WebDriver driver; 

     @BeforeMethod 
     public void setUp() throws Exception { 
     System.setProperty("webdriver.chrome.driver", "C:\\Directory\\chromedriver.exe"); 
     driver = new ChromeDriver(); 
     driver.manage().window().maximize(); 

     Thread.sleep(2000); 
     } 

     @Test 
     public void TestCase1() throws Exception { 
      FileInputStream fi=new FileInputStream("C:\\File\\Book2.xls"); 
      Workbook w=Workbook.getWorkbook(fi); 
      Sheet s=w.getSheet(0); 
     driver.get("https://example.com"); 

     try 
     { 
     for (int i = 0; i < s.getRows(); i++) 
     { 
     //Read data from excel sheet 
      String s1 = s.getCell(0,i).getContents(); 
      String s2 = s.getCell(1,i).getContents(); 
      String s3 = s.getCell(2,i).getContents(); 
      String s4 = s.getCell(3,i).getContents(); 
      String s5 = s.getCell(4,i).getContents(); 
      String s6 = s.getCell(5,i).getContents(); 

      driver.findElement(By.xpath("html/body/div[2]/form/input[1]")).sendKeys(s1); 
      Thread.sleep(2000); 
      driver.findElement(By.xpath("html/body/div[2]/form/input[2]")).sendKeys(s2); 
      Thread.sleep(2000); 
      driver.findElement(By.xpath("html/body/div[2]/a/span/span/span")).click(); 
      Thread.sleep(2000); 
      Assert.assertEquals("Testing Hub", driver.findElement(By.xpath("//*[@id='app-banner']/div[1]/div/h2")).getText()); 
      Thread.sleep(2000); 
      driver.findElement(By.xpath("html/body/div[1]/div[4]/div[1]/div[4]/div/div[2]/div/div/div/span[1]")).click(); 
      Thread.sleep(2000);   
      driver.findElement(By.xpath("html/body/div[1]/div[4]/div[3]/div[2]/div[3]/div[3]/div[1]/div/div[2]/div/div/div/span/span/span/span[2]")).click(); 
      Thread.sleep(1000);   
      driver.findElement(By.xpath("html/body/div[4]/table/tbody/tr[2]/td[2]")).click(); 
      Thread.sleep(2000);  
      driver.switchTo().frame("iframe-curam_ModalDialog_0"); 
      Thread.sleep(1000); 
      driver.findElement(By.xpath("//*[@id='__o3id0']")).sendKeys(s3); 
      Thread.sleep(1000); 
      driver.findElement(By.xpath("html/body/div[3]/form/div/div[5]/a[1]/span/span/span")).click(); 
      Thread.sleep(1000); 
      Assert.assertEquals("There are no matching items based on the Search Criteria entered.", driver.findElement(By.xpath("html/body/div[3]/div/ul/li/div")).getText()); 
      Thread.sleep(1000);   
      driver.findElement(By.xpath("html/body/div[4]/div[2]/a/span/span/span")).click(); 
      Thread.sleep(2000);   
      driver.findElement(By.xpath("html/body/div[3]/form/div/div[2]/div/table/tbody/tr[1]/td[1]/input")).sendKeys(s4); 
      Thread.sleep(1000);   
      driver.findElement(By.xpath("html/body/div[3]/form/div/div[2]/div/table/tbody/tr[2]/td[1]/input")).sendKeys(s5); 
      Thread.sleep(1000); 
      new Select(driver.findElement(By.id("___o3id7"))).selectByValue(s6); 
      Thread.sleep(2000); 

      }  
      } 
      catch(Exception e) 
      { 
      System.out.println(e); 

      } 
      } 
} 
+0

入力タイプはテキストです。あなたはそれが選択要素であると確信していますか?また、それはtrueにreadonlyプロパティを持っているので、あなたが何かを更新することができるかどうかは分かりません。 – kurakura88

+0

入力キーにsendキーを使用できますが、Excelシートから読み取ってドロップダウン値も使用します。したがって、フィールドには機能入力値とドロップダウンからの選択値の両方があります。 – Curious

+0

こんにちは、好奇心、 '女性'という値が表示されるのはいつですか?ドロップダウンをクリックすると値 'Female'が表示されます。私は正しい? –

答えて

0

貼り付けたコードには選択したタグが存在しないため、使用した「女性」は値をドロップダウンここで以下のようにExcelシートでED試験データドロップダウンをクリックするとselectは役に立ちません。

テストスクリプトとHtmlコードでは、idの値が異なります。

//*[@id='widget___o3id7'] - ドロップダウンを選択するxpathに使用されます.HTMLコードid = "__o3id7"にあります。シナリオを理解し、結論にUIとHTMLコードを共有するための


おかげで来て、あなたのUIを共有することが、より良い彼らに

その変更後

してみてください。

driver.findElement(By.id("__o3id7")).click(); 
    Thread.sleep(1500); 
    driver.findElement(By.xpath("//*[contains(text(),'Female')]")).click(); 

selectステートメントを交換してこのコードを試してください。これがドロップダウンから「女性」をクリックすることを望みます。

+0

こんにちはAnand - あなたが示唆したようにIDを更新しました。また、スクリーンショットでUIスクリーンショットとHTMLとXpath情報を提供しました。 – Curious

+0

@Curiousが私の答えはあなたを助けました –

+0

いいえ、あなたは答えてくれませんでした。 – Curious

関連する問題