一、什么是自動化測試
1、自動化測試介紹
自動化測試指軟件測試的自動化,在預設狀態下運行應用程序或者系統,預設條件包括正常和異常,最后評估運行結果。將人為驅動的測試行為轉化為機器執行的過程。
自動化就相當于將人工測試手段進行轉換,讓代碼去執行。
自動化測試包括?UI?自動化,接口自動化,單元測試自動化。按照這個金字塔模型來進行自動化測試規劃,可以產生最佳的自貢話測試產出投入比(ROI),可以用較少的投入獲得很好的收益。
(1)單元測試
最大的投入應該在單元測試上,單元測試運行的頻率也更加高。
Java?的單元測試框架是?Junit。
(2)接口自動化測試
接口測試就是?API?測試,相對于?UI?自動化?API?自動化更加容易實現,執行起來也更穩定。
接口自動化的有以下特點:
- 可在產品前期,接口完成后介入。
- 用例維護量小。
- 適合接口變動較小,界面變動頻繁的項目。
常見的接口自動化測試工具有?RobotFramework、JMeter、SoapUI、TestNG+HttpClient、Postman 等。
(3)UI?自動化測試
雖然測試金字塔告訴我們盡量多做 API 層的自動化測試,但是 UI 層的自動化測試更加貼近用戶的需求和軟件系統的實際業務。并且有時候我們不得不進行 UI 層的測試。
A. UI 自動化的特點
- 用例維護量大。
- 頁面相關性強,必須后期項目頁面開發完成后介入。
- UI 測試適合與界面變動較小的項目。
B. UI 自動化測試的好處
- 降低大型系統的由于變更或者多期開發引起的大量的回歸測試的人力投入,這可能是自動化測試最主要的任務,特別是在程序修改比較頻繁,效果是非常明顯的,自動化測試前期人力投入較多,但后期進入維護期后,可節省大量人力,而手工測試后期需要增加大量人力用于回歸測試。
- 減少重復測試的時間,實現快速回歸測試。
- 創建優良可靠的測試過程,減少人為錯誤。
- 可以運行更多更繁瑣的測試。
- 可以執行一些手工測試困難或不可能進行的測試。
- 更好的利用資源。
- 測試腳本的重用性。
C.?UI?層自動化測試框架
UI 層的測試框架比較多,比如 Windows 客戶端測試的 AutoIT,Web 測試的 Selenium 以及 TestPlant eggPlant,Robot framework,QTP 等。
下面主要以 Web UI 自動化測試框架 Selenium 為例進行詳細介紹。
Selenium 有以下優點:
- 免費,也不用再為破解軟件而大傷腦筋。
- 小巧,對于不同的語言它只是一個包而已,而QTP 需要下載安裝1個多G 的程序。
- 這也是最重要的一點,不管你以前更熟悉C、java、ruby、python、或都是C# ,你都 可以通過 Selenium 完成自動化測試,而QTP 只支持 VBS。
- 支持多平臺:Windows、Linux、MAC ,支持多瀏覽器:IE、ff、Safari、Opera、Chrome。
- 支持分布式測試用例的執行,可以把測試用例分布到不同的測試機器執行,相當于分發機的功能。
D.?UI 自動化測試的適用對象
實施自動化測試的前提條件:需求變動不頻繁、項目周期足夠長、自動化測試腳本可重復使用。
- 產品型項目。產品型的項目,新版本是在舊版本的基礎上進行改進,功能變不大的項目,但項目的新老功能都必須重復的進行回歸測試。回歸測試是自動化測試的強項,它能夠很好的驗證你是否引入了新的缺陷,老的缺陷是否修改過來了。在某種程度上可以把自動化測試工具叫做回歸測試工具。
- 機械并頻繁的測試。每次需要輸入相同、大量的一些數據,并且在一個項目中運行的周期比較長,比如兼容性測試。
- 需求變動頻繁的項目,自動化腳本不能重復使用,維護成本太大,性價比低。
- 項目周期短,自動化腳本編制完成后使用次數不多,性價比低。
- 交互型較強的項目,需要人工干預的項目,自動化無法實施。
2、如何實施自動化測試
單純的講,自動化測試的具體實現,應該是包含下面七個過程的:
- 分析:總體把握系統邏輯,分析出系統的核心體系架構。
- 設計:設計測試用例,測試用例要足夠明確和清晰,覆蓋面廣而精
- 實現:實現腳本,有兩個要求一是斷言,二是合理的運用參數化。
- 執行:執行腳本遠遠沒有我們想象中那么簡單。腳本執行過程中的異常需要我們仔細的去分析原因。
- 總結:測試結果的分析,和測試過程的總結是自動化測試的關鍵。
- 維護:自動化測試腳本的維護是一個難以解決但又必須要解決的問題。
- 分析:在自動化測試過程中深刻的分析自動化用例的覆蓋風險和腳本維護的成本。
3、自動化測試需要了解的技能
- 了解被測試系統的基本業務
- 了解業務的技術框架
- 懂得功能測試
- 懂得一種編程語言
- 懂數據庫、操作系統
- 了解常見的測試框架
- ......
二、Selenium?介紹
Selenium?是 Web?應用中基于?UI?的自動化測試框架,支持多平臺、多瀏覽器、多語言。
早期的 Selenium RC?已經被現在的 WebDriver?所替代,可以簡單的理解為 Selenium1.0+WebDriver?構成現在的 Selenium2.0。現在我們說起 Selenium,一般指的是?Selenium2.0,它有由?Selenium IDE,WebDriver,Selenium Grid?組成。
1、Selenium IDE
Selenium IDE?一個用于?Selenium?測試的完成集成開發環境,可以直接錄制在瀏覽器的用戶操作,并且能回放,編輯和調試測試腳本。調試過程中可以逐步進行或調整執行的速度,并且可以在底部瀏覽日志出錯信息。錄制的測試腳本可以以多種語言導出,比如 Java、Python、C#、JavaScript、Ruby?等(豐富的 API),方便掌握不同語言的測試人員操作。
2、Selenium 原理
3、WebDriver
Selenium RC 在瀏覽器中運行 JavaScript 應用,會存在環境沙箱問題,而?WebDriver?可以跳出 JavaScript 的沙箱,針對不同的瀏覽器創建更健壯的,分布式的,跨平臺的自動化測試腳本。基于特定語言(Java,C#,Python,Ruby,Perl,JavaScript?等)綁定來驅動瀏覽器對Web元素進行操作和驗證。
(1)Webdriver 的工作原理
啟動瀏覽器后,Selenium-webdriver?會將目標瀏覽器綁定到特定的端口,啟動后的瀏覽器則作為 webdriver 的?remote server。
客戶端(也就是測試腳本),借助?ComandExecutor?發送?HTTP?請求給 Sever?端(通信協議:The WebDriver Wire Protocol,在?HTTP request?的?body?中,會以?WebDriver Wire?協議規定的?JSON?格式的字符串來告訴 Selenium,我們希望瀏覽器接下來做什么事情)。
Sever 端需要依賴原生的瀏覽器組件,轉化?Web Service?的命令為瀏覽器?native?的調用來完成操作。
3、Selenium Grid
Selenium Grid?是一個服務器,提供對瀏覽器實例訪問的服務器列表,管理各個節點的注冊和狀態信息。可以實現在同一時刻不同服務器上執行不同的測試腳本。
三、如何使用 Selenium IDE?錄制腳本
四、Selenium + Java?環境搭建
(Windows 電腦環境搭建 - Chrome 瀏覽器)
Chrome + Java(推薦)
1、下載 Chrome 瀏覽器
官網鏈接:Google Chrome 網絡瀏覽器
2、查看 Chrome 瀏覽器版本
3、下載 Chrome 瀏覽器驅動
官方鏈接:ChromeDriver - WebDriver for Chrome - Downloads (chromium.org)
這個頁面數據比較多,往下滑一下就可以看到驅動了,接著將對應的鏈接復制到 Chrome 瀏覽器下載。
4、配置系統環境變量 PATH
解壓下載好的驅動壓縮包,將下載好的 chromedriver.exe 放到 Chrome 瀏覽器安裝路徑下,這里以 Chrome 瀏覽器驅動為例:我的 Chrome 瀏覽器安裝路徑是路徑是:C:\Users\30318\AppData\Local\Google\Chrome\Application
5、驗證環境是否搭建成功
(1)創建 Java 項目,添加 pom 文件中添加依賴
<dependencies><!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-java --><dependency><groupId>org.seleniumhq.selenium</groupId><artifactId>selenium-java</artifactId><version>3.141.59</version></dependency>
</dependencies>
注意:這里的版本是 Selenium3,不是 Selenium4。?
(2)編寫代碼運行
import org.openqa.selenium.chrome.ChromeDriver;public class Main {public static void main(String[] args) {WebDriver webDriver = new ChromeDriver();webDriver.get("https://www.baidu.com");}
}
如果打開了瀏覽器,此時說明安裝成功。?