• Python中怎么进行单元测试


    既然是测试,那我们得有被测试的代码,我们先定义一个简单的函数,这个函数的功能就是接收一个姓名,并返回一句问候语句。

    say_hello_function.py

    1 def hello_name(name):
    2     greet = "Hello , "
    3     return greet + name.title()

    显然,关于单元测试Python也给我们提供了相应的模块(unittest),单元测试:用于确定函数的某方面没有问题;测试用例:即一组单元测试,在各个情况下的行为都符合我们的预期。

    一、成功通过的测试

    编写测试用例的步骤:1.先导入unittest模块;2.创建一个类(任意名)继承unittest.TestCase;3.编写需要测试的代码对函数进行各方面的测试。我们先只用上面一个函数举例即只包含一个方法的测试用例,主要检查函数hello_name 运行之后是否符合我们的预期。

    test_say_hello.py

     1 #coding=gbk  //因为本人用的编辑器编码为GBK,所以需要加这一行,如果你的是utf-8,将gbk改为utf-8即可(主要是为了让Python能识别注释与字符串中的中文字符)
     2 import unittest
     3 
     4 from say_hello_function import hello_name
     5 
     6 class HelloTest(unittest.TestCase):
     7     """用于测试say_hello_function.py"""
     8     def test_hello_name(self):
     9         """是否能正确处理Joker 这个名字"""
    10         hello_str = hello_name('Joker')
    11         self.assertEqual(hello_str,'Hello , Joker')
    12         
    13 unittest.main()

    解释:国际惯例,先导入unittest模块,以及欲测试的函数hello_name(),第6行代码中,我们创建了一个名为HelloTest的类且继承了unittest.TestCase类,虽然这个类名你可以随便取,但最好让人见名知意,比如我所取的类名中包含Test,让人很简单的知道这是个测试类,继承unittest.TestCase类 这是必须的不能随意,因为这样Python才会知道如何运行你编写的测试。

    这个类只包含一个方法,用于测试hello_name()函数的一个方面。我们给方法命令为test_hello_name(),诶,这个方法名不能随意取,必须得以test_ 开头,这样Python才能在运行的时候运行所有的以test_开头的方法。

    第10 行我们调用了hello_name()函数 并将函数返回的结果存储到变量hello_str 中,我们在第11 行代码中,使用了unittest中最为有用的方法之一:断言方法。断言显而易见,就是用来核实得到的结果是否与我们预期的一致。在这里我们知道hello_name()函数返回 Hello +,(逗号) + 名字(且首字母大写),单词与符号之间都有一个空格,因此我们所预期的是“Hello , Joker”,为了验证我们所想,我们即调用unnittest的方法assertEqual() 并向它传递两个参数 hello_str 和 “Hello , Joker ”,将hello_str 的值与后者字符串进行比较,如果相等,就相安无事,而如果不相等,事儿就大了。

    我们运行该测试,控制台打印如下:

    第一行有一个点,表示有一个测试通过了,虚线下面的一行表示,Python运行了一个测试,所消耗时间不到0.001秒,而最后一行的OK 则表示所有的用例都通过了。综上,在给函数hello_name() 传入一个名字为“Joker”时,该函数总能正确处理。修改该函数后,再次运行这个测试用例,如果它通过了,我们就知道在给定Joker这个名字时,这个函数还是可以正确处理。

      未完待续......  

      你以为有钱人他们很快乐吗?对的,他们的快乐,你想象不到。

      

  • 相关阅读:
    SQL Server 文件规划 位置规划
    在VS2008中使用WSE 3.0过程全记录
    关于CDC功能的答疑
    SQL Server 2008 : 基于策略的管理(PolicyBased Management)
    使用 Google Gears 开发离线应用
    SQL Server 2008 :安装
    WCF 之UserName身份验证全记录
    SQL Server 文件规划 文件组
    不可思议的SQLite
    使用Trigger让UpdatePanel外部的控件也支持无刷新异步调用
  • 原文地址:https://www.cnblogs.com/tizer/p/11080007.html
Copyright © 2020-2023  润新知