• Web自动化测试怎么做?Web自动化测试的详细流程和步骤


    一、什么是web自动化测试

    自动化(Automation)是指机器设备、系统或过程(生产、管理过程)在没有人或较少人的直接参与下,按照人的要求,经过自动检测、信息处理、分析判断、操纵控制,实现预期的目标的过程。

    这是教科书里面的自动化的定义,回归到自动化测试其实自动化测试就是什么呢?

    指的是测试的过程在没有人或者较少的人为的干预的情况下进行的测试,再简单点说就是用程序或者脚本来测试程序,那么在web自动化测试中主要用来把测试人员从繁琐的内容中解放出来,主要做一些比如需要多次输入,多次运行的,比如我们用边界值,等价类设计的很多测试数据需要执行,比如业务流程需要执行很多遍的时候我们就可以使用web自动化测试

    二、web自动化测试的工具

    现在主流的web测试工具我们常用的就是selenium的那一套工具包括

    • 浏览器一般选择chrome
    • 浏览器对应的driver(chromedriver)
    • Python
    • Selenium库

    三、web自动化测试的环境安装

    • 浏览器安装 下载浏览器下一步按照就好了
    • chromedriver 下载 可以到 npmmirror.com/
    • 注:100的大版本对的上就Ok了

    在这里插入图片描述

    在这里插入图片描述

    四、web自动化测试的方法

    Web自动化测试一般使用设计测试用例的方法跟功能测试相同,使用等价类划分,边界值,因果图,场景法等等就好了

    Web自动化测试实施的使用我们一般会采用po模式设计

    PO是page object的简称,核心思想是通过对界面元素的封装减少冗余代码,同时在后期维护中,若元素定位发生变化, 只需要调整页面元素封装的代码,提高测试用例的可维护性、可读性。

    PO模式可以把一个页面分为三层,对象库层、操作层、业务层。

    对象库层:封装定位元素的方法。

    操作层:封装对元素的操作。

    业务层:将一个或多个操作组合起来完成一个业务功能。

    比如登录:需要输入帐号、密码、点 击登录三个操作。

    测试脚本只需要调用业务层代码就可以完成

    当出现页面需要的时候只需要测试代码可以完全不用修改只需要修改操作层就好了

    五、web自动化测试的流程实施

    web自动化测试流程和功能测试基本一致:

    下面我们已登录需求为例

    (1)需求分析

    请添加图片描述

    这里我们以手机登录为例

    请添加图片描述

    (2)设计测试用例与测试数据

    自动化测试测试用例不用像手工测试设计的那么详细

    ID测试模块标题前置条件测试输入
    login_001登录错误的手机号登录网络正常,功能正常手机号错误其他输入项正常

    【下方为测试数据】

    [
     {
        "username": "21888888888",
        "pwd": "123456",
        "code": "8888",
        "ast_msg": "账号格式不匹配",
        "desc": "用户名错误"
     },
      {
        "username": "12888888888",
        "pwd": "123456",
        "code": "8888",
        "ast_msg": "账号格式不匹配",
        "desc": "用户名错误"
      },
      {
        "username": "1088888888",
        "pwd": "123456",
        "code": "8888",
        "ast_msg": "账号格式不匹配",
        "desc": "用户名错误"
      },
      {
        "username": "138888888889",
        "pwd": "123456",
        "code": "8888",
        "ast_msg": "账号格式不匹配",
        "desc": "用户名错误"
      },
      {
        "username": "32888888888",
        "pwd": "123456",
        "code": "8888",
        "ast_msg": "账号格式不匹配",
        "desc": "用户名错误"
      },
      {
        "username": " ",
        "pwd": "123456",
        "code": "8888",
        "ast_msg": "用户名不能为空",
        "desc": "用户名错误"
      }
    ]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44

    (3)搭建web自动化测试环境

    在上面环境安装那里已经搭建了

    (4)设计web自动化测试框架

    一般测试po模式的内容包括

    在这里插入图片描述

    (5)编写代码

    在po文件夹中创建page_login

    	from selenium.webdriver.common.by import By
    
    	from utils import UtilsDriver
    	from base.page_base import BasePage
    
    	# 界面对象层
    
      	class PageLogin(BasePage):
    
      	# 账号元素
      	def find_username(self):
         	return self.driver.find_element_by_id("username")
           	# return self.driver.find_element(*self.username)
          	# return self.get_element(self.username)
    
       	# 密码元素
       	def find_pwd(self):
          return self.driver.find_element(By.ID,"password")
    
      	# 验证码元素
        def find_vcode(self):
          return self.driver.find_element_by_id("verify_code")
    
        # 按钮开始登录元素
        def find_login_btn(self):
    	   # return self.driver.find_element_by_name("sbtbutton")
           return self.driver.find_element(By.NAME,"sbtbutton")
    
    	# 操作层
    class HandleLogin(object):
        def __init__(self):
           self.page_login=PageLogin()
    
        def input_username(self,username):
            self.page_login.find_username().send_keys(username)
    
        def input_pwd(self,pwd):
          self.page_login.find_pwd().send_keys(pwd)
    
        def input_vcode(self,code):
           self.page_login.find_vcode().send_keys(code)
    	
        def click_login_btn(self):
            self.page_login.find_login_btn().click()
    
    	# 业务层
    	# 输入用户名密码验证码 点击登录
    class LoginProxy(object):
       def __init__(self):
         self.handle_login = HandleLogin()
    
      def login(self,username,pwd,code):
        self.handle_login.input_username(username)
        self.handle_login.input_pwd(pwd)
        self.handle_login.input_vcode(code)
        self.handle_login.click_login_btn()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56

    脚本执行代码 创建test_login

    # from selenium import webdriver
    	from po.page_home import HomeProxy
    	from po.page_login import LoginProxy
    	from utils import UtilsDriver,get_data
    	import time
    	import pytest
    	import allure
    	
    	@allure.feature("登录功能")
    	class Test_login:
    	    def setup_class(self):
    	        self.login_p=LoginProxy()
    	        self.home_p=HomeProxy()
    	    def setup(self):
    	        
    	        # 进入首页
    	        UtilsDriver.get_driver().get("http://127.0.0.1/")
    	      
    	        # 进入到login界面
    	        self.home_p.go_login_page()
    	    def teardown_class(self):
    	        time.sleep(2)
    	        UtilsDriver.quit_driver()
    	
    	    @pytest.mark.parametrize(["username","pwd","code","asrt_msg"],get_data())
            @allure.story("登录用户名错误")
    	    def test_login_username_error(self,username,pwd,code,asrt_msg):
    	        self.login_p.login(username,pwd,code)
    	        time.sleep(1)
    	        # 登录是否成功的预期结果
    	        res = UtilsDriver.get_msg()
    	        assert asrt_msg in res
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32

    (6)执行测试用例

    可以使用pytest控制测试用例的执行

    @pytest.mark.parametrize([“username”,“pwd”,“code”,“asrt_msg”],get_data())

    [pytest]
    addopts = -s --alluredir report
    testpaths = ./script
    python_files = test_*.py *test.py
    python_classes = Test_*
    python_functions = test_*
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    (7)生成测试报告

    可以使用allure生成测试报告

    在这里插入图片描述

    PS:这里分享一套软件测试的自学教程合集。对于在测试行业发展的小伙伴们来说应该会很有帮助,有需要的朋友你可以关注个人公众号:程序员一凡 获取软件测试资源。除了基础入门的资源,博主也收集不少进阶自动化的资源,从理论到实战,知行合一才能真正的掌握。全套内容已经打包到网盘,内容总量接近100个G。

    ☑ 215集-零基础到精通全套视频课程
    ☑ [课件+源码]-完整配套的教程
    ☑ 18套-测试实战项目源码
    ☑ 37套-测试工具软件包
    ☑ 268道-真实面试题
    ☑ 200个模板-面试简历模板、测试方案模板、软件测试报告模板、测试分析模版、测试计划模板、性能测试报告、性能测试报告、性能测试脚本用例模板(信息完整)

    这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

  • 相关阅读:
    23王道408全
    国家数据局正式揭牌,数据专业融合型人才迎来发展良机
    MySQL递归查询
    如何便捷获取参考文献的引用格式?
    ElasticSearch01_简介、详解倒排索引、安装es以及kibana、检索es基本信息、增删改查文档
    个人论坛系统的测试用例
    DVWA靶场&Brute Force 暴力破解&审计通关教程
    VisualSP Enterprise - September 2023 Crack
    STM32 从0开始移植FreeRTOS
    机器学习,神经网络中,自注意力跟卷积神经网络之间有什么样的差异或者关联?
  • 原文地址:https://blog.csdn.net/weixin_56502375/article/details/125621586