摘要:被測腳本只有正常退出或者以信號退出才能出發(fā),才能得到覆蓋率結(jié)果。如果直接或者用其他信號終止進程,覆蓋率結(jié)果將會丟失參考文章腳本覆蓋率分析方法介紹。
關于Coverage
Coverage是Python代碼覆蓋率分析工具,有關它的介紹和安裝方法請見:
Python代碼覆蓋率分析工具Coverage
用Python啟動的web服務可以方便地使用Coverage分析其覆蓋率,假設一個web服務,它的啟停命令如下:
sudo python xxx/main.py --port=8888 --logging=none > /dev/null 2>&1 & ps auxf|grep xxx/main.py |grep -v grep |awk "{print $2}"|sort -r| sudo xargs kill
像這樣用python啟動的服務可以使用Coverage命令行啟動,用kill -2的關閉,即可統(tǒng)計代碼覆蓋率。
啟停命令使用如下啟停命令:
sudo coverage run --parallel-mode --branch --include="yyy/*" xxx/main.py --port=8888 --logging=none > /dev/null 2>&1 & ps auxf|grep xxx/main |grep -v grep |awk "{print $2}"|sort -r|sudo xargs kill -2
與原來的命令區(qū)別在啟動命令用coverage run和一組參數(shù)替代python,停止命令用kill -2殺進程。
解釋一下啟動命令參數(shù):
--parallel-mode:使Coverage監(jiān)測被測代碼子進程的覆蓋率,如果被測代碼是多進程的,必須使用此參數(shù);
--branch:統(tǒng)計分支代碼覆蓋率,加上這個參數(shù)可使統(tǒng)計更精確,具體區(qū)別參見文檔:http://coverage.readthedocs.org/en/latest/branch.html;
--include: 限定要統(tǒng)計代碼的路徑,如果不限定,Coverage會把請求涉及到的所有代碼,包括系統(tǒng)庫和Tornado框架的代碼都分析一遍,會大大拉低代碼覆蓋率;
各參數(shù)具體可參見:http://coverage.readthedocs.org/en/latest/cmd.html
停止命令,必須使用kill -2。
這是因為Coverage在實現(xiàn)上使用了atexit模塊注冊一個回調(diào)函數(shù),在Python退出時將內(nèi)存中的覆蓋率結(jié)果寫到文件中。被測腳本只有正常退出或者以SIGINT 2信號退出才能出發(fā)atexit,才能得到覆蓋率結(jié)果。如果直接kill(SIGTERM 15)或者用其他信號終止進程,覆蓋率結(jié)果將會丟失(參考文章:Python腳本覆蓋率分析方法介紹)。
CTRL+C發(fā)的即是SIGINT 2信號,所以前臺啟動的服務用CTRL+C停止后可以出結(jié)果。
Coverage結(jié)果收集服務必須以coverage run啟動,并以kill -2終止后,才出現(xiàn)統(tǒng)計結(jié)果:
xxx@xxx:/xxx/$ ll
total 2708
drwxr-xr-x 11 root root 4096 Sep 25 11:46 ./
drwxr-xr-x 6 root root 4096 Sep 25 08:30 ../
-rw-rw-rw- 1 root root 284691 Sep 25 11:46 .coverage.xxx.15845.747211
-rw-rw-rw- 1 root root 284917 Sep 25 11:45 .coverage.xxx.15846.592706
-rw-rw-rw- 1 root root 284274 Sep 25 11:45 .coverage.xxx.15847.688607
-rw-rw-rw- 1 root root 284583 Sep 25 11:45 .coverage.xxx.15858.136003
-rw-rw-rw- 1 root root 284274 Sep 25 11:46 .coverage.xxx.15867.746159
-rw-rw-rw- 1 root root 284691 Sep 25 11:46 .coverage.xxx.15876.004083
-rw-rw-rw- 1 root root 283820 Sep 25 11:46 .coverage.xxx.15886.921243
每個.coverage.xxx文件代表一個子進程的覆蓋率,文件名格式為.coverage.<機器名>.<進程號>.<隨機數(shù)>。
測試結(jié)束后,需要合并測試結(jié)果,生成報告:
coverage combine coverage report -m coverage html coverage xml coverage erase
combine會合并7個.coverage.xxx文件成1個.coverage,因為最后Coverage統(tǒng)計的是.coverage的結(jié)果。
report/html/xml:直接在終端顯示報告/生成html報告/生成xml報告。
erase會刪除.coverage文件,保證不會影響下次統(tǒng)計的結(jié)果。
生成的報告非常清晰,html和xml可以直接點擊進入代碼文件查看。
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/37618.html
摘要:由于構造函數(shù)不支持參數(shù),必須使用配置文件。使用文件作為的配置文件一般的項目都是多進程,這需要分析子進程的覆蓋率,需要用到配置文件。這里文檔說在構造函數(shù)里使用參數(shù)可以限制,實測,沒有用會刪除文件,保證不會影響下次統(tǒng)計的結(jié)果。 關于Coverage Coverage是Python代碼覆蓋率分析工具,有關它的介紹和安裝方法請見:Python代碼覆蓋率分析工具Coverage 用Python啟...
摘要:簡介是一種用于統(tǒng)計代碼覆蓋率的工具,通過它我們可以檢測測試代碼的有效性,即測試對被測代碼的覆蓋率如何。支持分支覆蓋率統(tǒng)計,可以生成報告。 Coverage簡介 Coverage是一種用于統(tǒng)計Python代碼覆蓋率的工具,通過它我們可以檢測測試代碼的有效性,即測試case對被測代碼的覆蓋率如何。Coverage支持分支覆蓋率統(tǒng)計,可以生成HTML/XML報告。XML報告可以集成入Jenk...
摘要:本文會介紹新增的代碼覆蓋率功能如何收集數(shù)據(jù)如何基于它收集的數(shù)據(jù)來改進應用的性能。動態(tài)分析是指在應用運行狀態(tài)下收集代碼執(zhí)行數(shù)據(jù)的過程,換句話說,覆蓋率數(shù)據(jù)就是在代碼執(zhí)行過程中通過標記收集到的。 showImg(https://segmentfault.com/img/remote/1460000009013741); 共 1812 字,讀完需 3 分鐘。工欲善其事必先利其器,前端周刊本周...
摘要:本文將進入單元測試的部分,這也是基礎知識中最后一個大塊。本文將重點講述和中的單元測試的生態(tài)環(huán)境。另外,在中指定要運行的單元測試用例的完整語法是。中使用模塊管理單元測試用例。每個項目的單元測試代碼結(jié)構可 本文將進入單元測試的部分,這也是基礎知識中最后一個大塊。本文將重點講述Python和OpenStack中的單元測試的生態(tài)環(huán)境。 單元測試的重要性 github上有個人畫了一些不同語言的學...
摘要:單元測試框架作為的標準庫,是其他單元測試框架的基礎??梢院秃团浜鲜褂镁帉憜卧獪y試。官網(wǎng)地址單元測試覆蓋率工具單元測試中還需要用到代碼覆蓋率工具。代碼覆蓋率統(tǒng)計工具用來發(fā)現(xiàn)沒有被測試覆蓋的代碼,完善單元測試的覆蓋率。 在應用程序中,單元是具有一個或多個輸入和單個輸出的軟件中最小可測試部分。單元...
閱讀 2958·2023-04-25 22:16
閱讀 2125·2021-10-11 11:11
閱讀 3258·2019-08-29 13:26
閱讀 602·2019-08-29 12:32
閱讀 3422·2019-08-26 11:49
閱讀 3001·2019-08-26 10:30
閱讀 1952·2019-08-23 17:59
閱讀 1518·2019-08-23 17:57