測試平臺系列(71) Python定時任務方案

米洛丶發表於2021-11-04

大家好~我是米洛

我正在從0到1打造一個開源的介面測試平臺, 也在編寫一套與之對應的完整教程,希望大家多多支援。

歡迎關注我的公眾號測試開發坑貨,獲取最新文章教程!

定時任務

定時任務,顧名思義: 定時執行的任務,可以是一段bash命令,也可以是一個指令碼檔案。通常用於我們需要在特定時刻做事情。

舉個例子: 每晚8點執行全業務場景介面自動化迴歸測試,又或者每隔20分鐘去你家QQ農場偷菜!

Python的定時任務

如果是大中型公司,一定有對應的平臺讓大家接入。一般這樣的平臺的名字或者描述都是: 分散式任務排程平臺這樣的。再不濟還有jenkins滿足我們的需求~

想起博主以前"小時候"(剛工作的時候),公司既沒有用jenkins,也沒有這樣的大平臺可以接入。我是怎麼做定時任務的呢?

來看一段程式碼:

import time
from datetime import datetime

def func():
    # 這個是定時任務要執行的ui/介面自動化方法
    pass

def main():
    while True:
      # 獲取當前時間
      now = datetime.now()
      if now.hour == 20 and now.minute == 0:
          # 當時間到達晚上8點0分,我們就開始跑自動化任務啦
          print("任務開始執行")
          func()
      time.sleep(60)
      
      
if __name__ == "__main__":
    main()

不知道現在是否還有人依然用著這樣的方式定時執行自動化測試,既然都2021年了,那我們們還是先進點吧。那麼定時任務在Python中要怎麼做呢?接著看。

幾種常見的方案

schedule

如果你只是上面提到簡單訴求,那我建議直接使用schedule庫。這個庫我個人感覺是小學生版本的升級版,對於我那種侷限的sleep任務做了一些擴充套件:

  • 支援了按週期執行任務
  • 執行時間閱讀起來更人性化
  • 還支援星期X執行

  1. 安裝scheduler
pip install schedule
  1. 官網給出的例子
import schedule
import time

# 定義一個執行方法
def job():
    print("I'm working...")

# 每10分鐘執行一次job
schedule.every(10).minutes.do(job)
# 每小時執行一次job
schedule.every().hour.do(job)
# 每天10:30執行job
schedule.every().day.at("10:30").do(job)
# 每個星期一執行一次
schedule.every().monday.do(job)
# 每個星期三的13:15執行一次
schedule.every().wednesday.at("13:15").do(job)
# 在每分鐘的17秒執行一次
schedule.every().minute.at(":17").do(job)


while True:
    # 進入schedule迴圈
    schedule.run_pending()
    time.sleep(1)

可以看出,api十分簡單,語義也很清晰。基本可以滿足我們的需求了~如果我們只是要定時去做某些事情的話,我想這個庫非常human。

Jenkins

這個工具相比大家都有所瞭解吧~jenkins是一個比較強大的軟體了,它可以打通git/svn,也支援定時任務等。有著豐富的外掛,比如郵件,是一套完整的CI/CD解決方案。對於任務的執行結果的記錄,也是可追溯的。估計唯一的缺點就是,引入了額外的系統。可能本身我只是一個自動化測試框架,現在卻要搭建一套jenkins。

如果大家有程式碼改動->執行定時任務類似的需求,又需要完善的許可權控制系統的話,那jenkins會是你的不二選擇。

Celery

我對這傢伙瞭解的不太多,但python+celery彷彿成了一個固定搭配。不知道我理解的對不對:

celery是一個任務佇列,你可以制定好任務執行的規則,放入佇列中,會有專門的消費端來幫你執行這些任務。

說到這裡就不得不提到持久化了~

題外話之持久化

什麼是持久化呢?通俗的講,就是瞬時資料(比如記憶體中的資料,是不能永久儲存的)持久化為持久資料(比如持久化至資料庫中,能夠長久儲存)

我們可以把資料放到檔案裡,也可以放到資料庫(實際上也是磁碟裡)進行永續性儲存。

這樣做的目的: 資料可以儲存,下次也還能拿到這些資料。這裡面的內容太多了,打算後面再開一節來講。

我們在Python裡面的變數啊,這些資料都是存放在記憶體當中的,所以我們剛才的schedule是不支援持久化的。(也可能是我沒研究到)

那jenkins支援嗎?他是支援的,你想,你建立一個專案,裡面有一些job的配置,什麼時候執行,執行了幹嘛,最後儲存。

上述就是一個持久化的過程。

你儲存了資料以後,下次能夠獲取到這個專案的任務資訊,也就是說你哪怕重啟了jenkins,任務依然存在

說明任務本身作為了一條資料,持久地儲存了起來。

ApScheduler

"APScheduler是一個Python庫,可讓您安排稍後要執行的Python程式碼,只需一次或定期執行。您可以根據您新增新的作業或刪除舊的舊作業。如果您在資料庫中儲存工作,他們還將存活排程程式重新啟動並保持狀態。重新啟動排程程式時,它將執行它在離線1時應該執行的所有作業。"

這是摘自ApScheduler官網的介紹,總體來說它支援對任務的增刪改查(持久化),也能很好地支撐定時任務的執行。它相對來說比較輕量,不像celery那麼複雜,也不像schedule那麼簡陋。由於我們不打算引入jenkins,所以總體來說,ApScheduler算得上是我們們執行定時任務的不二之選了。

由於篇幅的原因,今天的內容就介紹到這啦~

下一節我們就詳細介紹ApScheduler在pity中的運用叭

相關文章