zoukankan      html  css  js  c++  java
  • doctest初次体验

    测试代码放在两个地方才有效果,一个是模块开头,一个是函数声明语句的下一行

    doctest 的概念模型


    在python的官方文档中,对doctest是这样介绍的:

    doctest模块会搜索那些看起来像是python交互式会话中的代码片段,然后尝试执行并验证结果。

    从名字上是否会让你联想到docstring呢?

    doctest的编写过程就像你在一个交互式shell中导入了一个被测试模块,然后一条一条执行被测试模块里面的函数一样。其实实际上doctest也是这么编写的,写好一个模块之后,在shell中测试这个模块里面的函数,将shell会话中的内容复制粘贴成doctest用例。

     

    测试代码验证:unnecessary_math.py

    '''
    
    这个例子展示如何在源码中嵌入doctest用例。
    
    '>>>' 开头的行就是doctest测试用例。
    
    不带 '>>>' 的行就是测试用例的输出。
    
    如果实际运行的结果与期望的结果不一致,就标记为测试失败。
    
    '''
    
    def multiply(a, b):
    
        """
    
        >>> multiply(4, 3)
    
        12
    
        >>> multiply('a', 3)
    
        'aaa'
    
        """
    
        return a * b
    
    if __name__=='__main__':
    
        import doctest
    
        doctest.testmod(verbose=True)

    然后在命令行中定位到文件所在目录,运行python -m doctest -v unnecessary_math.py即可。

    其中参数-v表示打印细节,去除后如果没有发现错误,则什么都不显示

    测试结果如下:

    image

  • 相关阅读:
    一本通1621轻拍牛头
    2.23模拟赛
    一本通1618越狱
    P2280 [HNOI2003]激光炸弹
    P4513 小白逛公园
    P2165 [AHOI2009]飞行棋
    P1877 [HAOI2012]音量调节
    P2023 [AHOI2009]维护序列
    P2253 好一个一中腰鼓!
    P2434 [SDOI2005]区间
  • 原文地址:https://www.cnblogs.com/luhouxiang/p/7503451.html
Copyright © 2011-2022 走看看