婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 淺談如何測試Python代碼

淺談如何測試Python代碼

熱門標簽:打電話機器人營銷 海外網吧地圖標注注冊 聊城語音外呼系統 騰訊地圖標注沒法顯示 孝感營銷電話機器人效果怎么樣 地圖標注自己和別人標注區別 ai電銷機器人的優勢 南陽打電話機器人 商家地圖標注海報

一、介紹

編寫測試檢驗應用程序所有不同的功能。每一個測試集中在一個關注點上驗證結果是不是期望的。定期執行測試確保應用程序按預期的工作。當測試覆蓋很大的時候,通過運行測試你就有自信確保修改點和新增點不會影響應用程序。

知識點

  • 單元測試概念
  • 使用 unittest 模塊
  • 測試用例的編寫
  • 異常測試
  • 測試覆蓋率概念
  • 使用 coverage 模塊

二、測試范圍

如果可能的話,代碼庫中的所有代碼都要測試。但這取決于開發者,如果寫一個健壯性測試是不切實際的,你可以跳過它。就像 _Nick Coghlan_(Python 核心開發成員) 在訪談里面說的:有一個堅實可靠的測試套件,你可以做出大的改動,并確信外部可見行為保持不變。

三、單元測試

這里引用維基百科的介紹:

在計算機編程中,單元測試(英語:Unit Testing)又稱為模塊測試, 是針對程序模塊(軟件設計的最小單位)來進行正確性檢驗的測試工作。程序單元是應用的最小可測試部件。在過程化編程中,一個單元就是單個程序、函數、過程等;對于面向對象編程,最小單元就是方法,包括基類(超類)、抽象類、或者派生類(子類)中的方法。

單元測試模塊

在 Python 里我們有 unittest 這個模塊來幫助我們進行單元測試。

階乘計算程序

在這個例子中我們將寫一個計算階乘的程序 factorial.py

import sys

def fact(n):
    """
    階乘函數

    :arg n: 數字
    :returns: n 的階乘

    """
    if n == 0:
        return 1
    return n * fact(n -1)

def div(n):
    """
    只是做除法
    """
    res = 10 / n
    return res


def main(n):
    res = fact(n)
    print(res)

if __name__ == '__main__':
    if len(sys.argv) > 1:
        main(int(sys.argv[1]))

運行程序:

$ python3 factorial.py 5

四、第一個測試用例

測試哪個函數?

正如你所看到的, fact(n) 這個函數執行所有的計算,所以我們至少應該測試這個函數。

編輯 factorial_test.py 文件,代碼如下:

import unittest
from factorial import fact

class TestFactorial(unittest.TestCase):
    """
    我們的基本測試類
    """

    def test_fact(self):
        """
        實際測試
        任何以 `test_` 開頭的方法都被視作測試用例
        """
        res = fact(5)
        self.assertEqual(res, 120)


if __name__ == '__main__':
    unittest.main()

運行測試:

$ python3 factorial_test.py
.
----------------------------------------------------------------------
Ran 1 test in 0.000s

OK

說明

我們首先導入了 unittest 模塊,然后測試我們需要測試的函數。

測試用例是通過子類化 unittest.TestCase 創建的。

現在我們打開測試文件并且把 120 更改為 121,然后看看會發生什么?

各類 assert 語句

Method Checks that New in
assertEqual(a, b) a == b
assertNotEqual(a, b) a != b
assertTrue(x) bool(x) is True
assertFalse(x) bool(x) is False
assertIs(a, b) a is b 2.7
assertIsNot(a, b) a is not b 2.7
assertIsNone(x) x is None 2.7
assertIsNotNone(x) x is not None 2.7
assertIn(a, b) a in b 2.7
assertNotIn(a, b) a not in b 2.7
assertIsInstance(a, b) isinstance(a, b) 2.7
assertNotIsInstance(a, b) not isinstance(a, b) 2.7

五、異常測試

如果我們在 factorial.py 中調用 div(0),我們能看到異常被拋出。

我們也能測試這些異常,就像這樣:

self.assertRaises(ZeroDivisionError, div, 0)

完整代碼:

import unittest
from factorial import fact, div

class TestFactorial(unittest.TestCase):
    """
    我們的基本測試類
    """

    def test_fact(self):
        """
        實際測試
        任何以 `test_` 開頭的方法都被視作測試用例
        """
        res = fact(5)
        self.assertEqual(res, 120)

    def test_error(self):
        """
        測試由運行時錯誤引發的異常
        """
        self.assertRaises(ZeroDivisionError, div, 0)



if __name__ == '__main__':
    unittest.main()

六、mounttab.py

mounttab.py 中只有一個 mount_details() 函數,函數分析并打印掛載詳細信息。

import os


def mount_details():
    """
    打印掛載詳細信息
    """
    if os.path.exists('/proc/mounts'):
        fd = open('/proc/mounts')
        for line in fd:
            line = line.strip()
            words = line.split()
            print('{} on {} type {}'.format(words[0],words[1],words[2]), end=' ')
            if len(words) > 5:
                print('({})'.format(' '.join(words[3:-2])))
            else:
                print()
        fd.close()


if __name__ == '__main__':
    mount_details()

重構 mounttab.py

現在我們在 mounttab2.py 中重構了上面的代碼并且有一個我們能容易的測試的新函數 parse_mounts()

import os

def parse_mounts():
    """
    分析 /proc/mounts 并 返回元祖的列表
    """
    result = []
    if os.path.exists('/proc/mounts'):
        fd = open('/proc/mounts')
        for line in fd:
            line = line.strip()
            words = line.split()
            if len(words) > 5:
                res = (words[0],words[1],words[2],'({})'.format(' '.join(words[3:-2])))
            else:
               res = (words[0],words[1],words[2])
            result.append(res)
        fd.close()
    return result

def mount_details():
    """
    打印掛載詳細信息
    """
    result = parse_mounts()
    for line in result:
        if len(line) == 4:
            print('{} on {} type {} {}'.format(*line))
        else:
            print('{} on {} type {}'.format(*line))


if __name__ == '__main__':
    mount_details()

同樣我們測試代碼,編寫 mounttest.py 文件:

#!/usr/bin/env python
import unittest
from mounttab2 import parse_mounts

class TestMount(unittest.TestCase):
    """
    我們的基本測試類
    """

    def test_parsemount(self):
        """
        實際測試
        任何以 `test_` 開頭的方法都被視作測試用例
        """
        result = parse_mounts()
        self.assertIsInstance(result, list)
        self.assertIsInstance(result[0], tuple)

    def test_rootext4(self):
        """
        測試找出根文件系統
        """
        result = parse_mounts()
        for line in result:
            if line[1] == '/' and line[2] != 'rootfs':
                self.assertEqual(line[2], 'ext4')


if __name__ == '__main__':
    unittest.main()

運行程序

$ python3 mounttest.py
..
----------------------------------------------------------------------
Ran 2 tests in 0.001s
OK

七、測試覆蓋率

測試覆蓋率是找到代碼庫未經測試的部分的簡單方法。它并不會告訴你的測試好不好。

在 Python 中我們已經有了一個不錯的覆蓋率工具來幫助我們。你可以在實驗樓環境中安裝它:

$ sudo pip3 install coverage

覆蓋率示例

$ coverage3 run mounttest.py
..
----------------------------------------------------------------------
Ran 2 tests in 0.013s
OK
$ coverage3 report -m
Name           Stmts   Miss  Cover   Missing
--------------------------------------------
mounttab2.py      22      7    68%   16, 25-30, 34
mounttest.py      14      0   100%
--------------------------------------------
TOTAL             36      7    81%

我們還可以使用下面的命令以 HTML 文件的形式輸出覆蓋率結果,然后在瀏覽器中查看它。

$ coverage3 html

八、總結

知識點回顧:

  • 單元測試概念
  • 使用 unittest 模塊
  • 測試用例的編寫
  • 異常測試
  • 測試覆蓋率概念
  • 使用 coverage 模塊

本節了解了什么是單元測試,unittest 模塊怎么用,測試用例怎么寫。以及最后我們使用第三方模塊 coverage 進行了覆蓋率測試。

在實際生產環境中,測試環節是非常重要的的一環,即便志不在測試工程師,但以后的趨勢就是 DevOps,所以掌握良好的測試技能也是很有用的。

到此這篇關于淺談如何測試Python代碼的文章就介紹到這了,更多相關測試Python代碼內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python實現http接口自動化測試的示例代碼
  • Python requests接口測試實現代碼
  • Python reques接口測試框架實現代碼
  • Python分類測試代碼實例匯總
  • Python3 webservice接口測試代碼詳解
  • Python+appium框架原生代碼實現App自動化測試詳解
  • python英語單詞測試小程序代碼實例
  • python自動化測試之DDT數據驅動的實現代碼
  • Python代碼縮進和測試模塊示例詳解

標簽:牡丹江 迪慶 楊凌 六盤水 揚州 撫州 南寧 聊城

巨人網絡通訊聲明:本文標題《淺談如何測試Python代碼》,本文關鍵詞  淺談,如何,測試,Python,代碼,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《淺談如何測試Python代碼》相關的同類信息!
  • 本頁收集關于淺談如何測試Python代碼的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人黄色网址在线观看| av午夜精品一区二区三区| 中文幕一区二区三区久久蜜桃| 成人性生交大片免费看在线播放| 国产福利一区二区三区视频| 在线精品视频小说1| 国产精品色呦呦| 风流少妇一区二区| 久久一区二区三区国产精品| 亚洲美女屁股眼交| 高清国产一区二区三区| 国产人成一区二区三区影院| 极品少妇xxxx精品少妇偷拍 | 精品国产1区2区3区| 五月综合激情婷婷六月色窝| 99在线视频精品| 欧美一级二级三级乱码| 青娱乐精品视频| 精品国产免费视频| 国产成人啪午夜精品网站男同| 国产精品午夜春色av| 欧美在线一区二区三区| 国内精品久久久久影院色| 国产人妖乱国产精品人妖| 亚洲柠檬福利资源导航| 欧洲一区二区三区在线| 亚洲一区二区精品视频| 日韩一区二区免费在线观看| 免费观看日韩av| 国产清纯白嫩初高生在线观看91| 91国偷自产一区二区三区成为亚洲经典 | 国产suv精品一区二区6| 国产精品乱码妇女bbbb| 一本大道综合伊人精品热热| 亚洲午夜久久久久中文字幕久| 日韩限制级电影在线观看| 激情文学综合丁香| 偷拍亚洲欧洲综合| 日本一区二区三区电影| 色综合中文字幕国产 | 欧美色综合网站| 成人动漫一区二区三区| 免费在线视频一区| 国产白丝精品91爽爽久久| 秋霞电影一区二区| 一区二区在线观看视频| 26uuu色噜噜精品一区| 91久久一区二区| 国产黑丝在线一区二区三区| 亚洲一区二区在线视频| 亚洲欧洲制服丝袜| 国产精品美女久久久久久久久| 中文字幕精品在线不卡| 日韩小视频在线观看专区| 欧美四级电影网| 色av成人天堂桃色av| 欧美午夜在线观看| 精品久久国产字幕高潮| 国产欧美精品区一区二区三区 | 久久综合中文字幕| 久久精品欧美日韩精品| 综合电影一区二区三区| 欧美激情综合在线| 美女视频一区二区| 成人精品在线视频观看| 欧美婷婷六月丁香综合色| 久久久综合视频| 一区2区3区在线看| 国产·精品毛片| 欧美日韩视频不卡| 国产日韩成人精品| 麻豆免费精品视频| 欧美日韩精品欧美日韩精品一综合| 日韩免费一区二区| 亚洲福利一区二区| 丁香一区二区三区| 国产亚洲一区二区三区在线观看| 一区二区三区波多野结衣在线观看 | 91麻豆自制传媒国产之光| 久久亚洲免费视频| 蜜桃久久久久久久| 欧美一二三在线| 精品一区二区免费视频| 日韩午夜电影在线观看| 美脚の诱脚舐め脚责91| 日韩一级片网站| 精品在线播放免费| 欧美极品另类videosde| 精品在线免费观看| 中文字幕第一区第二区| 国产成人啪免费观看软件| 中文字幕av一区 二区| 97精品久久久午夜一区二区三区| 国产三级精品视频| 白白色 亚洲乱淫| 亚洲综合一区二区| 欧美一区二区在线不卡| 狠狠色丁香久久婷婷综合丁香| 国产精品嫩草久久久久| 欧美一区二区在线看| 日本不卡123| 亚洲猫色日本管| 国产亚洲欧洲一区高清在线观看| 在线亚洲一区二区| 日本不卡123| 一区二区三区在线视频播放| 精品国产乱码久久久久久浪潮| 欧美一a一片一级一片| 国产aⅴ精品一区二区三区色成熟| 亚洲国产一二三| 成人免费在线观看入口| 国产欧美综合在线| 2021久久国产精品不只是精品| 欧美日韩午夜在线| 日本韩国精品在线| 在线中文字幕不卡| 在线免费亚洲电影| 91免费国产视频网站| 99精品视频在线播放观看| 91亚洲国产成人精品一区二区三 | 天堂va蜜桃一区二区三区漫画版| 国产日韩高清在线| 亚洲精品欧美在线| 亚洲电影一区二区| 日本系列欧美系列| 久久精品国产久精国产爱| 日韩电影在线免费看| 免费在线视频一区| 国产不卡视频在线观看| av一区二区三区| 一本久久精品一区二区| 色综合久久久久综合体| 欧美精品1区2区| 国产视频一区在线观看| 一个色综合网站| 国产精品亚洲午夜一区二区三区 | 午夜精品久久一牛影视| 国产资源在线一区| 日韩美女视频一区二区| 一本色道a无线码一区v| 美日韩黄色大片| 中文字幕在线视频一区| 日韩一区二区免费高清| 99久久精品情趣| 日韩福利电影在线| 亚洲欧洲精品一区二区精品久久久 | 日本 国产 欧美色综合| 中文字幕电影一区| 91精选在线观看| 成人黄色软件下载| 日韩精品亚洲专区| 亚洲三级电影网站| 国产精品国产三级国产aⅴ无密码| 欧美在线看片a免费观看| 韩国在线一区二区| 日日夜夜精品视频天天综合网| 久久免费的精品国产v∧| 91久久精品日日躁夜夜躁欧美| 麻豆91精品91久久久的内涵| 国产精品久久久久久亚洲伦| 成人久久18免费网站麻豆| 精品一区二区影视| 天天操天天色综合| 一区二区国产视频| 亚洲一线二线三线久久久| 一区二区三区在线影院| 亚洲一二三专区| 性欧美大战久久久久久久久| 一区二区高清视频在线观看| 综合激情网...| 午夜精品久久久久久久蜜桃app| 亚洲欧美中日韩| 性久久久久久久久久久久| 中文字幕精品一区| 欧美综合一区二区三区| 天堂va蜜桃一区二区三区漫画版| 26uuu久久天堂性欧美| 欧美这里有精品| 成人免费毛片app| 久久久久久久久久久久久女国产乱 | 国产精品短视频| 最新国产精品久久精品| 一区二区三区在线视频观看58| 日韩精品一区第一页| 成人精品免费看| 在线成人小视频| 日韩美女视频一区二区| 婷婷综合久久一区二区三区| 国产大陆a不卡| 欧美一区二区精美| 亚洲精品成人精品456| 国产精品1024| 亚洲精品一区在线观看| 亚洲成人在线免费| 91久久国产最好的精华液| 久久众筹精品私拍模特| 美腿丝袜亚洲色图| 日韩午夜中文字幕| 午夜精品福利一区二区蜜股av | 91精品国产综合久久蜜臀|