Test 版中的疑難排解
更新:2007 年 11 月
當您測試程式碼時,某些狀況會產生錯誤或警告,甚至導致測試失敗。本主題會說明其中某些狀況,以及解決它們所採取的步驟。
測試執行疑難排解
造成測試無法執行的狀況,通常可以歸咎於部署測試檔案 (或其他執行測試所需的檔案) 失敗。
遠端測試。對於遠端測試,與遠端電腦的通訊問題也可能會造成錯誤。這些錯誤以及測試層級與執行層級的其他錯誤,在測試執行疑難排解中有所描述。
ASP.NET 單元測試。如果您的 ASP.NET 單元測試是在 IIS 處理序中執行,基於安全性的目的,可以選擇將 ASP.NET 處理序當成「非預設使用者」(Non-default User) 執行,也就是以不同的處理序識別執行。在此狀況下,測試執行可能失敗。如需詳細資訊,請參閱ASP.NET 單元測試概觀。
連同您的測試一起部署檔案。部署錯誤通常都顯示在 [測試回合詳細資料] 頁中,而不是在失敗之個別測試的 [測試結果詳細資料] 頁面上。因此,可能不容易了解個別測試失敗的原因。如需詳細資訊,請參閱測試部署概觀中的<測試部署疑難排解>章節。
Web 測試疑難排解。當您執行 Web 測試時,可能會發生各種錯誤。造成這些錯誤的原因可能是遺漏資料繫結屬性 (Attribute)、安全性設定的問題,或嘗試存取防火牆以外的網站。如需詳細資訊,請參閱Web 測試疑難排解。
負載測試疑難排解。當您執行負載測試時,可能會發生各種錯誤。造成這些錯誤的原因可能是負載測試資料庫的問題、負載測試的計數器集合的問題、Rig 設定錯誤,或者負載測試所包含的其中一個測試有問題。如需詳細資訊,請參閱負載測試疑難排解。
資料驅動的單元測試疑難排解。當您執行資料驅動的單元測試時,可能會遭遇連接、驗證、部署或其他問題。請使用資料驅動的單元測試疑難排解中的資訊解決這些問題。
重新簽署強式名稱組件
當您執行單元測試時,就是在二進位檔中測試程式碼。您可以藉著「檢測」(Instrument) 該二進位檔,在測試執行時收集程式碼涵蓋範圍資訊;請參閱 HOW TO:取得程式碼涵蓋範圍資料。檢測的程序會將產生程式碼涵蓋範圍資訊的程式碼加入至二進位檔中。
如果您測試的二進位檔是強式名稱組件,檢測所造成的程式碼修改會使其簽署失效。因此在檢測步驟之後,Visual Studio 會立即自動嘗試重新簽署組件。如需強式名稱組件的詳細資訊,請參閱強式名稱的組件。
有很多狀況可能會造成重新簽署失敗。如需如何解決這些狀況的詳細資訊,請參閱檢測及重新簽署組件。
程式碼涵蓋範圍資料和 VSPerfMon.exe
如果您執行 VSPerfMon.exe 時,同時執行要收集程式碼涵蓋範圍資料的測試,則會發生下列事件:
如果您以 TRACE 或 SAMPLE 選項執行 VSPerfMon,則同時間執行的測試回合將會失敗,而且在 [測試回合詳細資料] 頁上會報告錯誤。
如果您是以 COVERAGE 選項執行 VSPerfMon.exe,VSPerfMon.exe 處理序便會中止。
對於這兩種狀況,解決辦法是避免同時執行 VSPerfMon.exe 和您要收集程式碼涵蓋範圍資料的測試。如需 VSPerfMon.exe 工具的詳細資訊,請參閱 VSPerfMon。
這會在何時發生?
執行 VSPerfMon 的最常見狀況如下:
您已啟動程式碼剖析工作階段,該剖析工作階段可能是在 Visual Studio 的執行個體中,而不是在您要執行測試的執行個體。
您藉由直接執行 VSPerfMon.exe 或使用 (更常見的) 包裝函式 VSPerfCmd.exe 收集程式碼涵蓋範圍資料或程式碼剖析資料。
程式碼涵蓋範圍資料並未正確出現
如果您已要求針對您的測試收集程式碼涵蓋範圍資料,但卻未出現,或所顯示的與您的期望不同,可能是發生以下其中一種狀況:
**沒有程式碼涵蓋範圍資料出現。**在測試執行期間,特定的二進位檔 (例如 COM DLL) 是由其原始位置載入,而不是由測試部署目錄載入。這類二進位檔必須就地檢測,否則,即使測試執行成功而且沒有產生執行層級警告,也不會收集程式碼涵蓋範圍資料。如需詳細資訊,請參閱選擇檢測資料夾。
程式碼涵蓋範圍反白顯示未出現。當您執行測試、收集程式碼涵蓋範圍資料,然後檢視測試結果時,Visual Studio 會在原始程式碼檔中,將測試回合中測試的程式碼以反白顯示方式指示出來。您可以選擇指示已涵蓋之程式碼、未涵蓋之程式碼和部分涵蓋之程式碼的顏色。如果這個反白顯示全部或部分未出現,請確認所選顏色與原始程式碼檔的背景顏色是否不同。如需選擇反白顯示之顏色的詳細資訊,請參閱 HOW TO:取得程式碼涵蓋範圍資料中的<變更程式碼涵蓋範圍資料的顯示>。
**程式碼涵蓋範圍資料合併不正確。**您可以合併含有一個或多個 ASP.NET 測試回合的結果,但是 [程式碼涵蓋範圍結果] 視窗會在 [合併結果] 下以個別節點顯示 ASP.NET 資料,而不會以單一、合併的節點顯示。如需詳細資訊,請參閱使用合併的程式碼涵蓋範圍資料。
**合併的程式碼涵蓋範圍資料並未全部顯示。**當您合併程式碼涵蓋範圍資料之後,可以將它以 XML 檔的格式匯出至磁碟中。如果您重新匯入這個檔案,然後將它與其他資料合併,那麼並非所有統計資料都會顯示。如需詳細資訊,請參閱使用合併的程式碼涵蓋範圍資料。
程式碼涵蓋範圍資料未匯入。Visual Studio 必須能夠找到磁碟上的特定檔案,才能匯入程式碼涵蓋範圍資料。如需詳細資訊,請參閱使用合併的程式碼涵蓋範圍資料。
已檢測的二進位檔被覆寫。您嘗試從手動測試期間所執行的程式中,收集程式碼涵蓋範圍資料。如果您使用 CTRL+F5 啟動該程式,CTRL+F5 動作會導致該程式的二進位檔重新建置。這會覆寫已檢測的二進位檔,也就是無法收集程式碼涵蓋範圍資料。
如需收集程式碼涵蓋範圍資料的一般資訊,請參閱 HOW TO:取得程式碼涵蓋範圍資料。
加入測試方法時的效能問題
當您加入新測試方法時,同時會執行背景處理,將此測試方法加入 [測試檢視] 視窗和 [測試清單編輯器] 中。因此,您可以立即看到它。如果單一測試類別或整個專案中有許多測試方法,當您將新測試方法加入這個測試類別時,可能會遇到這個自動處理功能所造成的效能問題。
如果您遇到這個效能問題,有三個可能的解決方法:
您可以將測試類別分割為部分類別,將測試方法分配在部分類別中。這會減少單一測試類別中的方法數目,並會在加入測試方法時改善效能。
您可以建立新的測試專案,將部分測試類別移至這個新測試專案,然後從原始測試專案移除這些測試類別。這會減少單一組件中的測試方法數目,並改善效能。
您也可以選擇關閉將測試方法加入 [測試檢視] 視窗和 [測試清單編輯器] 中的背景處理功能。這會改善加入測試方法時的效能。不過,設定這個選項時,除非編譯包含測試方法的類別,然後在 [測試檢視] 視窗或 [測試清單編輯器] 中按一下 [重新整理],否則在 [測試檢視] 視窗或 [測試清單編輯器] 中看不到測試方法。
注意事項: 設定這個選項時,會在編譯時期發現新測試方法。這會增加編譯方案的總時間。
若要停用測試方法的自動探索
在 [工具] 功能表上按一下 [選項]。
[選項] 對話方塊隨即出現。
展開左方窗格的 [測試工具],然後按一下 [測試專案]。
選取 [停用測試方法背景探索],停用測試方法的自動探索。
注意事項: 設定這個選項時,除非編譯包含測試方法的類別,否則在 [測試檢視] 視窗或 [測試清單編輯器] 中看不到加入任何測試類別的任何測試方法。