都2023年了,Python 和Java 哪个更适合做自动化测试?_自动化运维使用java还是python好-程序员宅基地

技术标签: 经验分享  python  自动化测试  java  软件测试  职场和发展  

大家好。从事软件测试很多年了,从各个大厂一路摸爬滚打,现在我有幸供职于字节跳动。个人也是从功能测试慢慢爬到了自动化测试这条路上。所以针对这个问题,我还有点发言权。

记得我一开始从功能准备转型到自动化测试,和很多“涉事未深”的同学一样,也面临首选语言的选择性障碍。在询问行业大佬到底是选Python还是Java时,基本能得到的答案无外乎:“你想干啥”,“你会啥”,“你想怎么做” 。

后来自以为想清楚了这三个问题,大佬们却像范大将军似的一顿训:“哎,谢天谢地,实用主义点,我劝你们,先弄明白自己的本职工作,把自动化的这个理念先搞懂。你测试基础不牢固,技术栈又不熟,一说全会,一做全废。连普通功能点都评估不好,到时候你问我要怎么写?”

带着这些问题,我以懵懂的心,才由深入浅的把这个“首选语言”搞明白。

软件产品自动化测试流程图

要想说透冰山上“自动化首选语言”这个表层问题,其实我们应该钻到冰山下,去了解另外两个问题:1、测试为什么要使用自动化,2、目前企业主流上是使用什么方法来实现自动化。了解了冰山下的2个问题,再来聊冰山上的问题,就能由深入浅知道答案了..

所以分享内容会稍长,我接下来的文章主题结构,就围绕这3个问题展开:

1)为什么要使用自动化测试?
2)目前企业主流上是使用什么方法来实现自动化测试
3)Python 和Java 哪个更适合做自动化测试?

好,文章正式开始....


一、软件测试为什么要使用自动化?

在回答这个问题之前,我们要先把自动化的理念搞清楚!

1、什么是自动化测试?

所谓自动化测试,指的是使用独立于待测软件的其他软件,来自动执行测试、比较实际结果与预期并生成测试报告这一过程。

在测试流程已经确定后, 测试自动化可以自动执行的一些重复但必要测试工作。也可以完成手动测试几乎不可能完成的测试。对于持续交付和持续集成的开发方式而言, 测试自动化是至关重要的

2、为什么测试工作要使用自动化?

自动化测试的工作原理其实本身粗略的讲就是代替手工测试,但究竟代替的是什么?

我们以传统手工测试举例,我们写一条case有前置,有步骤,有预期结果,然后人工操作,将实际结果同预期结果比对。

而自动化则是由计算机来代替我们将自动比对预期结果和实际结果的过程。

我们拿计算器举例子:

[暂不支持下载该格式的图片]

我们去计算加法,1+1=2

手工:a输入1 b输入1 预期结果为2 执行后 2=2 测试通过

程序:a=1 b=1 判断:2==a+b 执行后 2=2 测试通过

恭喜你!现在你拥有一个仅仅能计算1+1=2正确的计算器!但凡换一种你都不能保证它对!

于是有一天机缘巧合的把a=1改成a=2 这个时候执行结果 判断: 2==a+b 执行后 2==3 测试不通过

于是我们引入了参数化的概念。

a,b,c 加法时对应 第一组:1,1,2 现在 a=1 b=1 c=2 判断:c==a+b 执行后 2=2 测试通过

这个时候我们通过手工测试的基础,我们考虑我们的测试点,从传统手工测试角度出发,我们通过等价类划分,将数字分为,整形,浮点型,0。再根据边界值划分为比如最长就到3位也就是结果=999

这样来我们将更改我们的测试参数

第2组1.1 ,1.2 ,2.3 将参数 带入a+b=c中 执行 c==a+b c==2.3 执行后2.3==2.3 测试通过

第3组1,0,1 将参数 带入a+b=c中 执行 c==a+b c==1 执行后1==1 测试通过

第4组100,200,300 将参数 带入a+b=c中 执行 c==a+b c==300 执行后300==300 测试通过

上面都是正常的场景,现在来一些异常的场景,在原有的基础上进行划分

细化分第2组数据让两个浮点数相加往前进一位 1.89,1.33,3.22 将参数 带入a+b=c中 执行 c==a+b c==3.22 执行后3.3.2199999999999998==3.22 测试不通过 这个时候就造成了精度问题可以让研发进行修复,如保留2位小数。

当然我么还可以细化分第4组数据让它超出边界值999,1,超出边界,结合第2组细分和第4组细分既是浮点型,又让它结果超出边界 555.55,444.55,超出边界 等加减乘除的运算都验证一遍,通过参数输入,计算机输出,结果比对。从而得到一个加法的自动化用例集,在此基础上我们还可以有其他运算的用例集。

以上这就是最原始的一种测试方式。无论你是测试接口还是Web端,移动端,UI,归根结底,请求方后,返回值同预期值做比较。所以每种语言几乎都可以进行自动化测试。

既然每种语言几乎都可以进行自动化测试,Python 和Java 哪个更适合做自动化测试?

我们以程序员第一句话 Hello World!为例:

1. 这是java的HelloWorld:

public class HelloWorld {
 public static void main(String args[]) {
 System.out.println("Hello World!");
 }
}

2. 这是python的HelloWorld

print("HelloWorld!")

python 语言比较简洁,开发起来比较快。 java 语言也很简洁,但相对 python 而言比较复杂。很明显python的简洁不是浪得虚名。

二、目前企业主流上是使用什么方法来实现自动化测试

随着业务不断的积累,case逐渐增加,人员不断调整,我们无法草率的删除过往的case。

但也做不到上线一个够简单,够独立的功能,但每次执行自动化会回归全部case的痛点。

于是千呼万唤始出来了测试框架。

测试框架使得自动化测试,更便于实施处理自动化测试脚本,本身的存在的问题:如异常处理和场景恢复,弥补测试脚本本身的不足或是特殊测试需求,测试易于维护。

自动化测试框架的接口模型图

1、Java常听说的测试框架

1 ) JUnit

Junit可以让您为Java代码编写出相应的单元测试程序。您可以将JUnit用于单元与集成测试,它还能够支持Java 8的各种功能。

2 ) REST Assured

在Java中测试和验证各种REST服务,Java领域带来了语言上的简便性。它是一种十分优秀的REST API集成测试工具。

3 ) Selenium

Selenium应该是Java UI测试中最为普遍的工具了,它允许您测试JSP页面,甚至允许您去编写Web应用,以验收各种测试。

4 ) TestNG

TestNG是一种由JUnit和NUnit发展而来的测试框架,不过它引入了许多新的功能,如:annotations可以在任意大的线程池中,运行各种可用策略的测试,可以弥补JUnit和TestNG之间的差距。

2、python常见的测试框架:

1)Unittest

unittest 的一个很有用的特性是 setUp() 和 tearDown() 方法,它们提供了为测试进行准备和扫尾工作的功能,这种功能很适合用在测试对象需要复杂执行环境的情况下。当类里面定义了 setUp() 方法的时候,测试程序会在执行每条测试项前先调用此方法;同样地,在全部测试项执行完毕后,tearDown() 方法也会被调用。

2) Pytest

目前行业内常用的就是Pytest,Pytest简单灵活,容易上手,支持参数化。
能够支持简单的单元测试和复杂的功能测试,还可以用来做Selenium/Appnium等自动化测试、接口自动化测试(Pytest+Requests),Pytest具有很多第三方插件,并且可以自定义扩展。

3、企业是怎么选择的呢?

我不说也许你不知道,其实。。。。使用JavaScript或者jQuery也可以写一些简单的自动化脚本~

但很多大厂都是Java开发的,对于自动化测试开发工具多数也会使用Java语言,这样更容易沟通,思想兼容。同时面向移动端自动化对掌握Java语言工具的测试工程师来讲,Java也非常对口!

当然很多大厂包括一些中小型企业,创业团队也会使用Python进行测试。
用Python+Pytest自动化测试;
用Python+Selenium:搞定UI自动化测试,兼容性测试;
用Python Request:搞定接口测试;
用Python Locust,搞定性能测试;
用Python Scapy:搞定安全性能测试;
通过Python+mysql+Django/Flask搭建公司自己使用的自动化测试平台。

对于移动端我所在的公司字节跳动为例,我们会使用自研Shoots方案来做全平台自动化测试,也会通过Airtest做移动端跨平台的UI自动化测试框架(适用于游戏和App)而这些都是基于Python语言开发的。
在数据驱动测试的情况下,在一些临时项目,或者短期任务中,我们也常用Python这种胶水语言去写一些脚本,生成测试数据,辅助测试任务,降低人力成本。

三、Python 和Java 哪个更适合做自动化测试?

1、先来说说Python

Python没有很复杂的结构,前期准备也少,对人员的专项素质要求并不高,对电脑配置也没有很高的要求,对于未经过计算机专业培训的同学来说入门唾手可及。

尤其是Pytest框架,它的扩展也比较好:
如Pytest-selenium(集成selenium)、
Pytest-html(完美html测试报告生成)、
Pytest-rerunfailures(失败case重复执行)、
Pytest-xdist(多CPU分发)等测试用例的skip和xfail处理,可以很好和jenkins集成,
当然report框架----allure 也支持了Pytest。
最终你将会获得一份测试报告如Jenkins展示图:

总结:对测试工程师而言,Python 简单易学,庞大的充沛的生态,对现有的自动化测试框架相对完善且好用(比如 selenium,appium 等等),测试可以在框架上简易地开发,可以定制化测试环境。

2、再来说说JAVA

Java 虽然也能做自动化测试,但相对 Python 而言并不是那么好学。但如果测试工程师想在框架上进行简易的开发,做测试开发工作,那就必须掌握 Java 语言,需要学习更多的东西。

3、分享下我的真诚建议

Python和Java说到底是一种开发工具,一种语言,他们思想是互通的。

我们追求的本质是提高测试效率,提高测试质量,降低测试成本,降低维护成本。

语言本身无好坏。如何挑选?

要去挑你熟悉的或者周边儿大家都在用的,这样资源更具有优势。因为资源越丰富学习起来的成本越低,毕竟我们不是在一个封闭的环境闷声学技术。

可以从Python入门,等有些基础以后也可以选择,再往Java上面去靠,学习更多的计算机原理。

有基础的好上手,没基础的好入门,就目前Python对于测试来讲足够了。


四、写在最后

注重学习思路,测试基础的沉淀,测试策略及测试思路的培养对自动化测试更是事半功倍。等工作的时候基本都封装了一套自己的测试架构,大家更在乎的是使用xxxx的技术方案探讨和实践哦~~


最后: 为了回馈铁杆粉丝们,我给大家整理了完整的软件测试视频学习教程,朋友们如果需要可以自行免费领取 【保证100%免费】

资料获取方式 :

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_58026506/article/details/131022710

智能推荐

BAT批处理创建文件桌面快捷方式_批处理创建桌面快捷方式-程序员宅基地

文章浏览阅读1.5w次,点赞9次,收藏26次。简介一个创建某个文件到桌面快捷方式的BAT批处理.代码@echooff::设置程序或文件的完整路径(必选)setProgram=D:\Program Files (x86)\格式工厂.4.2.0\FormatFactory.exe::设置快捷方式名称(必选)setLnkName=格式工厂v4.2.0::设置程序的工作路径,一般为程序主目录,此项若留空,脚本将..._批处理创建桌面快捷方式

射频识别技术漫谈(6-10)_芯片 ttf模式-程序员宅基地

文章浏览阅读2k次。射频识别技术漫谈(6-10),概述RFID的通讯协议;射频ID卡的原理与实现,数据的传输与解码;介绍动物标签属性与数据传输;RFID识别号的变化等_芯片 ttf模式

Python 项目实战 —— 手把手教你使用 Django 框架实现支付宝付款_django 对接支付宝接口流程-程序员宅基地

文章浏览阅读1.1k次。今天小编心血来潮,为大家带来一个很有趣的项目,那就是使用 Python web 框架 Django 来实现支付宝支付,废话不多说,一起来看看如何实现吧。_django 对接支付宝接口流程

Zabbix 5.0 LTS在清理历史数据后最新数据不更新_zabbix问题没有更新-程序员宅基地

文章浏览阅读842次。Zabbix 5.0 LTS,跑了一年多了一直很稳定,前两天空间显示快满了,于是手贱清理了一下history_uint表(使用mysql truncate),结果折腾了一周。大概故障如下:然后zabbix论坛、各种群问了好久都没解决,最后自己一番折腾似乎搞定了。初步怀疑,应该是由于历史数据被清空后,zabbix需要去处理数据,但是数据量太大,跑不过来,所以来不及更新了(?)..._zabbix问题没有更新

python学习历程_基础知识(2day)-程序员宅基地

文章浏览阅读296次。一、数据结构之字典 key-value

mybatis-plus字段策略注解strategy_mybatisplus strategy-程序员宅基地

文章浏览阅读9.7k次,点赞3次,收藏13次。最近项目中遇到一个问题,是关于mybatis-plus的字段注解策略,记录一下。1问题调用了A组件(基础组件),来更新自身组件的数据,发现自己组件有个字段总是被清空。2原因分析调用的A组件的字段,属于基础字段,自己业务组件,对这个基础字段做了扩展,增加了业务字段。但是在自己的组件中的实体注解上,有一个注解使用错误。mybatis-plus封装的updateById方法,如果..._mybatisplus strategy

随便推点

信息检索笔记-索引构建_为某一文档及集构件词项索引时,可使用哪些索引构建方法-程序员宅基地

文章浏览阅读3.8k次。如何构建倒排索引,我们将这个过程叫做“索引构建”。如果我们的文档很多,这样索引就一次性装不下内存,该如何构建。硬件的限制 我们知道ram读写是随机的操作,只要输入相应的地址单元就能瞬间将数据读出来或者写进去。但是磁盘不行,磁盘必须有一个寻道的过程,外加一个旋转时间。那么只有涉及到磁盘,我们就可以考虑怎么节省I/O操作时间。【注】操作系统往往以数据块为单位进行读写。因为读一_为某一文档及集构件词项索引时,可使用哪些索引构建方法

IT巨头英特尔看好中国市场前景-程序员宅基地

文章浏览阅读836次。英特尔技术与制造事业部副总裁卞成刚7日在财富论坛间隙接受中新社记者采访时表示,该公司看好中国市场前景,扎根中国并以此走向世界是目前最重要的战略之一。卞成刚说,目前该公司正面临战略转型,即从传统PC服务领域扩展至所有智能设施领域,特别是移动终端。而中国目前正引领全球手机市场,预计未来手机、平板电脑等方面的发明创新将大量在中国市场涌现,并推向全球。持相同态度的还有英特尔中国区执行董事戈峻。戈峻

ceph中的radosgw相关总结_radosgw -c-程序员宅基地

文章浏览阅读627次。https://blog.csdn.net/zrs19800702/article/details/53101213http://blog.csdn.net/lzw06061139/article/details/51445311https://my.oschina.net/linuxhunter/blog/654080rgw 概述Ceph 通过radosgw提供RES..._radosgw -c

前端数据可视化ECharts使用指南——制作时间序列数据的可视化曲线_echarts 时间序列-程序员宅基地

文章浏览阅读3.7k次,点赞6次,收藏9次。我为什么选择ECharts ? 本周学校课程设计,原本随机佛系选了一个51单片机来做音乐播放器,结果在粗略玩了CN-DBpedia两天后才回过神,课设还没有开始整。于是懒癌发作,碍于身上还有比赛的作品没交,本菜鸡对硬件也没啥天赋,所以就直接把题目切换成软件方面的题目。写python的同学选择了一个时间序列数据的可视化曲线程序设计题目,果真python在数据可视化这一点性能很优秀。..._echarts 时间序列

ApplicationEventPublisherAware事件发布-程序员宅基地

文章浏览阅读1.6k次。事件类:/** * *   * @className: EarlyWarnPublishEvent *   * @description:数据风险预警发布事件 *   * @param: *   * @return: *   * @throws: *   * @author: lizz *   * @date: 2020/05/06 15:31 * */public cl..._applicationeventpublisheraware

自定义View实现仿朋友圈的图片查看器,缩放、双击、移动、回弹、下滑退出及动画等_imageview图片边界回弹-程序员宅基地

文章浏览阅读1.2k次。如需转载请注明出处!点击小图片转到图片查看的页面在Android开发中很常用到,抱着学习和分享的心态,在这里写下自己自定义的一个ImageView,可以实现类似微信朋友圈中查看图片的功能和效果。主要功能需求:1.缩放限制:自由缩放,有最大和最小的缩放限制 2居中显示:.若图片没充满整个ImageView,则缩放过程将图片居中 3.双击缩放:根据当前缩放的状态,双击放大两倍或缩小到原来 4.单指_imageview图片边界回弹