@Test

public void testUIComputation() throws Exception {

// populate text fields with values

populate();

// trigger computation by using the button

//点击控件计算两个数的和

WebElement button = driver.findElement(By.className("UIAButton"));

button.click();

// is sum equal ?

//判断得到的数是否和正确的和相等

WebElement texts = driver.findElement(By.className("UIAStaticText"));

assertEquals(String.valueOf(values.get(0) + values.get(1)), texts.getText());

}

@Test

public void testBasicAlert() throws Exception {

//点击alert控件,弹出提示框

driver.findElement(By.xpath("//UIAButton[2]")).click();

Alert alert = driver.switchTo().alert();

//check if title of alert is correct

//验证提示框文字是否正确

assertEquals("Cool title this alert is so cool.", alert.getText());

alert.accept();

}

@Test

public void testBasicButton() throws Exception {

// 验证求和 button文字显示是否正确

WebElement button = driver.findElement(By.xpath("//UIAButton[1]"));

assertEquals("Compute Sum", button.getText());

}

@Test

public void testClear() throws Exception {

//验证编辑框输入清空后编辑框内容是否为空

WebElement text = driver.findElement(By.xpath("//UIATextField[1]"));

text.sendKeys("12");

text.clear();

assertEquals("", text.getText());

}

@Test

public void testHideKeyboard() throws Exception {

//编辑框输入文字

driver.findElement(By.xpath("//UIATextField[1]")).sendKeys("12");

//确认键盘是否弹出

WebElement button = driver.findElement(MobileBy.AccessibilityId("Done"));

assertTrue(button.isDisplayed());

//点击隐藏键盘

button.click();

}

@Test

public void testFindElementByClassName() throws Exception {

Random random = new Random();

//通过classname定位控件测试

WebElement text = driver.findElementByClassName("UIATextField");

int number = random.nextInt(MAXIMUM - MINIMUM + 1) + MINIMUM;

text.sendKeys(String.valueOf(number));

driver.findElementByClassName("UIAButton").click();

// is sum equal ?

//验证是否相等

WebElement sumLabel = driver.findElementByClassName("UIAStaticText");

assertEquals(String.valueOf(number), sumLabel.getText());

}

@Test

public void testFindElementsByClassName() throws Exception {

Random random = new Random();

//通过classname定位控件测试

WebElement text = (WebElement) driver.findElementsByClassName("UIATextField").get(1);

int number = random.nextInt(MAXIMUM - MINIMUM + 1) + MINIMUM;

text.sendKeys(String.valueOf(number));

driver.findElementByClassName("UIAButton").click();

// is sum equal ?

WebElement sumLabel = (WebElement) driver.findElementsByClassName("UIAStaticText").get(0);

assertEquals(String.valueOf(number), sumLabel.getText());

}

@Test

public void testAttribute() throws Exception {

Random random = new Random();

WebElement text = driver.findElement(By.xpath("//UIATextField[1]"));

//编辑框输入文字

int number = random.nextInt(MAXIMUM - MINIMUM + 1) + MINIMUM;

text.sendKeys(String.valueOf(number));

//验证控件的name,label,value等属性是否和设定的相同,name为IntegerA

assertEquals("IntegerA", text.getAttribute("name"));

assertEquals("TextField1", text.getAttribute("label"));

assertEquals(String.valueOf(number), text.getAttribute("value"));

}

@Test

public void testSlider() throws Exception {

//get the slider

//进度条控件

WebElement slider = driver.findElement(By.xpath("//UIASlider[1]"));

// 查看初始数据是否为50%

assertEquals("50%", slider.getAttribute("value"));

Point sliderLocation = getCenter(slider);

//拖动控件,从中心拖到初始位置

driver.swipe(sliderLocation.getX(), sliderLocation.getY(), sliderLocation.getX()-100, sliderLocation.getY(), 1000);

//验证控件是否归0,不归0?

assertEquals("0%", slider.getAttribute("value"));

}

@Test

public void testLocation() throws Exception {

//验证控件的位置是否为94,122?

WebElement button = driver.findElement(By.xpath("//UIAButton[1]"));

Point location = button.getLocation();

assertEquals(94, location.getX());

assertEquals(142, location.getY());

}

@Test

public void testSessions() throws Exception {

// ?

HttpGet request = new HttpGet("http://localhost:4723/wd/hub/sessions");

@SuppressWarnings("resource")

HttpClient httpClient = new DefaultHttpClient();

HttpResponse response = httpClient.execute(request);

HttpEntity entity = response.getEntity();

JSONObject jsonObject = (JSONObject) new JSONParser().parse(EntityUtils.toString(entity));

String sessionId = driver.getSessionId().toString();

assertEquals(jsonObject.get("sessionId"), sessionId);

}

@Test

public void testSize() {

//验证两个编辑框控件大小是否一致

Dimension text1 = driver.findElement(By.xpath("//UIATextField[1]")).getSize();

Dimension text2 = driver.findElement(By.xpath("//UIATextField[2]")).getSize();

assertEquals(text1.getWidth(), text2.getWidth());

assertEquals(text1.getHeight(), text2.getHeight());

}

Appium basic UI check cases_from sample的更多相关文章

  1. 基于Appium的UI自动化测试

    为什么需要UI自动化测试 移动端APP是一个复杂的系统,不同功能之间耦合性很强,很难仅通过单元测试保障整体功能.UI测试是移动应用开发中重要的一环,但是执行速度较慢,有很多重复工作量,为了减少这些工作 ...

  2. (appium+python)UI自动化_09_unittest批量运行测试用例&生成测试报告

    前言 上篇文章[(appium+python)UI自动化_08_unittest编写测试用例]讲到如何使用unittets编写测试用例,并执行测试文件.接下来讲解下unittest如何批量执行测试文件 ...

  3. 02- web UI测试与UI Check List

    UI英文是 user interface .所以UI测试就是用户界面测试. Web UI测试 用户界面测试:user interface testing,UI Testing指软件中的可见外观及其与用 ...

  4. 基于Python3 + appium的Ui自动化测试框架

    UiAutoTest 一.概要 数据驱动的Ui自动化框架 二.环境要求 框架基于Python3 + unittest + appium 运行电脑需配置adb.aapt的环境变量,build_tools ...

  5. (appium+python)UI自动化_07_app UI自动化实例【叮咚搜索加车为例】

    前言 初学UI自动化的小伙伴,在配置好appium+python自动化环境后,往往不知道如何下手实现自动化.小编在初期学习的时候也有这种疑惑,在此以叮咚买菜app-搜索加车为实例,展示下appium是 ...

  6. (appium+python)UI自动化_03_元素定位工具

    前言 在UI自动化过程中,需要对手机app上的元素进行定位,然后进一步编写自动化脚本操作app.定位元素首先需要定位工具来辅助查看页面元素.小编常用的定位工具有2种,分别是uiautomatorvie ...

  7. (appium+python)UI自动化_02_appium启动手机app

    前提:需先安装配置好appium+python自动化环境,已配置好环境的小伙伴可以参考以下步骤启动Android app,具体步骤如下: 一.USB连接手机 (1)手机USB连接电脑 (2)手机打开开 ...

  8. (appium+python)UI自动化_01_自动化环境搭建【MAC版】

    Appium简介 Appium是一个开源的.跨平台的测试框架,主要用来进行app UI自动化,适用于原生应用.混合应用和移动网页应用(H5页面).目前支持Python.JavaScript.Objec ...

  9. Python+appium+unittest UI自动化测试

    什么是UI自动化 自动化分层 单元自动化测试,指对软件中最小可测试单元进行检查和验证,一般需要借助单元测试框架,如java的JUnit,python的unittest等 接口自动化测试,主要检查验证模 ...

随机推荐

  1. 一步一步在ubuntu上安装即时通讯服务器-Openfire

    1.首先登录到ubuntu server.在安装openfire 服务器之前,先确保你的系统已经更新到最新.然后输入下面的命令,一行一行执行,最后安装可用的更新 sudo apt-get update ...

  2. tensorflow 如何限制显存大小

    Python在用GPU跑模型的时候最好开多进程,因为很明显这种任务就是计算密集型的. 用进程池好管理,但是tensorflow默认情况会最大占用显存,尽管该任务并不需要这么多,因此我们可以设置显存的按 ...

  3. git 本地保存账号密码

    用ssh连接的项目都不用输账号密码 如果https的话   每次都用输入账号密码   很繁琐 解决方法,在本地的工程文件夹的.git下打开config文件添加: [credential]     he ...

  4. [BZOJ4506] [Usaco2016 Jan]Fort Moo(DP?)

    传送门 总之可以先预处理出来每个位置最多往上延伸多少 枚举两行,看看夹在这两行中间的列最大能构成多大的矩形 可以看出,必须得在一个两行都没有X的区间才有可能构成最大的答案 那么可以把这些区间处理出来, ...

  5. Redis常见配置redis.conf

    redis的配置文件.相信学过SSH或SSM的读者都知道,配置文件的使用在当下开发已十分普遍,希望大家要熟悉习惯这 种开发方式,废话不多说,来开始我们今天的内容吧. 首先得找到 redis 的配置文件 ...

  6. 了不得,我可能发现了Jar 包冲突的秘密

    一.前言 这篇是类加载器相关的第三篇: 实战分析Tomcat的类加载器结构(使用Eclipse MAT验证) 还是Tomcat,关于类加载器的趣味实验 昨天下午刚写了篇 类加载器相关的,晚上想着验证个 ...

  7. 不拖控件的asp.net编程方法——第1回

    以前写的asp.net程序基本上都用了webfrom的控件编写的,当然有个好处就是易入门.快速效率高,但感觉自己这了几个小系统,还是没学到什么东西,感觉心里没底,因为都是封装好的东西,拿来就用的,功能 ...

  8. Struts2防止重复提交

    一般使用<interceptor-ref name="token"></interceptor-ref>或者<interceptor-ref name ...

  9. HDU - 5973 Game of Taking Stones (威佐夫博弈 高精度)

    题目描述: Two people face two piles of stones and make a game. They take turns to take stones. As game r ...

  10. FIREDAC TFDCONNECTION连接ORACLE

    FIREDAC TFDCONNECTION连接ORACLE 1)安装OCI 2)如图设置参数 3)连接代码: procedure TfrmDB.ConnectDB;begin FDMoniFlatFi ...