APP自动化测试框架搭建(五)--Python+Appium+pytest-html

第一章 APP自动化环境搭建(Mac版)
第二章 APP自动化环境搭建(Windows版)
第三章 adb命令
第四章 元素定位、元素操作
第五章 APP自动化测试框架搭建 Python+Appium+pytest-html
第六章 uiautomator2、web-editor基础操作
第七章 Airtest基础操作
第八章 ATX Server2多设备集群环境搭建



一、筛选测试用例

1、举例某电商app,假设测试用例如下:

用例编号用例描述预期结果实际结果运行结果
test_001首页点击新品tab,校验新品tab第一个商品价格,与详情页价格一致新品tab第一个商品价格等于详情页价格新品tab第一个商品价格等于详情页价格成功

二、构建脚本

1、按用例编写测试脚本

# -*- coding: utf-8 -*-
# @Time  : 2022/6/23 19:12
# Author : 拒绝内卷的小测试

from appium.webdriver.common.mobileby import MobileBy
from appium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
import time


class TestClass:
    def setup(self):
        # 创建⼀个字典,⽤于存储设备和应⽤信息
        desired_caps = {
            "platformName": "Android",
            "platformVersion": "11.0.0",
            "deviceName": "eqb6w4zldmmvvwln",
            "appPackage": "com.suning.mobile.ebuy",
            "appActivity": "com.suning.mobile.ebuy.host.InitialActivity"
        }

        # 与appium session之间建⽴联系,括号内为appium服务地址
        global driver
        driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)

        # 进入app,点击同意按钮
        agree_locator = (MobileBy.ANDROID_UIAUTOMATOR, 'new UiSelector().text("同意")')
        WebDriverWait(driver, 10).until(EC.visibility_of_element_located(agree_locator)).click()
        # 点击我知道了按钮
        know_locator = (MobileBy.ID, 'com.suning.mobile.ebuy:id/privacy_know')
        WebDriverWait(driver, 10).until(EC.visibility_of_element_located(know_locator)).click()
        time.sleep(10)

        # 滑动屏幕
        x = driver.get_window_size()['width']
        y = driver.get_window_size()['height']
        driver.swipe(int(x * 0.5), int(y * 0.5), int(x * 0.5), int(y * 0.1), duration=500)

        # 点击新品tab
        newcomm_locator = (MobileBy.ANDROID_UIAUTOMATOR, 'new UiSelector().text("新品")')
        WebDriverWait(driver, 10).until(EC.visibility_of_element_located(newcomm_locator)).click()
        time.sleep(3)

    def test_001(self):
        # 获取首页新品第一个商品价格
        home_price_locator = (MobileBy.ID, 'com.suning.mobile.ebuy:id/product_price_tv_1')
        home_price = (WebDriverWait(driver, 10).until(EC.visibility_of_element_located(home_price_locator))).text
        print(home_price)

        # 点击第一个新品进商品详情页
        pageInfo_locator = (MobileBy.ID, 'com.suning.mobile.ebuy:id/product_iv_1')
        WebDriverWait(driver, 10).until(EC.visibility_of_element_located(pageInfo_locator)).click()
        time.sleep(10)

        #  判断是否有活动,倒计时上方文案
        time_text_locator = (MobileBy.ID, "com.suning.mobile.ebuy:id/tv_flash_sale_time_down_name")
        if "距" in WebDriverWait(driver, 10).until(EC.visibility_of_element_located(time_text_locator)).text:
            # 获取详情页商品活动价格
            pageInfo_gbprice_locator = (MobileBy.ID, 'com.suning.mobile.ebuy:id/tv_flash_sale_price')
            pageInfo_gbprice = (
                WebDriverWait(driver, 10).until(EC.visibility_of_element_located(pageInfo_gbprice_locator))).text
            print(pageInfo_gbprice)

            # 断言首页价格等于详情页商品活动价格
            assert home_price == pageInfo_gbprice, f"预期价格为{home_price},实际结果为{pageInfo_gbprice}"
        else:
            # 获取详情页商品价格前¥符号
            pageInfo_price_label_locator = (MobileBy.ID, 'com.suning.mobile.ebuy:id/tv_ord_price_lable')
            pageInfo_price_label = (
                WebDriverWait(driver, 10).until(EC.visibility_of_element_located(pageInfo_price_label_locator))).text

            # 获取详情页商品价格
            pageInfo_price_locator = (MobileBy.ID, 'com.suning.mobile.ebuy:id/tv_ord_price_value')
            pageInfo_price = (
                WebDriverWait(driver, 10).until(EC.visibility_of_element_located(pageInfo_price_locator))).text

            # 因为详情页价格符号和价格是分开的,所以相加得到完整详情页价格
            page_price = pageInfo_price_label + pageInfo_price
            print(page_price)

            # 断言首页价格等于详情页价格
            assert home_price == page_price, f"预期价格为{home_price},实际结果为{page_price}"

2、测试用例执行及测试报告输出

在这里插入图片描述

# -*- coding: utf-8 -*-
# @Time  : 2022/6/23 19:12
# Author : 拒绝内卷的小测试

import pytest

pytest.main(["--html=reports/report.html", "--self-contained-html"])

三、测试框架结构

在这里插入图片描述

四、项目下载

点击下载

随手点赞一次,运气增加一份。

  • 8
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Appium是一个用于移动应用自动化测试的开源工具,而Pytest是一个Python的测试框架。结合使用AppiumPytest,可以搭建一个强大的移动应用自动化测试框架。 使用AppiumPytest进行自动化测试时,首先需要安装AppiumAppium Python客户端。然后,编写测试脚本,可以使用Pytest提供的各种断言和测试装置。 下面是一个简单的例子,演示了如何使用AppiumPytest进行自动化测试: ```python import pytest from appium import webdriver @pytest.fixture def driver(): desired_caps = { 'platformName': 'Android', 'deviceName': 'your_device_name', 'appPackage': 'your_app_package', 'appActivity': 'your_app_activity' } driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps) yield driver driver.quit() def test_login(driver): # 执行登录操作 # ... # 使用Pytest进行断言 assert driver.find_element_by_id('login_success_element').is_displayed() def test_logout(driver): # 执行退出操作 # ... # 使用Pytest进行断言 assert driver.find_element_by_id('logout_success_element').is_displayed() ``` 在上面的例子中,我们使用了`@pytest.fixture`装饰器来创建一个测试驱动程序实例。通过将`driver`作为参数传递给测试函数,我们可以在每个测试用例中共享同一个驱动程序实例。 然后,我们编写了两个测试函数`test_login`和`test_logout`,分别测试登录和退出功能。在每个测试函数中,我们使用Appium提供的API执行相应的操作,并使用Pytest提供的断言来验证测试结果。 最后,使用Pytest运行测试脚本即可进行自动化测试。 需要注意的是,上述示例代码只是一个简单的示例,实际项目中可能需要更复杂的操作和断言。同时,还可以结合其他的测试工具和框架,例如Allure报告、数据驱动等,来提升测试效果和维护性。 希望以上信息对你有帮助!如有更多问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拒绝内卷的小测试

感谢老板的投喂

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值