web自动化测试进阶篇05 ——— 界面交互场景测试

在这里插入图片描述

 
 

在这里插入图片描述
😏作者简介:博主是一位测试管理者,同时也是一名对外企业兼职讲师。
📡主页地址:【Austin_zhai】
🙆目的与景愿:旨在于能帮助更多的测试行业人员提升软硬技能,分享行业相关最新信息。
💎声明:博主日常工作较为繁忙,文章会不定期更新,各类行业或职场问题欢迎大家私信,有空必回。

在这里插入图片描述

 
 

阅读目录

  • 1. 目的
  • 2. 作用
  • 3. 实操
    • 3.1 场景介绍与拆分
    • 3.2 GWT表设计
    • 3.3 代码设计
  • 4. 后话

1. 目的

在这里插入图片描述

  界面交互作为黑盒测试内容中重要的一环,在广大的测试人员群体中几乎成了入行的第一个接触内容,执行测试任务时站在客户角的度出发是每个测试人员都必须做到的基本条件,而模拟客户的日常业务操作,界面交互操作就成为了重中之重。同样的在自动化测试中,我们该如何更好的将界面交互操作融入到实际的自动化测试代码和框架中呢,今天博主就带着大家来看一看界面交互的一些进阶设计方法。

 
 

2. 作用

在这里插入图片描述

  那么在自动化测试中界面交互具体的实际意义有哪些呢?首先从业务层面来看,测试人员为了更接近真实用户的日常业务行为,必定需要设计一系列的对应界面交互操作,因为复杂交互测试会涉及多个元素之间的复杂交互和页面状态的变化,更接近真实用户在web被测对象中的实际操作,比起无计划的胡乱操作,通过特定的界面交互操作可以有效的模拟用户实际的使用场景,从而更全面地验证应用程序的功能和用户体验。那么与之相呼应的就是一旦形成有明确目的性的界面交互操作规划之后,该功能模块的测试覆盖率自然而然的就会被提升上来,我们所熟知的界面交互,除了一些组件的操作之外,动态内容、异步请求、页面跳转、弹出框交互等等也是经常会涉及到。有了这些元素的交叉与组合,测试人员就可以发现更多的潜在问题,从而提高测试的覆盖率。

  另外,除了界面的基础交互之外,数据的交换(前端与后端的逻辑处理)同样也可以借由界面交互的检查来进行验证。当然,这需要之前的有效交互操作规划来作为大前提。比如通过数据表单提交和后台数据的处理,可以验证前后端数据的传递是否正确,这样的场景相信大家应该都不会陌生,那么如何有效的排列组合各类的表单提交与数据检查就成为了是否成功执行该类测试场景的核心因素之一。

 
 

3. 实操

在这里插入图片描述
  好了,以上是对于界面交互的一些大致内容进行了一些了解,那我们接下来以一个实际的业务案例来进行界面交互在自动化测试中的应用方法。

 

3.1 场景介绍与拆分

   测试业务场景:某金融系统中,用户希望申请一笔贷款。贷款申请涉及填写个人信息、选择贷款产品、填写贷款金额、选择还款期限、上传必要资料等步骤,同时系统会根据用户信息和贷款产品进行额度计算和还款计划展示。在申请过程中,可能会遇到不同的验证和提示信息,用户需要正确填写和处理各项信息,以成功提交贷款申请。

  那接下来我们将业务场景进行最基本的业务流步骤拆解,这与我们设计测试代码的覆盖范围与执行步骤、界面交互有很重要的联系,所以拆解需要尽量的清晰与简洁。

  • 用户登录金融系统账户。
  • 导航到贷款申请页面。
  • 填写个人信息,包括姓名、身份证号、手机号等,并进行格式验证。
  • 选择贷款产品类型,例如个人消费贷款、车辆抵押贷款等。
  • 填写贷款金额,并验证金额范围。
  • 选择还款期限,例如12个月、24个月等,并验证还款期限与贷款产品的对应关系。
  • 上传必要资料,例如身份证扫描件、工资单等,验证上传的文件格式和大小。
  • 系统进行额度计算和还款计划展示,并与预期结果进行对比。
  • 处理风险提示,如还款风险、借贷条款等,确认并同意。
  • 提交贷款申请。
  • 验证贷款申请状态,确保申请成功。

对应的预期结果

  • 用户能够成功登录账户并导航到贷款申请页面。
  • 用户填写的个人信息和贷款信息符合格式和范围要求。
  • 贷款额度计算和还款计划展示与预期结果一致。
  • 用户成功提交贷款申请,并能够查看申请状态。

 

3.2 GWT表设计

   基于以上的业务场景与步骤拆解,我们已经可以明确的看到其中的对应测试范围与功能点了,那么在此基础上我们就可以将以上这些进行系统的输出,形成对应的测试故事了。

场景:用户进行普通贷款申请
 
场景描述: 作为贷款申请者,用户希望能够成功申请一笔贷款,从而展开的一系列申请业务所需步骤。
 
 
Given:
用户已经登录到自己的金融账户
用户还未进行对应的信息登记(姓名、身份证号、手机号)
用户所拥有的所有认证信息均有效且登记成功
 
When:
用户进入贷款申请页面
用户使用有效的个人信息填写表单
用户选择一种贷款产品类型
用户输入符合允许范围的贷款金额
用户选择有效还款期限
用户上传必要的文件
 
Then:
被测对象应该计算贷款金额并展示还款计划
用户查看并接受贷款条款和条件
用户提交贷款申请
用户应该看到他的贷款申请状态为成功

 

3.3 代码设计

  当我们整理出以上的这些信息之后,就可以正式的开始设计对应的测试代码了,当然这里只是简单的演示传统业务下我们该如何将界面交互测试的内容融入自动化测试框架中,其中的很多步骤(测试用例的设计,代码的单元测试,优化迭代)这里碍于篇幅就不展开细说了,有疑问的可以留言或私信博主。

  与大部分的UI自动化测试框架一样,我们可以将需要测试的业务部分拆分成三部分,base、page_objects、test_loan_application分别对应三个python脚本,base就不用多说了,一些基础驱动方法都是放在这里面的,page_objects看到名字就知道我们基于PO模式将页面的元素封装在这里面,而test_loan_application当然就是我们的测试用例啦。

  话不多说,我们先来设计base脚本:

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC

class BasePage:
    def __init__(self, driver):
        self.driver = driver

    def wait_for_element_to_be_visible(self, by, locator, timeout=10):
        wait = WebDriverWait(self.driver, timeout)
        return wait.until(EC.visibility_of_element_located((by, locator)))

class BaseTest:
    @classmethod
    def setUpClass(cls):
        cls.driver = webdriver.Chrome()
        cls.driver.implicitly_wait(5)
        cls.driver.maximize_window()

    @classmethod
    def tearDownClass(cls):
        cls.driver.quit()

 

  base脚本没什么好多说的,属于是常规操作了,需要说明的就是base中加入了对应异步通信的显式等待,这个大家见仁见智,自由发挥即可。接下来是page_objects,页面上的可见对象(测试对象)包括一些常见组件(按钮、下拉框等)全部封装在其中,方便后续的测试用例中的复用。

from selenium.webdriver.common.by import By
from base import BasePage

class LoginPage(BasePage):
    def __init__(self, driver):
        super().__init__(driver)
        self.username_input = (By.ID, "username")
        self.password_input = (By.ID, "password")
        self.login_button = (By.ID, "login_button")

    def login(self, username, password):
        self.driver.get("https://example-bank.com/login")
        self.driver.find_element(*self.username_input).send_keys(username)
        self.driver.find_element(*self.password_input).send_keys(password)
        self.driver.find_element(*self.login_button).click()

class LoanApplicationPage(BasePage):
    def __init__(self, driver):
        super().__init__(driver)
        self.product_type_dropdown = (By.ID, "product_type")
        self.loan_amount_input = (By.ID, "loan_amount")
        self.repayment_period_dropdown = (By.ID, "repayment_period")
        self.upload_file_input = (By.ID, "upload_file")
        self.submit_button = (By.ID, "submit_button")

    def apply_for_loan(self, product_type, loan_amount, repayment_period, file_path):
        self.driver.get("https://example-bank.com/loan_application")
        self.driver.find_element(*self.product_type_dropdown).send_keys(product_type)
        self.driver.find_element(*self.loan_amount_input).send_keys(loan_amount)
        self.driver.find_element(*self.repayment_period_dropdown).send_keys(repayment_period)
        self.driver.find_element(*self.upload_file_input).send_keys(file_path)
        self.driver.find_element(*self.submit_button).click()

    def click_calculate_button(self):
        calculate_button = self.wait_for_element_to_be_visible(By.ID, "calculate_button")
        calculate_button.click()

    def select_repayment_period(self, period):
        repayment_period_dropdown = self.wait_for_element_to_be_visible(By.ID, "repayment_period")
        select = Select(repayment_period_dropdown)
        select.select_by_visible_text(period)

    def accept_risk_warning(self):
        accept_button = self.wait_for_element_to_be_visible(By.ID, "accept_button")
        accept_button.click()

	def risk_assessment(self):
		assessment_button = self.wait_for_element_to_be_visible(By.ID, "assessment_button")
		assessment_button.click()

 

  在test_loan_application中,我们主要对测试额度计算、还款计划展示、贷款的申请结果进行断言,在断言之前我们针对业务流程进行对应的界面交互操作,当然真实的业务肯定远远不止如此,大家只需要理解如何封装各类组件并在用例中有计划的调用即可。

import unittest
from base import BaseTest
from page_objects import LoginPage, LoanApplicationPage

class TestLoanApplication(BaseTest):
    def test_loan_application(self):
        login_page = LoginPage(self.driver)
        login_page.login("testuser", "testpass")

        loan_application_page = LoanApplicationPage(self.driver)
        loan_application_page.apply_for_loan("Personal Loan", "5000", "12 months", "path/to/uploaded/file.pdf")

        # 添加异步通信和显式等待,等待贷款申请状态显示并验证
        loan_application_page.wait_for_element_to_be_visible(By.ID, "loan_application_status", timeout=20)
        status = self.driver.find_element(By.ID, "loan_application_status").text
        assert "Successful" in status, "贷款申请状态错误"

        # 测试额度计算和还款计划展示
        loan_amount = "5000"
        repayment_period = "12 months"
        expected_loan_amount = "5000"
        expected_repayment_plan = "Monthly Installments: 12\nAmount per Installment: 416.67"
        loan_application_page.fill_loan_amount_and_repayment_period(loan_amount, repayment_period)
        loan_application_page.click_calculate_button()
        loan_application_page.wait_for_element_to_be_visible(By.ID, "calculated_loan_amount", timeout=10)
        calculated_loan_amount = self.driver.find_element(By.ID, "calculated_loan_amount").text
        assert calculated_loan_amount == expected_loan_amount, "额度计算错误"
        repayment_plan = self.driver.find_element(By.ID, "repayment_plan").text
        assert repayment_plan == expected_repayment_plan, "还款计划展示错误"

        # 处理风险提示
        risk_warning = loan_application_page.get_risk_warning_text()
        if risk_warning:
            loan_application_page.accept_risk_warning()
        else:
            # 如果没有风险提示,进行投资风险评估
            loan_application_page.risk_assessment()

        # 选择还款期限
        new_repayment_period = "24 months"
        loan_application_page.select_repayment_period(new_repayment_period)

        # 提交贷款申请
        loan_application_page.submit_loan_application()
        loan_application_page.wait_for_element_to_be_visible(By.ID, "loan_application_status", timeout=20)
        status = self.driver.find_element(By.ID, "loan_application_status").text
        assert "Successful" in status, "贷款申请状态错误"

if __name__ == "__main__":
    unittest.main()

 
 

4. 后话

  看完以上的这个实操例子之后不知道对大家是否有所启发,其实不是说一定要用以上的方法来进行测试任务的拆解,在这里只想告诉大家,在自动化UI测试中,面对界面交互场景的测试时,我们需要有计划的对界面交互操作进行设计与实施,至于方法,这里只是给出了其中的一种思路而已,相信大家在日后的工作中一定会整理总结出适用与自己与团队的一套设计与执行的方法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/45991.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

stm32 IIC通信

文章目录 IIC 通信一、硬件电路二、IIC时序基本单元三、IIC时序1.指定地址写2.当前地址读3.指定地址读 IIC 通信 IIC总线是一种通用数据总线,有两根通信线(SCL(串行时钟总线),SDA(串行数据总线))。 特点:同…

【SpringCloud Alibaba】(二)微服务环境搭建

1. 项目流程搭建 整个项目主要分为 用户微服务、商品微服务和订单微服务,整个过程模拟的是用户下单扣减库存的操作。这里,为了简化整个流程,将商品的库存信息保存到了商品数据表,同时,使用商品微服务来扣减库存。小伙…

Rust vs Go:常用语法对比(十一)

题目来自 Rust Vs Go: Which Language Is Better For Developing High-Performance Applications?[1] 202. Sum of squares Calculate the sum of squares s of data, an array of floating point values. 计算平方和 package mainimport ( "math")func main() { da…

android数据的储存、文件的储存、SharedPreferences储存、SQLite的基本用法

一、文件的储存 1、将数据储存到文件中 Context类中提供了openfileOutput()方法,用来获取一个文件流,这个方法接收两个参数,第一个参数是文件名,在文件创建的时候使用的就是这个名称,注意这里指定的文件名不可以包含…

React AntDesign写一个导出数据的提示语 上面有跳转的路径,或者点击知道了,关闭该弹层

效果如下: 代码如下: ForwardDataCenterModal(_blank);export const ForwardDataCenterModal (target?: string) > {let contentBefore React.createElement(span, null, 数据正在处理中,请稍后前往);let contentAfter React.creat…

JAVA基础-集合(List与Map)

目录 引言 一,Collection集合 1.1,List接口 1.1.1,ArrayList 1.1.1.1,ArrayList的add()添加方法 1.1.1.2,ArrayList的remove()删除方法 1.1.1.3,ArrayList的contai…

网络超时导致namenode被kill的定位

交换机升级导致部分网络通信超时, 集群的namenode主从切换后,主namenode进程被杀死。 网络问题导致namenode与zk间的连接超时触发了hadoop集群的防脑裂机制而主动kill掉了超时的namenode进程。 日志分析发现zk和namenode之间的网络连接超时: 超时触发了namenode切换,并将超时…

游戏引擎UE如何革新影视行业?创意云全面支持UE云渲染

虚幻引擎UE(Unreal Engine)作为一款“殿堂级”的游戏引擎,占据了全球80%的商用游戏引擎市场,但如果仅仅将其当做游戏开发的工具,显然是低估了它的能力。比如迪士尼出品的电视剧《曼达洛人》、电影《狮子王》等等都使用…

白话机器学习笔记(三)评估已建立的模型

模型评估 在进行回归和分类时,为了进行预测,我们定义了函数 f θ ( x ) f_\theta(x) fθ​(x),然后根据训练数据求出了函数的参数 θ \theta θ。 如何预测函数 f θ ( x ) f_\theta(x) fθ​(x)的精度?看它能否很好的拟合训练数…

【Django学习】(十五)API接口文档平台_项目流程分析_日志器_认证_授权

一、API接口文档平台 使用API接口文档不经可以很好的的维护接口数据,还给测试人员的接口测试工作带来了便利; 我们可以在全局配置文件中添加路由路径生成接口文档 1、使用docs接口文档维护接口 1.1在全局配置文件里指定用于支持coreapi的Schema # 指…

Linux の shell 流程控制

条件控制 # if then 如果else 没有语句 可以省略 if condition then#语句 fi# if then 。。。 else 。。。 fi if condition then#语句 else#语句 fi# if condition then#语句 elif condition2 then#语句 else#语句 fiif [ $a -gt $b ] thenecho "a > b&quo…

骆驼祥子思维导图

《骆驼祥子》简单介绍 《骆驼祥子》小说,以20世纪20年代的旧北京为背景。祥子所处的时代是北洋军阀统治的时代。今天我们就用ProcessOn 思维导图 来给大家解析这本名著。所有文章中的思维导图都可以到ProcessOn 模板社区获得。 1936年,老舍的一位山东大…

[vulnhub]DC2

文章目录 [vulnhub]DC2信息收集flag1flag2cewlwpscan flag3什么是rbash? flag4flag5git提权 总结 [vulnhub]DC2 信息收集 扫ip,有两种方式:arp、nmap nmap -sP 192.168.56.0/24 -T4arp-scan -l192.168.56.137 扫端口: nmap -…

Mendix 创客访谈录|综合业务展示大屏应用开发

本期创客 刘书智 西门子工业领域专家 我在西门子工厂自动化工程有限公司工作。一直从事SCADA产品的技术支持工作,已经过去17个年头了。赶上数字化发展的浪潮,不断学习各种IT技术,践行 IT与OT融合,希望借助自己的IT知识助力OT的发…

力扣1114.按序打印-----题目解析

题目描述 解析: class Foo {public int a 0;public Foo() {}public void first(Runnable printFirst) throws InterruptedException {// printFirst.run() outputs "first". Do not change or remove this line.printFirst.run();a;}public void second…

vue全局状态管理工具 Pinia 的使用

先了解一下关于Pinia的一些故事,面试把这些讲给面试官挺加分的,同时这是我持续学习下去的动力 1.为什么叫Pinia? 官网解释是西班牙语中的 pineapple,即“菠萝”,菠萝花是一组各自独立的花朵,它们结合在一起…

【C语言】函数----详解

🍁 博客主页:江池俊的博客 💫收录专栏:C语言——探索高效编程的基石 💻 其他专栏:数据结构探索 🏩代码仓库:江池俊的代码仓库 🎪 社区:C/C之家社区(欢迎大家加入与我一起…

安装VMware

D:\VMware\VMware Workstation\ 输入许可证

Sentinel 规则持久化到 Nacos

一、Sentinel规则管理模式🍉 Sentinel的控制台规则管理有三种模式: 原始模式🥝 原始模式:控制台配置的规则直接推送到Sentinel客户端,也就是我们的应用。然后保存在内存中,服务重启则丢失 pull模式&#…

一文详解Spring Bean循环依赖

一、背景 有好几次线上发布老应用时,遭遇代码启动报错,具体错误如下: Caused by: org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name xxxManageFacadeImpl: Bean with name xxxManageFa…