作者:Surpassme

来源:http://www.jianshu.com/p/08ee1929875f

声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢。

单选按钮通常用在需要与用户进行交互且只能选一个选项的情况。下面即是一个典型的单选按钮示例:

 请选择您的性别:
<input type="radio" name="gender" value="male" id="male" checked="checked">男
<input type="radio" name="gender" value="female" id="female" />女<br />

选中单选按钮

通常情况下,在一个单选按钮组里面,它们的名字是一样的。所以我们使用定位的时候,不建议使用Name属性进行定位,建议使用Id、XPath和CssSelector进行定位,如下所示:

driver.FindElement(By.XPath("//input[@name='gender' and @value='male']")).Click();
Thread.Sleep(1000);
driver.FindElement(By.Id("female")).Click();

清除单选按钮的选中状态

对于一个已经选中的单选按钮进行多次点击,是不会带来任何影响的,下面的示例代码在测试过程中依然可以正常通过。

driver.FindElement(By.Id("female")).Click();
driver.FindElement(By.Id("female")).Click(); //已经选中,多次点击没有任何影响

如果一个单选按钮被选中,在Selenium中清除选中状态的常用方法是点击另一个单选按钮。下面的示例使用Clear()方法清除单选按钮的选中状态将会抛出异常Invalid Element State:Element Must Be User-Editable in Order to Clear It.

            driver.FindElement(By.Id("female")).Click();
try
{
driver.FindElement(By.Id("female")).Clear();
}
catch (Exception ex)
{
throw ex;
}

报错截图如下所示:

下面的示例演示了既抛出了异常也按预期的目标实现了点击,示例如下:

      driver.FindElement(By.Id("female")).Click();
try
{
driver.FindElement(By.Id("female")).Clear();
}
catch (Exception ex)
{
Console.WriteLine("不能清除单选状态,报错信息为:\n"+ex.ToString()); }
finally
{
driver.FindElement(By.Id("male")).Click();
}

判断单选按钮状态

    IWebElement femaleEle = driver.FindElement(By.Id("female"));
IWebElement maleEle = driver.FindElement(By.Id("male"));
bool flag = femaleEle.Selected;
if (flag)
{
maleEle.Click();
Assert.IsTrue(maleEle.Selected);
}
else
{
femaleEle.Click();
Assert.IsTrue(femaleEle.Selected);
Assert.IsFalse(maleEle.Selected);
}

通过循环点击单选按钮

在这之前我基本上仅使用方法FindElement()来查找定位元素,而在Selenium中还有另外一种方法FindElements(),示例如下:

    ReadOnlyCollection<IWebElement> elements = driver.FindElements(By.Name("gender"));
Assert.AreEqual<int>(2,elements.Count);
foreach (IWebElement item in elements)
{
if (item.GetAttribute("value")=="female")
{
item.Click();
}
}

与方法FindElement()不一样的是,方法FindElements()会返回能匹配到条件的集合,这对一些比较难定位的元素是非常有用的一个方法。

选中第N个单选按钮

在Name属性值相同且单选按钮也比较多的情况下,除了上面的方法循环判断来点击外,也可以通过XPath和以下方法来点击单选按钮,示例如下:

    driver.FindElements(By.Name("gender"))[1].Click();
Assert.IsTrue(driver.FindElements(By.Name("gender"))[1].Selected); driver.FindElement(By.XPath("//input[1]")).Click();
Assert.IsTrue(driver.FindElement(By.XPath("//input[1]")).Selected);

请注意里面的下标,C#下标默认是从0开始,而XPath里面下标默认是从1开始。

一些特殊的单选按钮:iCheck

针对一些默认的控件界面存在不好看的情况,一些大牛会自定义一些控件,比如下面这种单选按钮:

<ul>
<li>
<div class="iradio_square-blue checked hover">
<input id="input-3" tabindex="3" name="demo-radio" style="position: absolute; top: -20%; left: -20%; display: block; width: 140%; height: 140%; margin: 0px; padding: 0px; background: rgb(255, 255, 255) none repeat scroll 0% 0%; border: 0px none; opacity: 0;" type="radio"/>
<ins class="iCheck-helper" style="position: absolute; top: -20%; left: -20%; display: block; width: 140%; height: 140%; margin: 0px; padding: 0px; background: rgb(255, 255, 255) none repeat scroll 0% 0%; border: 0px none; opacity: 0;"/>
</div>
<label class="hover" for="input-3"> Radio button,
<span>#input-3</span>
</label>
<li>
<li>
<div class="iradio_square-blue">
<input id="input-4" tabindex="4" name="demo-radio" checked="" style="position: absolute; top: -20%; left: -20%; display: block; width: 140%; height: 140%; margin: 0px; padding: 0px; background: rgb(255, 255, 255) none repeat scroll 0% 0%; border: 0px none; opacity: 0;" type="radio"/>
<ins class="iCheck-helper" style="position: absolute; top: -20%; left: -20%; display: block; width: 140%; height: 140%; margin: 0px; padding: 0px; background: rgb(255, 255, 255) none repeat scroll 0% 0%; border: 0px none; opacity: 0;"/>
</div>
<label class="" for="input-4"> Radio button,
<span>#input-4</span>
</label>
</li>
</ul>

以下这段代码如果按之前的方法进行定位,将出错:

        driver.FindElement(By.Id("input-3")).Click();
driver.FindElements(By.ClassName("iCheck-helper"))[0].Click();
driver.FindElements(By.ClassName("iCheck-helper"))[1].Click();

正确的代码如下:

public void TestRadioButton()
{
IWebDriver driver = new ChromeDriver();
string url = "http://www.51xuediannao.com/js/jquery/icheck.html";
driver.Navigate().GoToUrl(url);
driver.Manage().Window.Maximize();
driver.FindElement(By.Id("demolink")).Click();
driver.SwitchTo().Window(driver.WindowHandles[1]);
Thread.Sleep(1000);
driver.SwitchTo().Frame(0);
IWebElement ele = driver.FindElement(By.XPath("//div[contains(@class,'demo-list')]/ul[2]/li[1]/label"));
ele.Click();
}

个人理解,特别是基于UI层面的自动化测试,对象查找定位是特别重要的,需要我们结合多种方法进行。常见的IdXPathCssSelector等定位方法,有时候甚至用JavaScript知识,需要了解和掌握的知识太多,另外还需要多看看Selenium API等。在自动化这条路上还任重道远了。

[Selenium With C#学习笔记] Lesson-06 单选按钮的更多相关文章

  1. udacity android 学习笔记: lesson 4 part b

    udacity android 学习笔记: lesson 4 part b 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...

  2. udacity android 学习笔记: lesson 4 part a

    udacity android 学习笔记: lesson 4 part a 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...

  3. 驱动开发学习笔记. 0.06 嵌入式linux视频开发之预备知识

    驱动开发读书笔记. 0.06  嵌入式linux视频开发之预备知识 由于毕业设计选择了嵌入式linux视频开发相关的项目,于是找了相关的资料,下面是一下预备知识 UVC : UVC,全称为:USB v ...

  4. 【Ext.Net学习笔记】06:Ext.Net GridPanel的用法(GridPanel 折叠/展开行、GridPanel Selection、 可编辑的GridPanel)

    GridPanel 折叠/展开行 Ext.Net GridPanel的行支持折叠/展开功能,这个功能个人觉得还说很有用处的,尤其是数据中包含图片等内容的时候. 下面来看看效果: 使用行折叠/展开功能之 ...

  5. Duilib学习笔记《06》— 窗体基类WindowImpBase

    在前面的例子中我们发现,窗口都是继承CWindowWnd.INotifyUI,然后重载相关函数去实现.显然,我们发现窗口的创建流程实际上都是差不多的,主要只是在OnCreate加载的配置文件不同等等… ...

  6. [Selenium With C#学习笔记] Lesson-01环境搭建

    Step-1:准备所需的开发环境.浏览器驱动.Selenium-Webdriver.单元测试框架,因目前使用C#的开发神器都Visual Studio,本文也打算采用Visual Studio 201 ...

  7. [Selenium With C#学习笔记] Lesson-02 Web元素定位

    使用Selenium来做自动化测试,一般的流程是:查找定位元素--->操作元素--->断言,那么第一步我们需要能够完成查找并定位元素,Selenium目前提供了8种基本定位方法,可根据实际 ...

  8. [Selenium With C#学习笔记] Lesson-03 超级链接

    超级链接或链接是Web页面的基本元素之一,而通过超级链接使得万维网可以互联互通.一个典型的链接如下所示: HTML源码如下所示: <a href="index.html" i ...

  9. selenium常用操作学习笔记

    一,弹窗处理(推荐文章:https://blog.csdn.net/huilan_same/article/details/52298460) selenium提供switch_to方法定位弹窗的对话 ...

随机推荐

  1. swift webView的高度自适应内容

    废话不多 直接上代码 //在webView的协议方法里实现以下代码 func webViewDidFinishLoad(webView: UIWebView) {//加载完成 //        se ...

  2. lepus3.7 天兔监控安装手册 CentOS6.5+mysql5.6

    lepus3.7 天兔监控安装配置手册 CentOS6.5+mysql5.6 整体环境 192.168.1.250为监控机 192.168.1.248为被监控机 安装LAMP环境 [root@HE3~ ...

  3. 大型网站制作前端使用PHP后台逻辑用 Java

    对于网站团队,大概可以按照职责分为前端.后端.架构三种角色. 前端:负责所有和用户有交互的产品,包括 WEB以及手机客户端 后端:负责各种业务 API 的开发,以及服务器端其他系统的开发 架构:负责设 ...

  4. nginx安装配置

    Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,由俄罗斯的程序设计师Igor Sysoev所开发,其特点是占有内存少,并发能力强 1. apache ...

  5. 史上最全的synchronized解释

    首先:推荐使用synchronized(obj)这种方法体的使用方式,一个类里面建议尽量使用单一的同步方法,多种方法混用,维护成本太大. 其次:关于java5.0新增的ReenTrantLock方法: ...

  6. Git学习之路(2)-安装GIt和创建版本库

    ▓▓▓▓▓▓ 大致介绍 前面一片博客介绍了Git到底是什么东西,如果有不明白的可以移步 Git学习之路(1)-Git简介 ,这篇博客主要讲解在Windows上安装Git和创建一个版本库 ▓▓▓▓▓▓ ...

  7. bzoj1061--线性规划

    线性规划裸题... 根据题目很容易可以得到线性规划方程(以样例为例): Min(2*x1+5*x2+2*x3) x1+ 0+ 0>=2 x1+x2+ 0>=3 0+x2+x3>=4 ...

  8. WebForm 控件(二)

    控件 Calendar:日历控件 但是html代码量太大不适用 FileUpdate: 文件上传 HiddenField:隐藏域 Image: 图片  可以直接给URL 不适用可用html代码写 Ta ...

  9. JAVA构造函数的继承

    1.子类中无参构造函数,可直接继承父类中无参构造函数,前提是所有变量均为public 如下:父类Student中有空构造函数Student(),子类Pupil中有空构造函数Pupil(),后者会继承前 ...

  10. 真机测试错误“The application could not be verified”

    真机测试错误"The application could not be verified" 真机测试的时候报错:"The application could not be ...