python+unittest框架第四天unittest之批量執行案例

来源:https://www.cnblogs.com/woshidaliua/archive/2019/08/25/11397346.html
-Advertisement-
Play Games

今天開始批量執行用例~,場景是這樣的: 工作中我們可能有多個模塊文件(.py)這些文件根據不同的業務類型或功能,測試案例分佈在不同的模塊文件下。前面的小示例中,我們的測試用例都是在一個文件中,直接運行的測試套件~,開發階段或者調試階段這樣做是沒毛病的,但是如果是測試運行階段,我們不可能這個模塊文件下 ...


  今天開始批量執行用例~,場景是這樣的:

工作中我們可能有多個模塊文件(.py)這些文件根據不同的業務類型或功能,測試案例分佈在不同的模塊文件下。前面的小示例中,我們的測試用例都是在一個文件中,直接運行的測試套件~,開發階段或者調試階段這樣做是沒毛病的,但是如果是測試運行階段,我們不可能這個模塊文件下的用例執行完畢後,切換另一個模塊中的用例繼續執行。所以我們需要用的批量執行多個模塊文件的測試用例。

 

首先第一個用例模塊的案例是這樣的~

 1 import unittest               #導入unittest庫
 2 from selenium import webdriver    #導入自動化測試selenium中的webdriver
 3 
 4 class baidu_test_1(unittest.TestCase):   #寫一個baidu_test_1 類,繼承unittest中的TestCase類
 5 
 6     @classmethod        #方便我們直接調用,不需要實例化類的對象直接調用
 7     def setUp(cls):     #所有案例執行前,都先執行該方法,初始化
 8         cls.driver = webdriver.Chrome()    #實例化一個webdriver對象
 9         cls.driver.maximize_window()      #最大化瀏覽器視窗
10         cls.driver.implicitly_wait(15)    #頁面載入慢的情況,我們設置等待時長15秒
11         cls.driver.get(r'http://www.baidu.com')     #打開百度的首頁
12 
13     @classmethod
14     def tearDown(cls):     #所有案例執行後,執行該方法
15         cls.driver.quit()     #關閉瀏覽器
16 
17     '''測試用例'''
18     def test_baidu_lianjie(self):    #百度鏈接測試的用例
19         '''百度首頁:測試新聞鏈接,跳轉後的鏈接地址是否正確'''
20         self.driver.find_element_by_link_text('新聞').click()  #點擊新聞鏈接後,獲取新聞鏈接:self.driver.current_url
21         self.assertEqual(self.driver.current_url,'http://news.baidu.com/')   #用獲取到的鏈接,和實際鏈接做對比,看是不是相等
22 
23 '''if __name__ == '__main__'的意思是:當.py文件被直接運行時,if __name__ == '__main__'之下的代碼塊將被運行;
24 當.py文件以模塊形式被導入時,if __name__ == '__main__'之下的代碼塊不被運行。'''
25 if __name__ == '__main__':
26     unittest.main(verbosity=2)

接下來是第二個用例模塊的代碼:

 

 1 import unittest
 2 from selenium import webdriver
 3 
 4 class baidu_test_2(unittest.TestCase):
 5     @classmethod
 6     def setUp(cls):
 7         cls.driver=webdriver.Chrome()
 8         cls.driver.maximize_window()
 9         cls.driver.implicitly_wait(15)
10         cls.driver.get(r'http://www.baidu.com')
11 
12     @classmethod
13     def tearDown(cls):
14         cls.driver.quit()
15 
16     def test_baidu_enabled(self):
17         so=self.driver.find_element_by_id('kw')    #檢查元素是否可編輯用is_enabled(),可以編輯返回的是True
18         self.assertTrue(so.is_enabled())   #如果返回的是True,那麼就是真真為真~通過
19 
20     def test_baidu_sousuo(self):
21         so = self.driver.find_element_by_id('kw')
22         so.send_keys('你好中國')  #上面的代碼選擇了輸入框,這是輸入:send_keys()
23         self.driver.find_element_by_id('su').click()   #該方法是模擬點擊操作click()
24         print(so.get_attribute('value'))     #根據屬性獲取表單中的值get_attribute('value')
25         self.assertEqual(so.get_attribute('value'),'你好中國')       #我們用獲取到的值,和我們預期的值做對比,看是否相等
26 
27 if __name__ == '__main__':
28     unittest.main(verbosity=2)

 

註意:測試模塊的名稱,前面需要統一,看圖:兩個測試用例模塊文件的名字前面都是test_  開頭

接下來就是最後一個模塊文件的代碼,批量執行用例模塊中的代碼:

 1 import unittest    #導入unittest
 2 import os       #導入前面學習的os庫,方便獲取文件路徑
 3 
 4 def allTests():
 5     suite=unittest.TestLoader().discover(            #實例化測試套件
 6         start_dir=os.path.dirname(__file__),         #start_dir=該參數是discover()方法中的,後面的參數是需要批量執行的用例模塊路徑
 7         pattern='test_*.py',                         #pattern=該參數是discover()方法中的,後面的參數是所有需要執行的用例前面是test_,後半部分用*號代替的.py文件
 8         top_level_dir=None)                          #top_level_dir=該參數是discover()方法中的,固定格式:top_level_dir=None
 9     return suite                                     #記住返回測試套件
10 
11 def run():                                           #運行
12     unittest.TextTestRunner(verbosity=2).run(allTests())           #測試報告
13 
14 if __name__ == '__main__':
15     run()

批量執行就是這樣的~~~~

總結:

1、 #檢查元素是否可編輯用is_enabled(),可以編輯返回的是True,否則是Flase
2、在編輯框中輸入內容用:send_keys()
3、點擊按鈕的操作可以用:click()
4、根據屬性獲取表單中的值get_attribute('value') 比如搜索中的內容
5、獲取當前頁面的url鏈接地址: driver.current_url 來判斷我們跳轉的頁面是否正確
6、批量執行用例用到的unitest庫中的TestLoader()類,該類中的discover(start_dir, pattern=’test*.py’, top_level_dir=None)方法

discover中可以看出有三個參數:以下是百度給大家的輪子~~~自行學習

start_dir :要測試的模塊名或測試用例目錄。 pattern='test*.py' :表示用例文件名的匹配原則。星號“*”表示任意多個字元。(test*.py是以test開頭) top_level_dir=None:測試模塊的頂層目錄。如果沒頂層目錄(也就是說測試用例不是放在多級目錄中),預設為 None。
原文鏈接:https://blog.csdn.net/weixin_40569991/article/details/81155145
-------------來自自學的總結,希望對大家有幫助,不會的朋友可以留言,一起進步~~~~~秋天來了,註意季節轉換,容易生病~~~~~~貼秋膘

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.位元組流: FileInputStream(位元組輸入流) 特有方法: FileInputStream fis = new FileInputStream("temp.txt"); 1.int num = fis.available();//返迴文件的位元組總個數 2.fis.read()//返回in ...
  • 在上一篇文章《SpringBoot進階教程(六十)intellij idea project下建多個module(上)》中,我們已經介紹了在intellij idea中創建project之後再分化多個module,今天再大致介紹介紹各個module之間詳細工作的細分。 如果是不考慮細分多個modul... ...
  • 1.Writer:字元輸出流 Writer: FileWriter BufferedWriter:newLine()//換行 簡單步驟: FileWriter fw=new FileWriter("e:\\t.txt"); fw.write("hello");//寫入到內部的緩衝區,是一個位元組數組 ...
  • 1.Map:獨立的介面 HashMap:使用的是哈希表,保證鍵不重覆依據: int hashCode() boolean equals(Object obj) TreeMap:使用的是二叉樹,根據鍵排序,Comparable<E> int compareTo(E e) Comparator<E> i ...
  • Django之ORM-model模型屬性,內容包括項目準備,其中包括a標簽中url的/,Django ORM小結;包括 欄位屬性和選項,其中包括 模型類屬性命名限制,欄位類型,選項等;包括 單表查詢,其中包括 配置MySQL的日誌文件,查詢函數,Q對象,F對象,聚合函數,查詢集等內容。 ...
  • 1.Collection List 有序,可重覆,可以操作下標 | ArrayList: | LinkedList:Node(數據,地址) | Vector Set 無序,不可重覆,不可以操作下標 | HashSet:哈希表(根據哈希值確定對象的存儲位置) | add() int hashCode( ...
  • Python 入門之流程式控制制語句 if判斷 while迴圈 for迴圈 ...
  • 立刻像專業人士一樣構建API 組織正在改變他們已經在軟體應用項目中成功的微服務架構模型,這就是大多數微服務項目使用 (應用程式介面)的原因。 我們要為微服務喝彩,因為它相對於其他的模型有各種先進的特性。 與此類似,這些數據存儲區具有獨立的命令來處理每個數據存儲區;此外,它還允許軟體提供商更快地部署組 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...