selenium测试(Java)--元素操作(五)

元素的操作有

1. 清除文本

2. 模拟按键输入

3. 单击元素

4. 返回元素尺寸

5. 获取文本

6. 获取属性值

7. 判断是否可见

8. 提交

 

 

下面通过操作新浪邮箱的注册界面的脚本来展示使用方法

 

源代码:

package com.test.elementoperation;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.firefox.FirefoxDriver;

public class ElementOperationEmail {

    public static void main(String[] args) {

        WebDriver driver = new FirefoxDriver();

        driver.get("https://mail.sina.com.cn/register/regmail.php");
        driver.manage().window().maximize();

        // 获取email名称输入框节点,并输入名称
        WebElement emailName = driver.findElement(By.cssSelector("[name=email]"));
        emailName.clear();
        emailName.click();
        emailName.sendKeys(AllInfo.emailName);

        // 获取email密码输入框节点,在输入密码之前,先验证一下email名称时候可用,如果可用就继续,如果不可用就退出浏览器
        WebElement emailPassword = driver.findElement(By.cssSelector("[name=psw]"));
        emailPassword.click();// 点击一下密码框,使得email名称验证信息出现
        waitTime(3000);
        // 获取email名称验证信息节点,并判断信息是否为"左箭头"
        WebElement checkName = driver
                .findElement(By.xpath("html/body/div[2]/div/div/div/div/form[1]/div[2]/ul/li[1]/div[3]/i"));
        String checkContent = checkName.getText();// 通过getText方法来获取节点文本信息
        System.out.println("验证用户名信息是否存在: " + checkName.isDisplayed() + "  比对结果的信息是 :" + checkContent);
        // 获取到信息后开始判断,并进行不同的分支
        if ("左箭头".equals(checkContent)) {
            // 确认名称无误后输入密码
            emailPassword.sendKeys(AllInfo.emailPassword);
            waitTime(3000);

            // 获取验证码输入框节点,在输入验证码之前,先验证一下密码是否有效和密码强度
            WebElement emailImgvcode = driver.findElement(By.cssSelector("[name=imgvcode]"));
            emailImgvcode.click();
            waitTime(3000);
            // 获取密码校验信息节点,并判断时候存在以及信息是否为"密码强度:高"
            WebElement checkPassword = driver.findElement(By.cssSelector("[class=passWord3]"));
            if (checkPassword.isDisplayed() && "密码强度:高".equals(checkPassword.getText())) {

                // 密码校验通过后,获取验证验证图片节点,并通过一下方法来获取该节点的信息
                WebElement img = driver.findElement(By.cssSelector("[id=capcha]"));
                System.out.println("验证图片的 hight是: " + img.getSize().getHeight());
                System.out.println("验证图片的 Width是: " + img.getSize().getWidth());
                System.out.println("验证图片的 src属性值是: " + img.getAttribute("src"));
                waitTime(3000);

                // 输入验证码,真实环境中selenium很难获取到正确的验证码,如果在测试环境可以通过访问Cookie的方式实现。
                // 这里随意输入一个验证码
                emailImgvcode.sendKeys("1234567890");
                waitTime(3000);

                // 获取提交按钮信息,并通过一些方法来获取该节点的信息
                WebElement submit = driver.findElement(By.cssSelector("[class=subIco]"));
                System.out.println("提交按钮的文本信息是: " + submit.getText());
                System.out.println("提交按钮的class属性值是: " + submit.getAttribute("class"));
                System.out.println("提交按钮的style属性值是: " + submit.getAttribute("style"));
                System.out.println("提交按钮的css属性值是: " + submit.getCssValue("float"));
                System.out.println("提交按钮的href属性值是: " + submit.getAttribute("href"));
                submit.submit();
                waitTime(5000);

                driver.quit();

            } else {
                System.out.println("密码校验信息没有展示或者密码强度低");
                driver.quit();
            }

        } else {
            System.out.println("用户名不可用");
            driver.quit();
        }

    }

    static public void waitTime(int time) {

        try {
            Thread.sleep(time);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

执行结果:

验证用户名信息是否存在: true  比对结果的信息是 :左箭头
验证图片的 hight是: 34
验证图片的 Width是: 118
验证图片的 src属性值是: https://mail.sina.com.cn/cgi-bin/createcode.php?t=1468141676
提交按钮的文本信息是: 立即注册
提交按钮的class属性值是: subIco
提交按钮的style属性值是: float: left;
提交按钮的css属性值是: left
提交按钮的href属性值是: javascript:void(0)

 

 

原文:http://www.cnblogs.com/moonpool/p/5658160.html

转载于:https://www.cnblogs.com/wuzhiming/p/6870225.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值