unittest

1.执行命令:

python -m unittest E:\lpjx-ui_test\lpjx-web-ui\testcase\web\testcases_pytest\test_XT-0501-002.py

python -m unittest E:\lpjx-ui_test\lpjx-web-ui\testcase\web\testcases_pytest\test_login_DL-001.py

unittest.main(argv=['', 'TestAdd.test_add']

2.组件:

3.TestCase使用方法:

4.断言方法:

5.TestSuite使用: 注意:运行需要借助于TextTestRunner类

6.TestLoader使用:

discover(test_dir, pattern=匹配模式)

参数说明:

  • test_dir: 为指定的测试用例的目录,它会搜索该目录的所有文件
  • pattern:为匹配模式,如要查找所有的.py格式文件,你就可以写为'test*.py',这样就会搜索test_dir目录下所有以test开头,以py结尾的文件。

7.TextTestRunner使用:

8.参数化:需先导包:ddt,parametrized

- 传单个字符串:
@data("bb")
def test_run_b(self,b):
    print(b)     #bb

@data(("a","b","c","d"))
@unpack
def test_run_c(self,para1,para2,para3,para4):
    print(para1,para2,para3,para4)   #a b c d

@data(["a", "b", "c", "d"])
@unpack
def test_run_d(self, para1, para2, para3, para4):
    print(para1, para2, para3, para4)   #a b c d

- 传几组字符串-data  字典怎么传?
@data(("ae","be"), ("ce","de"))
@unpack
def test_run_e(self, para1, para2): #会生成2条用例
    print("test_run_e:"+para1+" "+ para2)   
#.test_run_e:ae be
#.test_run_e:ce de

@data(["aa", "bb"], ["cc", "dd"])
@unpack
def test_run_f(self, para1, para2):  # 会生成2条用例
    print(" test_run_f:"+para1+" "+para2)
#. test_run_f:aa bb
#. test_run_f:cc dd

@data({"aa":"bb"}, {"cc":"dd"}) #字典报错???
@unpack
def test_run_g(self, aa, cc):  # 会生成2条用例
    print(" test_run_g:"+aa+" "+cc)

- 传几组字符串-parameterized
@parameterized.expand([("ai","bi"), ("ci","di")])
def test_run_i(self, username, password):
    print(" test_run_i:" + username + " " + password)
#. test_run_i:ai bi
#. test_run_i:ci di

- 传json文件
{
  "user1": {"username": "111", "password": "as"},
  "user2": {"username": "222", "password": "ad"},
  "user3": {"username": "A320098207", "password": "Cszxqc@2022"}
}
@file_data("E:\demo-selenium-pytest\data\login2.json") #json
def test_run_g2(self, username, password):  # 会生成2条用例
    print(" test_run_g2:"+username+" "+password)
#. test_run_g2:111 as
#. test_run_g2:222 ad
#. test_run_g2:A320098207 Cszxqc@2022

- 传yaml文件:
user1:
  username: "111"
  password: "as"
user2:
  username: "222"
  password: "ad"
user3:
  username: "A320098207"
  password: "Cszxqc@2022"
@file_data("E:\demo-selenium-pytest\data\login.yaml")  #yaml
def test_run_g3(self, username, password):  # 会生成2条用例
    print(" test_run_g3:" + username + " " + password)
#. test_run_g3:111 as
#. test_run_g3:222 ad
#. test_run_g3:A320098207 Cszxqc@2022

- 传txt文件:
111,as
222,ad
A320098207,Cszxqc@2022
def readtxt():
    params = []
    file = open("E:\demo-selenium-pytest\data\login3.txt", "r", encoding="utf8")
    for line in file.readlines():
        params.append(line.strip("\n").split(","))
    return params
@ddt
class test_query_userinfo2(unittest.TestCase):
    @data(*readtxt())  #txt
    @unpack
    def test_run_h(self, username, password):  #
          print(" test_run_h:" + username + " " + password)
#.EE test_run_h:111 as
#. test_run_h:222 ad
#. test_run_h:A320098207 Cszxqc@2022

### 单元测试指南:使用 Unittest 框架进行实践 #### 1. 理解单元测试的基本概念 单元测试是软件开发中确保代码质量的重要手段,它通过验证代码的最小可测试单元(如函数、类方法)的行为是否符合预期来提高代码的可靠性和可维护性。Python 提供了内置的 `unittest` 模块,支持编写和运行单元测试 [^2]。 #### 2. 编写单元测试用例 在 `unittest` 中,所有的测试用例必须继承自 `unittest.TestCase` 类,并且每个测试方法需要以 `test_` 开头,不能有参数或返回值 [^3]。例如: ```python import unittest from calculator import Count class TestCount(unittest.TestCase): def setUp(self): print("Test Start") def test_add(self): s = Count(3, 4) self.assertEqual(s.add(), 7) # 验证 add 方法的结果是否等于 7 def tearDown(self): print("Test End") if __name__ == '__main__': unittest.main() ``` #### 3. 使用 setUp 和 tearDown 设置测试固件 为了确保测试环境的一致性,可以使用 `setUp()` 和 `tearDown()` 方法分别在每个测试方法执行前后进行初始化和清理工作。例如,在 UI 自动化测试中,可以在 `setUp()` 中启动浏览器,并在 `tearDown()` 中关闭浏览器 [^5]。 ```python import unittest from selenium import webdriver class TestBaidu(unittest.TestCase): def setUp(self): self.driver = webdriver.Chrome() self.driver.maximize_window() self.driver.get("https://www.baidu.com/") def test_title(self): self.assertEqual(self.driver.title, "百度一下,你就知道") def tearDown(self): self.driver.quit() ``` #### 4. 构造测试套件 (TestSuite) 除了直接使用 `unittest.main()` 运行单个模块中的所有测试用例外,还可以通过构造 `TestSuite` 来组织多个测试用例并按需运行。这可以通过 `unittest.TestLoader().loadTestsFromTestCase()` 或手动添加测试用例实现: ```python import unittest from test_module import TestCount, TestAnotherFunction suite = unittest.TestSuite() suite.addTest(TestCount('test_add')) suite.addTest(TestAnotherFunction('test_subtract')) runner = unittest.TextTestRunner() runner.run(suite) ``` #### 5. 测试发现与批量执行 `unittest` 支持自动发现项目中的测试文件并批量执行它们。通常情况下,测试文件命名习惯为 `test_*.py`,并且位于指定目录下。可以通过以下命令执行: ```bash python -m unittest discover -s tests ``` 其中 `-s` 参数指定测试目录。 #### 6. 使用断言验证结果 `unittest.TestCase` 提供了一系列断言方法用于验证测试结果,常见的包括: - `assertEqual(a, b)`:检查 a 是否等于 b。 - `assertTrue(x)`:检查 x 是否为 True。 - `assertRaises(exception, callable, *args, **kwargs)`:检查调用是否抛出特定异常。 ```python def test_divide_by_zero(self): with self.assertRaises(ZeroDivisionError): divide(10, 0) ``` #### 7. 最佳实践 - **保持测试独立**:每个测试用例应独立运行,不依赖其他测试的状态。 - **测试命名清晰**:测试方法名应描述被测功能,便于定位问题。 - **覆盖边界条件**:测试不仅要覆盖正常情况,还要覆盖边界条件和异常情况。 - **持续集成**:将单元测试集成到 CI/CD 流程中,确保每次提交都经过测试验证。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值