【问题标题】:How to verify the selected option in a dropdown in IE如何验证 IE 下拉菜单中的选定选项
【发布时间】:2015-05-04 17:00:17
【问题描述】:

我在验证是否在下拉菜单中选择了某个选项时遇到了一些问题。在我的应用程序中,我有一个包含 10 个选项的下拉菜单。如果我选择选项 5,我想验证它是否实际被选中。

使用 Firefox 和 Chrome,非常简单。下面是我的下拉列表和选项的 HTML。

<select class="Test-field-ddlist" runat="server" onchange="javascript:setTimeout('__doPostBack(\'ctl00$cphMainContent$ctl17\',\'\')', 0)" name="ctl00$cphMainContent$ctl17">
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
<option value="5" selected="selected">5</option>
<option value="6">6</option>
<option value="7">7</option>
<option value="8">8</option>
<option value="9">9</option>
<option value="10">10</option>

为了验证所选选项,我使用 CSS 选择器创建了一个对象。然后我验证了文本等于 5。

public static final String ManagerPage_DropdownSelection = "css=.Test-field-ddlist option[selected]";

String actualtext = driver.getSingleElement(ManagerPage_DropdownSelection).getText();
Assert.assertEquals(actualtext, "5");

我在使用 IE 时遇到的问题是 HTML 不同。当我检查元素时,HTML 看起来像这样。没有说选择了 5

<SELECT name=ctl00$cphMainContent$ctl17 class=Test-field-ddlist onchange="javascript:setTimeout('__doPostBack(\'ctl00$cphMainContent$ctl17\',\'\')', 0)" runat="server" sizcache="0" sizset="0"> 
<OPTION value=1>1</OPTION> 
<OPTION value=2>2</OPTION> 
<OPTION value=3>3</OPTION> 
<OPTION value=4>4</OPTION> 
<OPTION value=5>5</OPTION> 
<OPTION value=6>6</OPTION> 
<OPTION value=7>7</OPTION> 
<OPTION value=8>8</OPTION> 
<OPTION value=9>9</OPTION> 
<OPTION value=10>10</OPTION>

看起来“选定”的文本被隐藏了。如果我将 HTML 复制并粘贴到文本编辑器中,则可以看到“已选择”文本。与 Firefox 和 Chrome 不同,没有 selected 属性。而是将选定的文本添加到 value 属性中。

<SELECT name=ctl00$cphMainContent$ctl17 class=Test-field-ddlist onchange="javascript:setTimeout('__doPostBack(\'ctl00$cphMainContent$ctl17\',\'\')', 0)" runat="server" sizcache="0" sizset="0"> 
<OPTION value=1>1</OPTION> 
<OPTION value=2>2</OPTION> 
<OPTION value=3>3</OPTION> 
<OPTION value=4>4</OPTION> 
<OPTION value=5 selected>5</OPTION> 
<OPTION value=6>6</OPTION> 
<OPTION value=7>7</OPTION> 
<OPTION value=8>8</OPTION> 
<OPTION value=9>9</OPTION> 
<OPTION value=10>10</OPTION> 

我可以创建一个可以在所有浏览器中找到所选下拉选项的选择器吗?还是有更好的方法来验证下拉列表的选定值?我试过下面的方法。它似乎有效,但需要很长时间才能完成(大约 5 分钟)。

protected void verifyDropDownSelection(String selector, String expectedvalue) {
        List<String> listA = new ArrayList<String>();
        listA.add(expectedvalue);
        List<String> listB = new ArrayList<String>();
        List<Element> DDSelected = driver.getSingleElement(selector).useAsDropdown().getAllSelectedOptions();
            for(Element selectedoption : DDSelected) {
                String actualtext = selectedoption.getText();
                listB.add(actualtext);
            }
        log.info("INFO: Verifying the selected option in the dropdown");
        Assert.assertEquals(listB, listA);
        log.info("PASS: "+expectedvalue+" was the selected option in the dropdown");
    }

【问题讨论】:

    标签: java html css selenium selenium-webdriver


    【解决方案1】:

    我会让Select class处理这个案子:

    WebElement select = driver.findElement(By.name("ctl00$cphMainContent$ctl17"));
    Select dropDown = new Select(select);  
    
    String selected = dropDown.getFirstSelectedOption().getText();
    Assert.assertEquals(selected, "5");
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2012-12-03
      • 1970-01-01
      • 1970-01-01
      • 2013-12-22
      • 2014-11-06
      • 1970-01-01
      • 1970-01-01
      • 2016-01-06
      相关资源
      最近更新 更多