8年经验之谈 —— 如何使用自动化工具编写测试用例?_安全测试用例执行自动化

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上网络安全知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip204888 (备注网络安全)
img

正文

  • 明确概述目标。
  • 确定是否进行功能、回归、性能或任何其他特定类型的测试。
  • 了解您的测试目标将指导您创建相关且有意义的测试用例。
  • 此外,通过指定测试用例需要涵盖的领域和功能来定义测试工作的范围。
第3步:选择正确的自动化工具
  • 选择合适的自动化工具对于成功的测试自动化至关重要。
  • 根据您的项目要求、技术堆栈和预算限制评估各种自动化工具。
  • Selenium、Apache JMeter、EggPlant、SoapUI、LambdaTest、CyPress等工具可用于测试用例自动化。
  • 考虑应用程序类型(Web、移动、桌面)、支持的编程语言、易用性、社区支持和集成功能。
  • 选择最适合项目需求并支持应用程序中使用的技术的工具。
  • 优先级指导你有效地分配测试工作,特别是当担心时间限制时。
第4步:规划测试数据和环境
  • 确定测试用例所需的测试数据。
  • 测试数据包括需要测试的各种输入和场景,包括积极的和消极的。
  • 确保您准备好并组织了必要的测试数据,以有效地执行测试用例。
  • 此外,使用所需的配置、数据库和依赖项设置测试环境以模拟真实场景。
第5步:设计测试用例
  • 创建清晰一致的测试用例模板,其中包括测试用例ID、描述、测试步骤、输入数据、预期结果和通过/失败标准字段。
  • 编写单独的测试用例,保持它们的原子性和独立性。避免编写难以维护的又长又复杂的测试用例。
  • 使用清晰且具有描述性的测试用例名称,使其易于理解。包括测试执行所需的任何先决条件。
第6步:利用测试设计技术
  • 应用测试设计技术来创建全面且有效的测试用例。
  • 等价划分、边界值分析、决策表、状态转换图和基于用例的测试等技术可帮助识别测试场景并验证应用程序在各种条件下的行为。
  • 这些技术提高了测试覆盖率并确保系统化的测试用例创建方法。
第7步:确定测试用例的优先级
  • 根据测试用例的重要性和对应用程序的影响对测试用例进行排名,以有效地确定它们的优先级。
  • 通过优先考虑高优先级测试用例,实现关键功能的全面测试。
第8步:实施测试自动化框架
  • 使用所选的自动化工具设置测试自动化框架。
  • 自动化框架为自动化测试脚本开发和管理提供了结构化方法。
  • 它可能包括预定义的函数、库和实用程序,以促进高效的测试脚本开发。
  • 构建强大的自动化框架对于扩展和维护测试自动化工作至关重要。

第9步:编写自动化测试脚本

  • 使用自动化工具的脚本语言或界面将手动测试用例转换为自动化测试脚本。
  • 自动化工具通常提供与应用程序的用户界面交互并验证预期结果的方法或功能。
  • 编写模拟用户交互的测试脚本,并根据测试用例验证应用程序的行为。
第10步:运行和调试测试脚本
  • 在测试环境中执行自动化测试脚本。
  • 监督测试执行并解决测试过程中出现的任何问题。
  • 调试对于测试自动化至关重要,以确保测试脚本顺利运行并产生准确的结果。
第11步:生成测试报告
  • 收集并分析自动化工具生成的测试结果。
  • 自动化测试报告提供有关测试覆盖范围、通过/失败状态和检测到的缺陷的见解。
  • 这些报告可帮助利益相关者和测试团队了解应用程序的运行状况以及正在测试的软件的质量。
第12步:维护和更新测试用例
  • 持续审查和更新测试用例,以确保持续的相关性和有效性。
  • 随着应用程序的发展或新功能的添加,请更新测试用例以反映这些更改。
  • 定期维护可确保测试用例随着时间的推移保持可靠和准确。
第13步:将自动化集成到 CI/CD 管道中
  • 将自动化测试脚本集成到持续集成 (CI) 和持续交付 (CD) 管道中,以便在每次代码提交或部署时无缝执行。
  • CI/CD 管道中自动化的集成可以在开发过程中及早识别问题,并促进持续测试和交付。
第14步:持续改进测试自动化
  • 收集反馈以确定需要改进的领域。
  • 定期评估自动化测试用例和自动化脚本的有效性。
  • 不断增强测试自动化以提高有效性和效率。
  • 拥抱学习和优化的文化,以确保测试自动化在整个软件开发生命周期中保持相关性和价值。

按照此详细的分步指南,可以使用自动化工具编写全面且高效的测试用例,从而提高软件质量并简化测试流程。

示例:测试Web应用程序的登录功能

在这里,我将示范使用Python中的 Selenium WebDriver自动化工具为登录功能编写测试用例。在运行代码之前,我们应该安装 Selenium WebDriver 和浏览器相应的 Web 驱动程序(例如 ChromeDriver)。

1.通过导入所需的库来设置WebDriver。

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
import time


driver = webdriver.Chrome()
driver.maximize_window()

2.定义测试用例场景和测试数据。

valid_username = "testuser123"
valid_password = "Test@123"
invalid_username = "invaliduser"
invalid_password = "invalidpassword"


test_scenarios = [
    {"username": valid_username, "password": valid_password, "expected_result": "success"},
    {"username": invalid_username, "password": valid_password, "expected_result": "failure"},
    {"username": valid_username, "password": invalid_password, "expected_result": "failure"},
    {"username": invalid_username, "password": invalid_password, "expected_result": "failure"},
]

3.编写测试用例函数来执行登录测试用例。

deftest_login(username, password, expected_result):
    driver.get("https://example.com/login")
    username_input = driver.find_element(By.NAME, "username")
    password_input = driver.find_element(By.NAME, "password")
    login_button = driver.find_element(By.XPATH, "//button[contains(text(), 'Login')]")


    username_input.clear()
    username_input.send_keys(username)


    password_input.clear()
    password_input.send_keys(password)


    login_button.click()


    time.sleep(2)


    if expected_result == "success":
        welcome_message = driver.find_element(By.XPATH, "//h1[contains(text(), 'Welcome')]")
        assert welcome_message.is_displayed(), "Login failed. Welcome message not displayed."
    elif expected_result == "failure":
        error_message = driver.find_element(By.XPATH, "//div[@class='error-message']")
        assert error_message.is_displayed(), "Expected error message not displayed."


    time.sleep(2)

4.执行测试用例。

for scenario in test_scenarios:
    username = scenario["username"]
    password = scenario["password"]
    expected_result = scenario["expected_result"]
    print(f"Testing login with username: {username}, password: {password}")
    test_login(username, password, expected_result)


driver.quit()

此示例定义了四个测试场景,每个场景都涉及有效和无效用户名和密码的不同组合。test_login函数输入用户名、密码和预期结果,并使用Selenium WebDriver 执行登录操作。然后它根据期望的结果检查登录是否成功。

结语

测试用例自动化是追求软件质量和可靠性的强大助力。通过选择正确的自动化工具、设计有效的测试用例并结合最佳实践,软件测试人员可以充分利用自动化的潜力,以实现更快的发布周期、更高的测试覆盖率和提高的产品质量。

拥抱测试自动化,同时承认其局限性,可以采用平衡的软件测试方法,实现手动和自动化测试技术之间的完美和谐。

最后: 可以在我的VX公众号:【自动化测试老司机】免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!

如何自学黑客&网络安全

黑客零基础入门学习路线&规划

初级黑客
1、网络安全理论知识(2天)
①了解行业相关背景,前景,确定发展方向。
②学习网络安全相关法律法规。
③网络安全运营的概念。
④等保简介、等保规定、流程和规范。(非常重要)

2、渗透测试基础(一周)
①渗透测试的流程、分类、标准
②信息收集技术:主动/被动信息搜集、Nmap工具、Google Hacking
③漏洞扫描、漏洞利用、原理,利用方法、工具(MSF)、绕过IDS和反病毒侦察
④主机攻防演练:MS17-010、MS08-067、MS10-046、MS12-20等

3、操作系统基础(一周)
①Windows系统常见功能和命令
②Kali Linux系统常见功能和命令
③操作系统安全(系统入侵排查/系统加固基础)

4、计算机网络基础(一周)
①计算机网络基础、协议和架构
②网络通信原理、OSI模型、数据转发流程
③常见协议解析(HTTP、TCP/IP、ARP等)
④网络攻击技术与网络安全防御技术
⑤Web漏洞原理与防御:主动/被动攻击、DDOS攻击、CVE漏洞复现

5、数据库基础操作(2天)
①数据库基础
②SQL语言基础
③数据库安全加固

6、Web渗透(1周)
①HTML、CSS和JavaScript简介
②OWASP Top10
③Web漏洞扫描工具
④Web渗透工具:Nmap、BurpSuite、SQLMap、其他(菜刀、漏扫等)
恭喜你,如果学到这里,你基本可以从事一份网络安全相关的工作,比如渗透测试、Web 渗透、安全服务、安全分析等岗位;如果等保模块学的好,还可以从事等保工程师。薪资区间6k-15k

到此为止,大概1个月的时间。你已经成为了一名“脚本小子”。那么你还想往下探索吗?

如果你想要入坑黑客&网络安全,笔者给大家准备了一份:282G全网最全的网络安全资料包评论区留言即可领取!

7、脚本编程(初级/中级/高级)
在网络安全领域。是否具备编程能力是“脚本小子”和真正黑客的本质区别。在实际的渗透测试过程中,面对复杂多变的网络环境,当常用工具不能满足实际需求的时候,往往需要对现有工具进行扩展,或者编写符合我们要求的工具、自动化脚本,这个时候就需要具备一定的编程能力。在分秒必争的CTF竞赛中,想要高效地使用自制的脚本工具来实现各种目的,更是需要拥有编程能力.

如果你零基础入门,笔者建议选择脚本语言Python/PHP/Go/Java中的一种,对常用库进行编程学习;搭建开发环境和选择IDE,PHP环境推荐Wamp和XAMPP, IDE强烈推荐Sublime;·Python编程学习,学习内容包含:语法、正则、文件、 网络、多线程等常用库,推荐《Python核心编程》,不要看完;·用Python编写漏洞的exp,然后写一个简单的网络爬虫;·PHP基本语法学习并书写一个简单的博客系统;熟悉MVC架构,并试着学习一个PHP框架或者Python框架 (可选);·了解Bootstrap的布局或者CSS。

8、超级黑客
这部分内容对零基础的同学来说还比较遥远,就不展开细说了,附上学习路线。
img

网络安全工程师企业级学习路线

img
如图片过大被平台压缩导致看不清的话,评论区点赞和评论区留言获取吧。我都会回复的

视频配套资料&国内外网安书籍、文档&工具

当然除了有配套的视频,同时也为大家整理了各种文档和书籍资料&工具,并且已经帮大家分好类了。

img
一些笔者自己买的、其他平台白嫖不到的视频教程。
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注网络安全)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

convert/32eb4b22aa740233c5198d3c161b37e8.webp?x-oss-process=image/format,png)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注网络安全)
[外链图片转存中…(img-n4YezWya-1713297087765)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值