欢迎来到皮皮网网首页

【php简易源码】【swift cache源码】【netModbus源码解析】unittest源码讲解

来源:打牌源码 时间:2024-12-28 17:20:30

1.常用的源码自动化测试工具有哪些
2.一文搞懂PythonUnittest测试方法执行顺序
3.python中unittest 单元测试调用没有调用到测试用例,新手求指点
4.Python热门单元测试框架对比:pytest和unittest还傻傻分不清楚?

unittest源码讲解

常用的讲解自动化测试工具有哪些

       1、Appium

       AppUI自动化测试

       Appium 是源码一个移动端自动化测试 开源工具,支持iOS 和Android 平台,讲解支持Python、源码Java 等语言,讲解php简易源码即同一套Java 或Python 脚本可以同时运行在iOS 和Android平台,源码Appium 是讲解一个C/S 架构,核心是源码一个 Web 服务器,它提供了一套 REST 的讲解接口。当收到客户端的源码连接后,就会监听到命令,讲解然后在移动设备上执行这些命令,源码最后将执行结果放在 HTTP 响应中返还给客户端。讲解

       2、源码Selenium

       WebUI自动化测试

       Selenium是一个用于Web应用程序测试的工具,Selenium已经成为Web自动化测试工程师的首选。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7、8、9)、Mozilla Firefox、Mozilla Suite等。这个工具的主要功能包括:测试与浏览器的兼容性——测试你的应用程序看是否能够很好得工作在不同浏览器和操作系统之上。测试系统功能——创建回归测试检验软件功能和用户需求。支持自动录制动作和自动生成 .Net、swift cache源码Java、Perl等不同语言的测试脚本。Selenium 是ThoughtWorks专门为Web应用程序编写的一个验收测试工具。其升级版本为Webdriver。

       3、Postman

       接口测试

       Postman 提供功能强大的 Web API 和 HTTP 请求的调试,它能够发送任何类型的HTTP 请求 (GET, POST, PUT, DELETE…),并且能附带任何数量的参数和 Headers。不仅如此,它还提供测试数据和环境配置数据的导入导出,付费的 Post Cloud 用户还能够创建自己的 Team Library 用来团队协作式的测试,并能够将自己的测试收藏夹和用例数据分享给团队。

       4.Robot Framework

       Robot Framework是一个开源自动化框架,它实现了用于验收测试和验收测试驱动开发(ATDD)的关键字驱动方法。 Robot Framework为不同的测试自动化需求提供框架。 但是,通过使用Python和Java实现其他测试库,可以进一步扩展其测试功能。 Selenium WebDriver是Robot Framework中常用的外部库。

       测试工程师可以利用Robot Framework作为自动化框架,不仅可以进行Web测试,还可以用于Android和iOS测试自动化。 对于熟悉关键字驱动测试的测试人员,可以轻松学习Robot Framework。

       5、Soapui

       接口测试

       SoapUI提供了所有所需的netModbus源码解析工具来测试和完善的测试。总览标签给你一个项目的所有内容和全面的看法。只需一次点击,您可以添加任何数量的断言为验证传入的消息TestStep。使用功能强大的HTTP监视器记录,分析甚至修改客户机 - 服务器通信,因为它发生。和SoapUI临带来了更专业和先进的功能,保持遥遥领先其他测试工具。轻松创建和运行数据驱动测试。该数据源TestStep读取测试数据从任何外部来源 - Excel中,XML,JDBC,文件,等等 - 到标准SoapUI属性。

       针对上面的自动化测试工具,每一个都有自己优势的功能,随着计算机行业的发展,自动化测试工具会越来越多,越来越完善。

一文搞懂PythonUnittest测试方法执行顺序

       Unittest

       unittest大家应该都不陌生。它作为一款博主在5-6年前最常用的单元测试框架,现在正被pytest,nose慢慢蚕食。

       渐渐地,看到大家更多的讨论的内容从unittest+HTMLTestRunner变为pytest+allure2等后起之秀。

       不禁感慨,chroot函数源码终究是自己落伍了,跟不上时代的大潮了。

回到主题

       感慨完了,回到正文。虽然unittest正在慢慢被放弃,但是它仍然是一款很全面的测试框架。

       今天在群里看到番茄卷王的一番言论,激起了我的一番回忆。

       自己以前是知道unittest的执行顺序并不是按照编写test方法的顺序执行,而是按照字典序执行的。但遗憾的是我都是投机取巧去解决的问题(后面会讲)。

       下面我们就来探讨下unittest类的test方法的执行顺序问题。

源码初窥

       研究一下源码(unittest.TestLoader)可以发现,在加载一个class下面的test方法的时候,原生Loader进行了排序,并且根据functools.cmp_to_key方法对测试方法列表进行了排序。

       我们知道,unittest是不需要我们指定对应的方法,说白了,它是从类里面自动获取到咱们的方法,并约定了以test开头的方法都会被视为测试方法。

       查询一下self.sortTestMethodsUsing(这个是一个排序的方式)。

       可以看到这个比较方法写的很明确了,如果x<y那么返回-1,x=y则返回0,x>y返回1。导出PLC源码

       其实大家可能不知道Python里面的字符串也是可以比较的,在此必须说明一下字典序。我们来看看这个例子:

a="abc"b="abcd"c="abce"print(a>b)print(b>c)

       猜猜看执行结果,很显然,字典序的比较,是按A-Z的顺序来比较的,如果前缀一样但长度不一样,那么长度长的那个,字典序靠后。

       了解了字典序以后,我们就不难知道,在unittest里面它寻找case的过程可以这样简化:

       找到对应类下面以test开头的测试方法

       对他们进行字典序排序

       依次执行

       这样就不难解释为什么我们有时候写的case不按照自己想的顺序来。

回到问题的本质

       搞清楚为什么用例会乱,那就想到对应的解决方案。由于修改源码是不太合适的,那我们有2个策略去达成目的。

       比如我有多个test方法:

classTestcase(unittest.TestCase):defsetUp(self)->None:passdeftest_1(self):print("执行第一个")deftest_2(self):print("第二个")deftest_3(self):print("第三个")deftest_(self):print("第四个")deftest_(self):print("第五个")deftearDown(self)->None:passif__name__=="__main__":unittest.main()

       执行起来,按照字典序,其实是的顺序。

1.以字典序的方式编写test方法

       我们可以手动修改test方法的名称,这也是我早前的处理方式。也就是说把想要先执行的case字典序排到前面:

classTestcase(unittest.TestCase):defsetUp(self)->None:passdeftest_0_1(self):print("执行第一个")deftest_0_2(self):print("第二个")deftest_0_3(self):print("第三个")deftest_1_0(self):print("第四个")deftest_1_1(self):print("第五个")deftearDown(self)->None:pass

       我们可以把数字按位数拆开,个位数就把位补0,这样就能达到效果,如果会写个case,我们就需要补2个0,比如0_0_1,当然一个文件里面也不会有太多case。

       如果遇到test_login这种怎么办呢,不是数字结尾的方法。

       其实是一样的,可以写成test_数字_业务的模式。番货写了一个装饰器专门解决这样的问题,大家可以去参考下。

2.回归本质,从根本解决问题

       方案1用了番货的装饰器,好是好,但是改变了方法本身的名称,我们其实可以针对他的排序方式入手,按照我们编写case的顺序排序测试方法,就能达到想要的目的。

       说说思路:

       手写一个loader继承自TestLoader类,改写里面的排序方法

       在unittest运行的时候传入这个新的loader

       来看看完整代码,注释里面写的很完善了。

importunittestclassMyTestLoader(unittest.TestLoader):defgetTestCaseNames(self,testcase_class):#调用父类的获取“测试方法”函数test_names=super().getTestCaseNames(testcase_class)#拿到测试方法listtestcase_methods=list(testcase_class.__dict__.keys())#根据list的索引对testcase_methods进行排序test_names.sort(key=testcase_methods.index)#返回测试方法名称returntest_namesclassTestcase(unittest.TestCase):defsetUp(self)->None:passdeftest_1(self):print("执行第一个")deftest_2(self):print("第二个")deftest_3(self):print("第三个")deftest_(self):print("第四个")deftest_(self):print("第五个")deftearDown(self)->None:passif__name__=="__main__":unittest.main(testLoader=MyTestLoader())

       执行了一下还是不对,是不是哪里出了什么问题呢?

       是因为pycharm有一种默认的unittest的调试方法,我们要改成普通的方法去执行。

       试试用控制台执行:

       作者:米洛

python中unittest 单元测试调用没有调用到测试用例,新手求指点

       没太明白你的意思,按你现在发出来的截图,print(b)确实只能打印<unittest.suite.TestSuitetests=XXXXXXX>,因为按你的代码,变量b接收到的是discover返回的数据,而discover返回的就是TestSuite的一个实例。

       你是想问test-baidu.py为啥没执行吗?因为没看到你的内部代码,我只能猜测:

       ① 确定下test-baidu.py中的测试类是否继承了unittest.TestCase,如果没继承,肯定执行不到

       ② 确定test-baidu.py中类的方法名(你编写的测试用例方法),是否以test开头,不按这个开头,而你的Python源码中也没改的话,不会被加载到测试套件里。

       ③确定文件夹中__init__.py中是否包含load_tests方法,如果有,discover也只会加载load_tests中加载的方法。

       话说,你的测试类文件名中为啥要用“-”,这个合适吗?

Python热门单元测试框架对比:pytest和unittest还傻傻分不清楚?

       前言

       在进行自动化测试时,编写测试用例会使用到单元测试模块,其中Python中常见的单元测试模块包括unittest、pytest、nose等。其中,unittest和pytest是被提及最多的两个框架,本文将通过简单介绍,对比这两者在断言、用例执行规则、前后置操作、测试报告、参数化功能、失败重跑、跳过用例等方面的主要区别。

       unittest

       unittest框架是Python内置的单元测试框架,广泛应用于各种项目中。它基于JUnit框架设计,支持多种自动化测试用例编写、前置条件和后置数据清理功能。unittest能将多个测试用例组织到测试集中,生成测试报告。

       pytest

       pytest是基于Python的单元测试框架,是对unittest的扩展,更加简洁、方便,支持第三方插件,可以高效完成测试工作。pytest也支持unittest的代码框架内容。

       区别

       从以下几个方面对比unittest和pytest的主要区别:

       断言

       unittest采用自身携带的断言函数,如assertEqual、assertTrue、assertFalse等。而pytest使用Python内置的assert语句进行断言。

       用例执行规则

       unittest要求测试类继承unittest.TestCase,测试用例以test开头,执行顺序按ASCII排序,不能指定特定用例顺序。unittest提供多种方法(如TestCase、TestSuite、TestLoder、TextTestRunner)来方便测试用例编写和执行。

       pytest则要求测试文件名以test_开头,类名以Test开头,测试用例同样以test_开头。执行顺序默认从上到下,可以通过第三方插件定制。执行用例无需导入模块,通过命令行即可执行。

       前后置操作

       unittest支持setup()和tearDown()方法控制用例前后置操作,setupclass()和teardownclass()方法控制类级别操作。pytest支持模块级别(setup_module,teardown_module)、函数级别(setup_function,teardown_function)等操作,通过fixture和装饰器灵活使用。

       测试报告

       unittest没有自带测试报告,需依赖第三方插件(如HTMLTestRunner、BeautifulReport)生成报告。pytest同样没有自带报告,可使用第三方插件(如pytest-html、allure-pytest)生成详细报告。

       参数化功能

       unittest不支持参数化,需借助第三方库(如DDt)实现。pytest支持参数化,可通过@pytest.mark.parametrize或@pytest.fixture(params)实现。

       失败重跑

       unittest不支持用例失败后的自动重跑机制,而pytest通过第三方插件(如pytest-rerunfailures)实现用例重跑。

       跳过用例

       两者都有跳过用例的功能,unittest通过skip或skipif实现,pytest通过skip或skipif实现,允许在条件满足时跳过用例。

       实战演示

       通过请求天气和查询身份证接口的测试用例,分别使用unittest和pytest框架进行参数化测试、跳过用例的实现,并通过生成测试报告进行对比。

       总结

       综上所述,unittest提供基础的单元测试功能,而pytest在unittest的基础上进行了增强和扩展,支持更多的第三方插件,使得测试编写更为灵活和高效。对于初学者,建议先学习unittest,了解其源码后,再逐步接触pytest。