1.介紹

標(biāo)準(zhǔn)的github沒有CI測試,可以在Github應(yīng)用市場中搜索CI找到相應(yīng)的應(yīng)用。這里我們使用Travis CI,也就是下圖標(biāo)記的工具進(jìn)行ci測試。

2.綁定Travis CI
點(diǎn)擊進(jìn)入之后需要綁定你的github賬號(hào),需要說明的是對(duì)于開源項(xiàng)目Travis CI是免費(fèi)的,其它情況需要另行收費(fèi)。

具體設(shè)置很簡單,只需要按步驟走就可以了,設(shè)置完成之后。在主界面(Travis CI的主界面不是github)可以顯示你的所有項(xiàng)目。

到此為止,綁定Travis CI的步驟就結(jié)束了。
3.測試用例編寫
-
假設(shè)安裝了pytest包,在pycharm中設(shè)置測試包為pytest
pycharm設(shè)置pytest
然后,我在項(xiàng)目中新建了兩個(gè).py 文件,分別是tool1.py, tool2.py
文件目錄形式
tool1.py文件我實(shí)現(xiàn)了一個(gè)取兩個(gè)列表交集的函數(shù)
def inter_set(l1, l2):
l3 = set(l1).intersection(l2)
return l3
tool2.py文件我實(shí)現(xiàn)了一個(gè)取兩個(gè)列表差集的函數(shù)
def diff_set(l1, l2):
l3 = set(l1).difference(l2)
return l3
假設(shè)我們需要編寫這兩個(gè)函數(shù)的測試用例,首先我們把鼠標(biāo)移動(dòng)到需要測試的函數(shù),如下圖操作

這是我們就生成了一個(gè) test_文件名.py 的測試文件

進(jìn)入該文件點(diǎn)擊鼠標(biāo)右鍵可以發(fā)現(xiàn),右邊的運(yùn)行選項(xiàng)變成了pytest test_tool2

假設(shè)我們已經(jīng)寫好的測試程序,并新建一個(gè)test文件夾專門存放這些測試文件,如下圖

4. 使用Travis CI
使用Travis CI需要在你的項(xiàng)目中新建一個(gè).travis.yml, 我的配置如下,這里我使用的是poetry安裝依賴包(使用方法我的文章里面有),如果不使用poetry也可以直接使用pip安裝
language: python
python:
- "3.6"
# 安裝依賴包的命令
# 這里首先使用pip安裝poetry和pytest
# poetry和pytest不是該項(xiàng)目本身必須的依賴包
# poetry用來安裝項(xiàng)目依賴包。
# pytest用來進(jìn)行測試
# 當(dāng)然所有依賴包也可以全部使用pip安裝
install:
- pip install poetry
- pip install pytest
- poetry install
# 這里定義環(huán)境變量,用于做ci測試
env:
- test_run1=test/test_tool1.py
- test_run2=test/test_tool2.py
# 運(yùn)行測試用例命令
script:
- pytest $test_run1
- pytest $test_run2
到此為止,所有準(zhǔn)備工作就已經(jīng)做好了,我們git push 項(xiàng)目到github,于此同時(shí)我們打開Travis CI的頁面選擇剛才git push的項(xiàng)目,Build History選項(xiàng)中可以看到我們的測試


如果某一次提交沒通過測試,可以點(diǎn)擊Build History,選擇相應(yīng)的Build job

點(diǎn)擊進(jìn)入Build job之后選擇一個(gè)測試任務(wù),你就會(huì)進(jìn)入如下頁面觀看相信測試信息

5.領(lǐng)取標(biāo)簽
測試完成之后可以在項(xiàng)目中領(lǐng)取build通過的圖標(biāo)

最后可以將圖標(biāo)添加到項(xiàng)目的README.md中,效果如下

這個(gè)寫的有點(diǎn)匆忙,有些東西不是寫的很細(xì),詳情請(qǐng)見這個(gè)項(xiàng)目,另外pytest的教程網(wǎng)上很多,很多時(shí)候規(guī)范化變成很重要,這里推薦pytest的用法博客

