问题的背景:
自动化测试的第一个工具在20多年前问世,当时这些工具只是简单的用户操作录制和回放工具。随着时间的推移,出现了编程语言、专用框架以及强大的工具,如Selenium、Appium、TestCafe、Playwright等。今天,选择工具受多种因素影响:项目的特性、团队、可扩展性、所开发应用的类型。
问题:
主要难点是缺乏通用解决方案。工具在所支持的平台(web、移动、桌面)、编程语言、实施简便性、性能和拥有成本等方面各不相同。公司常常只关注工具的受欢迎程度或推荐,而没有分析自己的任务和限制,从而犯错误。
解决方案:
在选择时,应该考虑以下标准:与技术栈的兼容性、团队支持、对应用更新的抵抗力、与现有流水线的集成能力、支持和文档的可用性、实施和维护的成本。重要的是进行比较分析,并在真实任务上试点2-3个工具,然后做出最终决定。
关键特点:
可以选择最受欢迎的框架(例如,Selenium),并且确信它能完美适用于任何任务吗?
不行,Selenium是一个强大的工具,但并不适用于任何任务的自动化。例如,它不支持移动应用。此外,它在与不同语言的集成和支持方面也有自己的细节。
付费自动化工具与免费工具有什么不同?购买它们是否合理?
付费工具通常提供额外支持、更好的可视化工具、与企业解决方案的集成。但是,随着开源技术的发展,许多任务可以免费成功解决。如果需要快速支持、专门集成或安全性,购买是有道理的。
大项目的所有测试类型是否仅需要一个自动化工具就足够了?
通常情况下,不是。不同的任务可能需要不同的工具。例如,web测试适合用Selenium,移动测试用Appium,API测试用Postman+Newman或Rest Assured等。
在一家金融科技公司,决定使用Selenium来自动化所有内容:web、移动应用和API。经过一年,团队不得不为移动应用的测试编写许多不稳定的封装和临时解决方案,而API则手动测试。
优点:
缺点:
在另一家公司,评估了任务的特性:web通过Playwright测试,移动应用通过Appium,API通过Rest Assured。团队进行了培训,设置了流水线,实现了高覆盖率和稳定的工作。
优点:
缺点: