嵌入式智能設備的測試研究方法
1 前言
智能軟件Agent是能夠為用戶執行特定的任務、具有一定程度的智能、能夠自主的執行部分任務并以一種合適的方式和環境相互作用的軟件程序。Agent 有自主性、響應性、學習能力和社會性等特性。這使得它適合在高度動態的環境下做出及時的響應。
嵌入式技術和新一代移動通訊網絡的發展使得嵌入式智能設備大量的涌現。這些設備的大都具有嵌入式操作系統的支持, 并運行著越來越豐富的應用程序。如何對這些應用程序進行測試,就成為一個需要研究的課題。本文將Agent技術引入嵌入式智能設備的測試中,使用目標設備Agent, 測試控制Agent, 網絡環境Agent分別模擬和處理測試設備,測試工程師和測試環境的復雜性,利用Agent自身具有的特點,提出了一種有效的自動化測試的方法。
2 相關的研究及本文的思路
Agent 所具有的自主性、響應性、學習能力和社會性等特性,使得它很適合處理復雜測試系統中的問題。將Agent技術應用于測試領域已經有一些相關的研究,下面是具體的介紹。
Jeongeun Choi 和 Byoungju Choi [1]提出了一個基于Agent技術的測試工具,它通過使用用戶接口Agent來處理和測試者的交互,使用測試用例選擇Agent來進行測試用例的選擇,并使用回歸測試Agent進行回歸測試,從而很好的實現了自動化的軟件測試。但是他們提出的測試用例選擇技術僅能在大量已有的測試用例中選擇最佳的用例,不能減少編寫測試用例本身的復雜性。
另外一些研究將Agent 技術應用到了某一領域的測試中。Yu Qi、 David Hung 和 Eric Wong [3] 提出了一個基于Agent 技術的Web 應用程序測試方法。他們使用Agent技術降低了網絡應用測試的復雜性。他們的方法不僅僅適用于Web應用程序的測試,也適合于嵌入式智能設備的測試。
在實際測試過程中,測試人員很大的一項任務仍然是編寫各種測試用例,要真正的提高測試效率,就要提高測試腳本的通用性,減少測試腳本的變化[2] [4]。常見的嵌入式智能設備測試工具(比如TestQuest)使用圖像比對來判斷目標設備的狀態, 這種方法雖然實現了非侵入性的測試,但是存在兩個問題:
圖片的抓取和傳送消耗了大量測試資源.
不同手機的用戶界面風格變化很大,這使得測試腳本在用來進行新設備的測試時需要對腳本進行維護.
然而,實際的設備中,當重要的事件發生時,系統會產生敏感事件來激勵相關模塊進行處理.如果能夠在測試過程中捕獲這些敏感事件,就能更加高效的進行測試. 并且,只要操作系統相同,敏感事件的捕獲方式也是一樣,測試用例不會因為界面的變化而變化。本文用目標設備Agent抽象和捕獲測試過程中的敏感事件,并將敏感事件發送給測試控制Agent。而測試控制Agent收到敏感事件后,根據自己的知識,采取相應的動作的機制(如異常處理,重新調度測試等)加以處理。這正好可以作為Agent的推理規則,用Agent的智能性來屏蔽測試過程的復雜性。此外,考慮到目標設備處于復雜的網絡環境中,我們利用網絡環境Agent來控制目標設備所處的網絡信號,從而實現對設備所處網絡環境的控制。
3 基于Agent的測試系統
3.1 總體結構
測試系統的最終目標是實現一個移動數字終端的自動化測試平臺,能夠對移動數字終端上的系統軟件和應用層軟件建立模塊化、可重用的測試腳本庫,提高各種黑盒測試的效率,自動化測試結果的生成,并實現測試結果的回放。
評論