关于自动化测试的误区(完整版)

自动化测试作为软件测试的一种技术手段,时常被大家讨论。本人在自动化技术方面有过略有小成,今天聊一聊关于自动化的一些误区,以帮助新手能正确的了解和认识自动化一些概念。

测试的行为本质是什么?

为什么先从这个概念开始谈起,因为对于新手来说,总是把自动化看得很高端和复杂。

先来看看功能测试如何进行的:编写测试用例,测试用例当中最主要的是测试步骤和预期结果;测试人员根据测试用例执行操作步骤,然后通过眼睛和思考判断实际结果与预期结果是否相等。如果相等,测试通过;如果不相等,测试失败。

自动化测试要做的事情与功能测试是一致。这里的自动化主要包含三个层面的自动化,单元测试自动化,接口测试自动化和web测试自动化。当然,不同层面的自动化关注点是不一样的。

单元测试自动化,调用被测试的类或方法,根据类或方法的参数,传入相应的数据。然后,得到一个返回结果。最终断言返回的结果是否等于预期结果。如果相等,测试通过;如果不相等,测试失败。所以,这里单元测试关注的是代码的实现与逻辑。

接口测试自动化,根据接口文档,到底是传get请求呢?还是post请呢?调用被测试的接口,构造相应的数据(id=1,name=zhangsan),得到返回值,是200成功,并返回查询结果。还是10021,用户名不能为空。不管输入的参数是怎样的,我们都将得到一个结果。最终断言返回的结果是否等于预期结果。如果相等,测试通过;如果不相等,测试失败。所以,接口测试关注的是数据。只要数据正确了,功能就做成大半,剩下的无非是如何把这些数据展示在页面上。

如果对软件测试有兴趣,想了解更多的测试知识,解决测试问题,以及入门指导,帮你解决测试中遇到的困惑,我们这里有技术高手。如果你正在找工作或者刚刚学校出来,又或者已经工作但是经常觉得难点很多,觉得自己测试方面学的不够精想要继续学习的,想转行怕学不会的, 都可以加入我们1079636098,群内可领取最新软件测试大厂面试资料和Python自动化、接口、框架搭建学习资料!

web测试的自动化,这种测试更贴近用户的行为,模拟用户点击了某个按钮,向个输入框里输入了什么。但是用户可以看到登录成功了,但web自动化并不知道它刚才的点击有没有生效。所以,要找“证据”,比如,登录成功后页面右上角会显示“欢迎,xxx”。这就是登录成功的有力“证据”。于是,当web自动化登录成功后,就去获取这个数据进行断言。断言如果相等,测试通过;如果不相等,测试失败。所以,web自动化的关注点用户操作形为,页面上真正的按钮和输入框是否可用。

所以,从测试的行为本质上来看,功能测试与单元自动化测试,接口自动化测试和web自动化测试并没有区别。唯一的区别是,一个由人来执行,一个由代码或工具执行。

我们时常会听到两个声音:

一种声音,许多测试新手把自动化想象成走向人生巅峰的必备技能。只要掌握了自动化就可以当上CTO,迎娶白富美,走向人生巅峰了。时常用期盼的小眼神问:xxx 自动化多少钱一个月?如何学习自动化测试技术?推荐个书或资料或视频吧?

另一种声音,略懂自动化的,被自动化坑过的,或者压根就鄙视和抵触自动化的,又把自动化说成屎。页面老是变,维护成本高,这个元素TM怎么定位不到。劳民伤财,费了很大力气也发现不了bug。而自动化用例本身到是bug不断。什么?自动化居然不能做浏览器兼容性测试?什么?你们领导让你搞自动化呀?你们领导SB。

先说前一种声音,理论上任何技能都是为了提高效率和产出,节约公司成本为前提的。比如,以前项目要5个测试,现在用了自动化之后,3个就够了。但如果用了自动化,还需要再招2个人来维护自动化脚本。那就没戏。那我只为学习不行啊?我学好了找个专职做自动化的岗位不行啊?工资起码比现在功能测试高吧!行行行!学习当然行。但方法要正确。我稍后再说正确学习自动化测试的姿势。(左手右手一个慢动作…)但,其实我想告诉你,对于测试来说,理论上你掌握一个单一的技能是远远不能走上人生巅峰的。

再说另一种声音,这个情况一般是我们对自动化测试的期望太高了。自动化嘛,不就应该自动化脚本写好,自动化脚本刷刷的跑。然后,喝杯茶的功夫,bug就找到了。要真这么美好,这得有多少功能测试人员得转行去搬砖了。一般造成这个认识的,主要两方面原因,技能不够,有些只依赖于各种自动化测试工具,有些一只能写写简单的模拟用户操作的脚本。第二个原因,不管三七二十一上来就拿自己所测试的项目开刀。这元素咋定位?这功能怎么写断言?我靠,脚本运行又出错了。你有分析你的项目是否适合做自动化了么?看到有些同学拿着只能在IE下运行的某XXX项目,艰难的定位着元素,赶紧放弃吧!!

如果对软件测试有兴趣,想了解更多的测试知识,解决测试问题,以及入门指导,帮你解决测试中遇到的困惑,我们这里有技术高手。如果你正在找工作或者刚刚学校出来,又或者已经工作但是经常觉得难点很多,觉得自己测试方面学的不够精想要继续学习的,想转行怕学不会的, 都可以加入我们1079636098,群内可领取最新软件测试大厂面试资料和Python自动化、接口、框架搭建学习资料!

学习的两点建议

你别BB了,你都大神了,你当然鄙视我们这些新手,你当然站着说话不腰疼。那要不,你说自动化测试咋学?你给个方法。自动化方面的资料挺多的了。我给两点建议。

不要迷恋自动化工具,学好开发语言。这一点我个人感受很深,理论上不管你写的是单元测试自动化,接口测试自动化,还是web测试自动化,都属于开发的行为,只是带着测试的思维在写测试代码而已。你说,如果开发能力只停留在稍微能看懂,让你实现个简单的功能就大脑一片空白的水平肯定不行。代码要多写,写得多了,自然思想就来了,代码结构的设计能力也来的。不过,这是需要半年一年才能出效果。那我该学哪个语言呢?目前主流的哪个都行,你们开发用Java,你就可以学Java,你们开发用Python,你就可以学Python。

我要学自动化技术,你让我学编程语言,我要能把语言学好,我当开发去算了。那你还想不想走向人生巅峰了?只有跨过编程能力这道坎才有希望。(当然,不走技术流的另说。)

当你把编程学好,知道功能是如何开发出来的。很多测试的问题自然就通了。如何单元测试怎么写,接口测试怎么做等。

另外一点建议就是专一!专一!专一!重要的事情说三遍,如果,你经常混测试群的话,就会被各种测试技术工具吸引,今天大家讨论性能测试很火啊,貌似职位工资很高。要不找点资料学学。过段时间又发现,现在移动自动化测试是方向,应该学习一下。所以,不专一是你最大的敌人,等到面试的时候。看着简历上写了满满的技能,每个多问两句就…

那有什么办法呢?人家公司要求的必须会这些,你能不学一下?那你能把眼光放高点对标一下BAT的招聘信息么?将来是要走向人生巅峰的人,怎么只能把眼光放在那些二流的公司上面,这些公司,本来就招个功能测试,还非要求“精通LoadRunner、QTP等自动化工具”。

从你的技术博客来看,你也不专一啊!今天更新这个技术,明天介绍点那个技能。我是有学习主线的好么?博客的更新都是我学习总结的一小部分。从大的主线来看,我近三年来重点提升的就是编程能力和自动化相关技能。
  
如果对软件测试有兴趣,想了解更多的测试知识,解决测试问题,以及入门指导,帮你解决测试中遇到的困惑,我们这里有技术高手。如果你正在找工作或者刚刚学校出来,又或者已经工作但是经常觉得难点很多,觉得自己测试方面学的不够精想要继续学习的,想转行怕学不会的, 都可以加入我们1079636098,群内可领取最新软件测试大厂面试资料和Python自动化、接口、框架搭建学习资料!

本来想讲自动化测试认识的一些具体误区,结果扯了这么多,剩下的放在下一篇了。

继续胡说(我真姓‘胡’啊!)对自动化测试的一些看法,上一篇文章讲得比较模糊,这一篇就具体讲讲在做自动化测试时的一些误区,主要针对已经在开始学习自动化的同学。当然,我这里主要指的是webUI自动化以及使用selenium工具的情况下。

数据驱动怎么玩?

数据驱动:因为数据的改变导致结果的改变。说人话就是,因为我在百度里搜索的是“selenium”导致结果就是包含了“seleniumhq.org”。因为我登录时候输入的是“zhangsan”导致的结果就是登录之后页面右上角显示“欢迎,zhangsan”。你自己体会一下,我说的也不一定对。

曾几何时,不知哪位测试大牛说的,数据一定要放在excel表格里才逼格满满。再后来就演变成元素的定位一定要放到excel里才够“数据驱动”,才是玩自动化测试的高级境界。在这里插入图片描述
 抱歉,可能我姿势不对!因为我不知道你们是如何想像着把元素定位放到excel表格里面的。

但我认为这样做纯属多此一举。

1、读excel有多麻烦,你知道么?不知道的百度一下,“python读取excel ” 或 “java 读取excel”。你想像一下,每个用例的每一步元素定位之前,先读一下excel是有多麻烦。

2、这样好维护!谁告诉你的?你能记清excel第125行第2列对应的哪个页面上的哪个元素的定位?因某个页面上多加一个元素,我又在excel第32行下面插入一行元素定位,从33行往的所有元素的行号都变了,你那些读取excel中元素定位的操作都要跟着改吧!?

那你给说道说道,什么情况下需要excel管理用例,在我看还真没想到什么场景必须excel管理。不过,有什么条件可以参考:

1、这个数据有点多,比如这个输入框限制500字,我输入501个字提交看是否会提示错误。这500字写代码里有点多了。可以建立个文件读取。

2、这个数据经常改动,比如自动化测试用例通过个哪个环境执行,哪款浏览器运行,运行哪个项目下的用例。这个配置是需要我经常改的,可以创建一个专门的配置文件来保存。

3、这个数据作用于多个地方,比如系统的登录用户名密码,可能很多条测试用例都用一个账号登录。那我不可能每个用例,都写一遍这个账号,假如想统一更换帐号还得每个用例都改一下,这个时候也可以对这个数据独立保存。

你看!你看!元素的定位也挺符合你的第2、3条的,经常变动,一个元素定位可能被多个用例用到。那你为什么不研究一个Page Ojbect 设计模式?专门解决元素变化问题的。

web自动化要用多大的数据?

对了,前两天有人给我留言:你这个web自动化书吧挺好的(书在本博客面右上!),就是没有关于数据库的操作!亲,你不是在做web自动化,应该是在做性能自动化吧!?那我要碰到很多数据的情况下怎么存?这一定是你意淫出来的情况。那我在页面上插入了一条数据,我需要查询数据库表检查对不对呀?

你确定你是在做web自动化么?web自动化是基于UI的自动化测试,是模拟用户操作的。你家用户这么高端,在你们的网站上买了个商品,还要跑到你家数据库里去查一查,刚才买的商品有没有写到xxx表里?

那自动化怎么知道商品对没有没插入到xxx表?那我反问一下用户怎么知道自己有没有购买成功,一定是他在“已购买”的商品栏里看到自己的商品。你不会获取这信息做断言啊?

说往数据库里存数据那位,你家用户在使用你们的系统的时候,自己要先准备几千条数呀?你说用户用excel存数据我信,你说用户上传excel数据文件我信,你说用户弄个数据库存几千数据,我不信!

这样的系统不太适合web自动化!

什么样的系统不太适合web自动化?以查询报表为主的系统,就是以插入,查询,删除,编辑为主的xx管理系统。如查你还不清楚的话,下图仅供参考。在这里插入图片描述
  我此言一出,估计你要灰心了!我家系统就是这种的,添加,查询,编辑。这种系统一般定位起来也比较麻烦,要写又臭又长的xpath。(估计你现在已经和我产生共鸣了。)

这种系统的核心就是数据,其后台实现就是各种查询接口。功能可用就好,一般这系统不讲究用户体验之类的。关键是数据得正确。尤其是针对金融领域相关的系统,那少算一个数、一个零、一个小数点,事可就大了。但在我看来做web自动化的实际意义并不大。或者这类系统要自动化的并不是系统最重要的部分。当然,我并不是说系统的功能不重要。

最主要的是这种系统不太好断言结果,你想,你的数据是查询出来的,今天查询出来“张三”在第一页,后面这个查询数据增加,“张三”跑后第五页了,再后来跑到第170页,你说怎么用固定的信息断言? 没有断言,你怎么知道查询的结果对不对?

我可以查数据库呀,我前面说了,查数据库的就不是web自动化了。

其实,这类系统非常适合做接口自动化测试。关于,接口自动化的学习和需要掌握的技能,我会放到下一篇介绍(这一篇要还没啥阅读量,我就不写了_,毕竟这些吐槽也挺无聊的)。

有同学说了,那我学自动化还有什么用?我家系统就是这种的。

1、首先,我并不是说这类系统不能自动化,拿来练习web自动化还是可以的嘛。再说了,web自动化也是测试人员必备技能之一嘛,以后为你跳槽加薪好处也是大大地嘛。

2、你学习的技能并没有白费:

2.1、编程能力提升了吧!那编程语言能干的事情可以多了去了。

2.2、单元测试框架学会了吧!这框架还可以用来写单元测试和接口测试呢!

2.3、自动化测试的思想学到了吧!移动自动化也是这么玩的,只是把selenium换成appium而已。

如果对软件测试有兴趣,想了解更多的测试知识,解决测试问题,以及入门指导,帮你解决测试中遇到的困惑,我们这里有技术高手。如果你正在找工作或者刚刚学校出来,又或者已经工作但是经常觉得难点很多,觉得自己测试方面学的不够精想要继续学习的,想转行怕学不会的, 都可以加入我们1079636098,群内可领取最新软件测试大厂面试资料和Python自动化、接口、框架搭建学习资料!
在这里插入图片描述

<think>好的,用户之前问过产品测试岗位需要掌握的知识提升路径,现在又接着问自动化测试工具的学习。看来他对测试领域有持续的兴趣,特别是想深入自动化测试部分。首先,我需要确定用户的需求层次。他可能已经了解了基础,现在想具体学习工具,所以需要详细的指导。 用户可能是刚入行的测试人员,或者有一定经验想转向自动化测试。不管怎样,他需要明确的学习路线工具推荐。我需要分步骤介绍,从基础到进阶,涵盖不同的测试类型,比如Web、移动端、API、性能测试等,这样他能全面了解。 还要考虑不同工具的特点适用场景,比如Selenium适合Web,Appium适合移动端,PostmanJMeter分别用于API性能测试。同时,要强调编程语言的重要性,比如PythonJava,因为很多工具需要编程基础。 用户可能对如何开始学习感到困惑,所以需要推荐学习资源,比如官方文档、实战项目社区支持。此外,提供学习路径,分阶段从入门到精通,帮助他规划学习步骤。 另外,用户可能关心未来的趋势,比如AI在测试中的应用或者持续测试,所以加入新兴工具持续学习建议会更好。提醒他持续学习的重要性,并参与社区交流,保持技术更新。 需要避免使用专业术语过多,保持解释清晰易懂,结构分明。确保每个工具都有简要说明、学习重点示例,帮助用户理解如何应用。最后,总结关键点,强化他的学习信心,并鼓励实践项目经验积累。</think>#### 自动化测试工具学习指南 自动化测试工具学习需围绕 **工具选型→技术栈匹配→实战应用** 展开,以下是系统性学习路径: --- ### 一、核心工具分类与选型逻辑 | **测试类型** | **主流工具** | **适用场景** | |-----------------|---------------------------|--------------------------------| | **Web UI测试** | Selenium/Cypress/PlayWright | 浏览器兼容性测试、页面交互验证 | | **移动端测试** | Appium/Espresso/XCUITest | Android/iOS应用功能与性能测试 | | **API测试** | Postman/SoapUI/RestAssured | 接口功能验证、数据契约测试 | | **性能测试** | JMeter/LoadRunner/k6 | 高并发压测、系统瓶颈定位 | | **持续测试** | Jenkins/GitLab CI | 自动化流水线集成、测试任务调度 | **选型原则**: - 团队技术栈匹配(Java系选TestNG+RestAssured,Python系选Pytest+Requests) - 社区活跃度(GitHub Star数>10k优先) - 企业招聘需求(国内常用Selenium+Appium+JMeter组合) --- ### 二、技术栈能力构建 #### 1. **编程语言基础** - **Python**(推荐):语法简洁,生态丰富 ```python # Selenium示例 from selenium import webdriver driver = webdriver.Chrome() driver.get("https://www.baidu.com") assert "百度" in driver.title ``` - **Java**:企业级框架支持更完善 ```java // TestNG示例 @Test public void testLogin() { WebDriver driver = new ChromeDriver(); driver.get("https://example.com"); Assert.assertTrue(driver.getTitle().contains("Home")); } ``` #### 2. **工具深度掌握** - **Selenium**: - 掌握WebDriver原理(浏览器驱动通信) - 元素定位策略(XPath/CSS Selector优化) - 显式等待与隐式等待的区别 $$ \text{元素定位成功率} = 1 - \frac{\text{定位失败次数}}{\text{总操作次数}} $$ - **Appium**: - 理解ADB(Android Debug Bridge)指令 - 混合应用测试(WebView上下文切换) - Desired Capabilities配置(设备型号/系统版本) - **Postman**: - 脚本化测试(Pre-request Script/Test Script) - 环境变量与数据驱动(CSV/JSON文件导入) - Newman命令行执行 #### 3. **框架设计能力** - **分层架构**: ``` 测试数据层(Excel/YAML) → 核心逻辑层(Page Object模式) → 执行控制层(Pytest插件/TestNG.xml) ``` - **持续集成**: - Jenkins Pipeline脚本编写(并行测试任务配置) - Allure测试报告生成与可视化分析 --- ### 三、实战学习路径 #### 阶段1:工具基础(2-4周) 1. 完成Selenium官方文档的定位与操作练习 2. 使用Postman手动创建10个API测试用例 3. 在JMeter中实现HTTP请求压测(线程组+监听器配置) #### 阶段2:框架搭建(4-8周) 1. 使用Pytest+Allure构建Web自动化框架 ```python # 数据驱动示例 @pytest.mark.parametrize("username,password", [("admin", "123"), ("test", "456")]) def test_login(username, password): login_page.input_credentials(username, password) assert home_page.is_displayed() ``` 2. 实现Appium移动端多设备并行测试(Selenium Grid扩展) #### 阶段3:高阶应用(持续提升) 1. **精准测试**:覆盖率统计(JaCoCo/Cobertura) 2. **AI测试**:使用TensorFlow识别图像验证码 3. **混沌测试**:Chaos Monkey模拟服务器故障 --- ### 四、学习资源推荐 | **资源类型** | **推荐内容** | |------------|----------------------------------------| | 官方文档 | Selenium Docs / Appium GitHub Wiki | | 实战项目 | GitHub搜索「automation-framework」 | | 在线课程 | Udemy《Selenium WebDriver with Python》 | | 社区支持 | StackOverflow/TestAutomationU社区 | --- ### 五、避坑指南 1. **避免盲目追求新技术**:优先掌握企业主流工具链(如国内更倾向Selenium而非Cypress) 2. **性能测试误区**:TPS≠线程数,需理解 **Little's Law**: $$ \text{并发用户数} = \text{平均响应时间} \times \text{吞吐量} $$ 3. **移动端测试陷阱**:真机测试覆盖率需>80%,模拟器无法完全替代设备碎片化问题 --- ### 六、未来趋势 1. **低代码测试**:Katalon Studio/Tricentis Tosca 2. **智能断言**:基于Diffy的自动化结果验证 3. **云化测试**:Sauce Labs/BrowserStack云端设备农场 **建议**:每周投入10小时系统性学习,通过实际项目(如电商网站全流程测试)巩固技能,参与开源项目贡献(如Apache JMeter插件开发)提升工程能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值