7个超好用的测试框架(总有一款适合你)

 🔥 交流讨论:欢迎加入我们一起学习!

🔥 资源分享耗时200+小时精选的「软件测试」资料包

🔥 教程推荐:火遍全网的《软件测试》教程  

📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!

昨天吃饭的时候和同事聊到测试框架,于是决定根据自己的实战工作经验总结一波好用的测试框架。本来文章里一共11个的,最后想想还是剔除掉了Maxim、Cypress、Gauge和ZTF(Zentao Testing Framework)。

工具在精而不在多,毕竟还是得以我们测试工程师平常用的最多的为基准。

另外,当你学习一个新的工具时,建议你直接看官方文档。(以下工具的官网链接,我都帮大家列出来了)

虽然官网常常是英文的,但是它也是最权威、最官方的。百度直接查的话,有的文章常常有错误,或者说文中所说内容已经过时了,小白很容易被误导。而且程序员难免要接触英文,当你习惯看官方文档后,你会发现自己的英文水平也在不知不觉间提高了。

好了,不说废话直接进入正文:

目录如下:

1、Junit
2、Selenium
3、TestNG
4、Cucumber
5、pytest
6、Appium
7、ATX

我们一个个来说:

一、Junit(白盒测试、API自动化、UI自动化)

【官网】

https://junit.org/junit5/

【简介】

Junit是一个面向Java编程语言的单元测试框架。

单元测试:针对最小的功能单元编写测试代码。Java程序最小的功能单元是方法,对Java编程语言进行单元测试,说白了就是对Java的方法进行测试。

用 Junit 编写单元测试的好处有:

非常简单地组织测试代码,并随时运行它们。
可以自动生成测试报告,收集成功的测试用例和失败的测试用例,统计测试成功率和代码覆盖率。
几乎所有的IDE工具都集成了Junit。
任何Java开发者都应当学习并使用Junit编写单元测试;同时,Java 技术栈的测试或者测试开发工程师,也可以学习 Junit 来作为自动化测试底层框架。

Junit目前最新版本是5。

【使用场景】

常用于单元测试(白盒测试)
自动化测试的用例管理和用例执行框架(API自动化、UI自动化)。
在这里插入图片描述

二、Selenium(Web自动化、爬虫)

【官网】

https://www.selenium.dev/

【简介】

Selenium 是使用最为广泛的 Web 自动化测试(UI自动化)框架之一。

Selenium 可以完全模拟用户对主流浏览器进行操作,主要包括鼠标事件和键盘事件。

鼠标事件:右击、双击、拖动、悬停。
键盘事件:Keys()类提供了键盘上几乎所有按键的方法,可以模拟各种键盘输入。
Selenium 支持八种元素定位方式:

id定位: find_element_by_id()
name定位: find_element_by_name()
class定位:find_element_by_class_name()
tag定位:find_element_by_tag_name()
link定位:find_element_by_link_text()
partial_link定位:find_element_by_partial_link_text()
xpath定位:find_element_by_xpath()
CSS定位:find_element_by_css_selector()
兼容性方面,Selenium 支持 Chrome、FireFox、Safari 等主流浏览器;

并且 Selenium 对 Java 和 Python 都提供了便捷的API调用。

【使用场景】

UI 自动化

爬虫
在这里插入图片描述

三、TestNG(白盒测试、API自动化、UI自动化)

【官网】

https://testng.org/doc/index.html

【简介】

TestNG 是 Java中一个很流行实用的单元测试框架。

它的灵感来源于 Junit ( java 的单元测试框架) 和 Nunit ( .net 的单元测试框架)。

但是它又在此基础上引入了新的东西,使得它更加强大。

关于注解特性方面,可以参考下表:
在这里插入图片描述
TestNG 和 JUnit 还有两个比较明显的区别:

在Junit 4 中,如果我们需要在方法前面使用 @BeforeClass 和 @AfterClass ,那么该测试方法则必须是静态方法。TestNG 在方法定义部分则更加的灵活,它不需要类似的约束。
TestNG 中子类不会运行父类中的 @BeforeClass 和 @AfterClass, 而在Junit中会先运行父类的@BeforeClass,再运行自己的 @BeforeClass;而 @AfterClass 是先运行自己的,再运行父类的。
经过一番对比之后,TestNG 在参数化测试、依赖测试以及套件测试(组)方面功能比 Junit 更加强大,并且包含了几乎 Junit 的所有功能,所以建议优先选择 TestNG。

【使用场景】

常用于单元测试(白盒测试)

自动化测试的用例管理和用例执行框架(API自动化、UI自动化)
在这里插入图片描述

四、Cucumber(API自动化、UI自动化)

【官网】

https://cucumber.io/

【简介】

自动化测试用例越写越多,也越来越难维护。

开发看不懂测试写的代码,测试也看不懂测试写的代码,那是因为代码不讲人话。

如何才能做到面向“注释”编程?BDD给出了答案。

BDD:Behavior-Driven Development ,也就是行为驱动开发。

BDD使用的叫做Gherkin的语言,它的理念是使用自然语言来描述功能,而且强调的是使用例子来说明需求功能。是不是跟敏捷开发中的用户故事(User Story)很像?嗯,因为它们都是一个妈生的。

使用这种方法可以让非技术人员、客户可以参与到需求的确认与验收当中。

以下是用 Cucumber 写出的 BDD 风格的测试用例 Demo :

// Given 前置(预置)条件。(一般用于定义一个变量等)
@Given("today is Sunday")  
public void today_is_Sunday() {
    // Write code here that turns the phrase above into concrete actions
    throw new io.cucumber.java.PendingException();
}

// When 当xxx的时候(相当于 if )
@When("I ask whether it's Friday yet") 
public void i_ask_whether_it_s_Friday_yet() {
    // Write code here that turns the phrase above into concrete actions
    throw new io.cucumber.java.PendingException();
}

// Then 那么将要做xxx操作。
@Then("I should be told {string}")
public void i_should_be_told(String string) {
    // Write code here that turns the phrase above into concrete actions
    throw new io.cucumber.java.PendingException();
}

就像讲故事一样,来梳理代码逻辑。

【使用场景】

自动化测试用例管理和用例执行(API自动化、UI自动化)。
在这里插入图片描述

五、pytest(白盒测试、API自动化、UI自动化)

【官网】

https://docs.pytest.org/en/6.2.x/

【简介】

pytest 是 python 语言中一款强大的单元测试框架(也是最好用的单元测试框架,不服来战),用来管理和组织测试用例,可应用在单元测试、自动化测试工作中。

当然,如果你是个 pythoner 的话,你可能也多多少少听说过 unittest。

其实论用途而言,pytest 和 unittest 用途不多,都是优秀的单元测试框架。

但是 pytest 在 unittest 的基础上,丰富了不少功能,而且比 unittest 更简洁高效,pytest + allure 还可以输出更加美观的测试报告,pytest在数据驱动上的支持,也是略优于unittest。

所以还是可以优先选择 pytest。

【使用场景】

常用于单元测试(白盒测试)
自动化测试的用例管理和用例执行框架(API自动化、UI自动化)。
在这里插入图片描述

六、Appium(移动端的UI自动化测试)

【官网】

http://appium.io/

【简介】

在移动端的 UI自动化 测试领域,带头大哥当属 Appium。

Appium 是基于 Nodejs 的一款 UI自动化 测试框架。

支持多平台(Android、iOS等)

支持多语言(python、java、ruby、js、c#等)

Appium是跨平台的,可以用在OSX,Windows以及Linux桌面系统上运行。
在这里插入图片描述
之前曾看过一则新闻,Appium 已经进军 AI 测试(基于AI查找控件)的领域了,不愧是龙头大哥。

【使用场景】

移动端的UI自动化测试
一般会结合单元测试框架去开发UI自动化测试框架。

Java:TestNG + Appium + Jenkins

Python:Pytest + Appium + Allure + Jenkins
在这里插入图片描述

七、ATX(移动端的UI自动化测试)

【官网】

https://github.com/NetEaseGame/ATX

【简介】

ATX(AutomatorX) 是一款(网易)开源的自动化测试工具,支持测试iOS平台和Android平台的原生应用、游戏、Web应用。

使用Python来编写测试用例,混合使用图像识别,控件定位技术来完成游戏的自动化。

附加专用的IDE来完成脚本的快速编写。

ATX的生态圈:

[底层驱动]

安卓(Android) https://github.com/openatx/uiautomator2 简称u2
苹果(iOS) https://github.com/openatx/facebook-wda
[元素定位]

Weditor https://github.com/openatx/weditor
[设备管理]

atxserver2 https://github.com/openatx/atxserver2

[测试框架]

ATX-Test pengchenglin/ATX-Test

【使用场景】

移动端的UI自动化测试
一般会结合单元测试框架去开发UI自动化测试框架。

Python:Pytest + uiautomator2/wda + Allure + Jenkins
在这里插入图片描述
以上7个测试框架,都是臻叔实际工作中最常用到的。如果你是刚入门测试的同学,可能看到这里会一头雾水。

没关系,你可以先大概了解下这些最常用的测试框架,之后臻叔也会陆续把我之前学习这些工具的笔记整理好,发出来供大家参考。

最后再小结一下:

1)Java的白盒测试、API自动化、UI自动化:

Junit(对Java的方法进行测试);
TestNG(相比Junit,参数化测试、依赖测试以及套件测试更好用,建议优先选这个);
2)python的白盒测试、API自动化、UI自动化:

pytest(功能更多,更简洁高效,优于unittest )。

3)API自动化、UI自动化:

Cucumber(面向“注释”编程)。

4)移动端的UI自动化测试:

Appium(基于 Nodejs,多平台多语言,OSX、Win和Linux上也能用 )
ATX(只支持iOS、Android)
5)UI自动化、爬虫:

Selenium(兼容性好,Web自动化必选)。

最后我邀请你进入我们的【软件测试学习交流群:785128166】, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路

作为一个软件测试的过来人,我想尽自己最大的努力,帮助每一个伙伴都能顺利找到工作。所以我整理了下面这份资源,现在免费分享给大家,有需要的小伙伴可以关注【公众号:程序员二黑】自提!

  • 17
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,我可以回答这个问题。React TS 项目框架可以使用 Create React App 来创建,然后在其中添加 TypeScript 支持。另外,可以使用 Redux 或 MobX 等状态管理库来管理应用程序的状态。还可以使用 React Router 来处理路由。此外,可以使用 Axios 或 Fetch 等库来处理数据请求。最后,可以使用 Jest 或 Enzyme 等测试库来编写测试用例。 ### 回答2: React TS项目框架可以基于现有的脚手架工具来创建,如Create React App(CRA)。 首先,我们需要安装Node.js和npm(Node Package Manager)。然后,在命令行中运行以下命令来创建一个新的React TS项目: ``` npx create-react-app my-app --template typescript ``` 这将在当前目录下创建一个名为my-app的新项目,并使用TypeScript模板。 接下来,进入my-app目录,并打开一个编辑器。在src目录下,可以看到一个名为index.tsx的文件,这是React组件的入口文件。我们可以在这个文件中开始编写我们的应用程序。 删除不需要的代码,并添加自己的组件和逻辑。可以使用JSX语法编写组件,并使用TypeScript来进行类型检查。在编写组件时,还可以使用React的钩子函数(Hooks)来管理组件状态和生命周期。 此外,还可以根据项目需求安装其他依赖项,如UI组件库、数据管理库等。可以使用npm或者yarn来安装这些依赖项,并在代码中按需引入和使用。 当准备好运行项目时,只需在命令行中运行以下命令: ``` npm start ``` 这将启动一个开发服务器,并在浏览器中打开一个新的标签页,显示你的应用程序。每当进行代码更改时,服务器会自动重新加载应用程序,以便立即看到更改效果。 在开发完成后,可以运行以下命令来构建应用程序的生产版本: ``` npm run build ``` 这将在build目录中生成一个优化过的、供生产环境使用的应用程序。 以上就是一个简单的React TS项目框架的创建过程。根据具体项目需求,可以继续定制和扩展框架,以满足开发需求。 ### 回答3: React是一个非常受欢迎的JavaScript库,用于构建用户界面。而TypeScript是一种强类型的JavaScript超集,它提供了更好的开发工具和编译时错误检查。结合React和TypeScript,可以创建更可靠、可维护和可扩展的项目。 以下是一个适用于React TypeScript项目的基本框架: 1. 安装项目依赖:首先,需要安装React和TypeScript的相关依赖。可以使用npm或yarn命令来安装,例如: ``` npx create-react-app my-app --template typescript ``` 这将创建一个新的React TypeScript项目。 2. 文件结构:创建一个适当的文件结构来组织你的代码。以下是一个示例文件结构: ``` - src - components:存放React组件 - pages:存放页面组件 - styles:存放样式文件 - utils:存放工具函数 - App.tsx:React应用的入口文件 - index.tsx:React渲染的入口文件 ``` 3. 编写组件:开始编写React组件。使用TypeScript的类型注解来定义组件的Props类型,并使用React的函数式组件或类组件来实现组件的逻辑。 4. 使用Hook:React提供了许多有用的Hook,如useState、useEffect等。它们可以在函数式组件中使用,并提供了更好的状态管理和生命周期管理。 5. 使用CSS模块化:使用CSS模块化来组织和管理你的样式文件。在TypeScript项目中,可以使用`.module.css`或`.module.scss`来定义模块化样式。 6. 添加路由:如果需要创建多页面应用,可以使用React Router添加路由功能。React Router提供了一个简单易用的API来实现页面之间的导航。 7. 使用Redux:如果需要全局状态管理,可以考虑使用Redux。Redux与React结合使用,可以更好地管理和共享应用程序的状态。 8. 运行项目:在项目根目录下运行`npm start`或`yarn start`命令来启动开发服务器,预览你的React TypeScript应用。 以上是一个简单的React TypeScript项目框架。根据具体的项目需求,你还可以添加更多的功能和工具库来提高开发效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值