C#建立測試用例系統(tǒng)的示例代碼
引言
很多時候,需要對類中的方法進行一些測試,來判斷是否能按要求輸出預期的結果。
C#提供了快速創(chuàng)建單元測試的方法,但單元測試不僅速度慢不方便,大量的單元測試還會拖慢項目的啟動速度。
所以決定自己搞個方便的測試用例。
控制臺調(diào)用
只需要簡簡單單的一句話
測試用例.注冊并Print(EnumEx.Name);
結果畫面

測試用例的實現(xiàn)
/// <summary>
/// 提供測試用例的注冊和運行功能,用來比對結果和預期值是否相同,向控制臺輸出結果。
/// </summary>
public class 測試用例 {
/// <summary>
/// 測試的方法
/// </summary>
public Func<string> 方法 { get; set; }
/// <summary>
/// 測試名稱
/// </summary>
public string 名稱 { get; set; }
/// <summary>
/// 期望得到的結果string
/// </summary>
public string 期望值 { get; set; }
/// <summary>
/// 新建一個測試
/// </summary>
/// <param name="v名稱">測試名稱</param>
/// <param name="v期望值">期望得到的結果string</param>
/// <param name="v方法">測試的方法</param>
public 測試用例(string v名稱, string v期望值, Func<string> v方法) {
名稱 = v名稱;
期望值 = v期望值;
方法 = v方法;
}
/// <summary>
/// 儲存所有注冊的方法。
/// </summary>
public static OrderedDictionary<string, 測試用例> 方法冊 = new OrderedDictionary<string, 測試用例>();
/// <summary>
/// 將「返回值為string的方法〈Func<string>〉」注冊到「方法冊」中。
/// </summary>
/// <param name="測試用例">要注冊的測試</param>
/// <returns>返回是否注冊成功</returns>
public static bool 注冊(測試用例 測試用例) {
return 方法冊.添加(測試用例.名稱, 測試用例);
}
/// <summary>
/// 運行指定名稱的測試并返回運行結果〈<see cref="string"/>〉
/// </summary>
/// <param name="名稱">方法注冊到測試的名稱</param>
/// <returns>返回運行結果〈<see cref="string"/>〉</returns>
public static string 運行(string 名稱) {
if (方法冊.有鍵(名稱)) {
return 方法冊[名稱].方法.Invoke();
} else {
return 名稱 + " : 不存在該方法!";
}
}
/// <summary>
/// 注冊并向控制臺輸出運行結果。
/// </summary>
/// <param name="測試用例"></param>
public static void 注冊并Print(測試用例 測試用例) {
if(方法冊.添加(測試用例.名稱, 測試用例)) {
Print(測試用例.名稱);
}
}
/// <summary>
/// 向控制臺輸出運行結果。
/// </summary>
/// <param name="測試用例"></param>
public static void Print(測試用例 測試用例) {
Print(測試用例.名稱);
}
/// <summary>
/// 向控制臺輸出運行結果。
/// </summary>
/// <param name="名稱"></param>
public static void Print(string 名稱) {
string 結果 = 運行(名稱);
string 期望 = 方法冊[名稱].期望值;
Console.WriteLine(名稱 + "\r\nResult: "+ 結果);
Console.Write("期望值: " + 期望);
if (結果 == 期望) {
var c = Console.ForegroundColor;
Console.ForegroundColor = ConsoleColor.Green;
Console.WriteLine(" [TRUE]");
Console.ForegroundColor = c;
} else {
var c = Console.ForegroundColor;
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine(" [FALSE]");
Console.ForegroundColor = c;
}
}
}
它可以方便的測試某個方法的返回string是否等于設定期望值
可以輸出到控制臺,也可以保存在string。
要測試的類,位于項目 namespace:
//************************************************************
/// <summary>
/// ◇ 增強 枚舉〖System.Enun〗的擴展功能。
/// </summary>
/// <seealso cref="Enum"/>
/// <remarks></remarks>
//************************************************************
public static class EnumEx {
//=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
/// <summary>
/// 返回枚舉 「thisEnum」 的定義名稱〈<see cref="string"/>〉
/// </summary>
/// <param name="thisEnum">該枚舉自身</param>
/// <returns>〈string〉返回枚舉的定義名稱</returns>
public static string Name(this Enum thisEnum) {
return Enum.GetName(thisEnum.GetType(), thisEnum);
}
測試用例是這樣的,把它放到項目.Test namespace中以避免重名:
這里填入要顯示的名稱、期望值、方法體。
- 方法體的返回參數(shù)必須為 string
- 兩個用例名稱不能相同否則會覆蓋。
/// <summary>
/// EnumEx的測試用例。
/// </summary>
public class EnumEx {
/// <summary>【測試用例】EnumEx.Name() </summary>
public static 測試用例 Name = new 測試用例("EnumEx.Name - UriComponents.Path.Name()", "Path", NameFunc);
/// <summary>【測試方法】UriComponents.Path調(diào)用EnumEx.Name() 返回值 ➤ "Path" </summary>
/// <returns>返回值應該等于"Path"</returns>
public static string NameFunc() { return UriComponents.Path.Name(); }
}
最后在新建控制臺應用程序,就叫項目.Test,這樣測試有關內(nèi)容處在相同namespace,直接調(diào)用就行了
以上就是C#建立測試用例系統(tǒng)的示例代碼的詳細內(nèi)容,更多關于C#建立測試用例系統(tǒng)的資料請關注腳本之家其它相關文章!
- 使用 BenchmarkDotNet 對 C# 代碼進行基準測試
- 關于Unity C# Mathf.Abs()取絕對值性能測試詳解
- C#使用base64對字符串進行編碼和解碼的測試
- C#使用String和StringBuilder運行速度測試及各自常用方法簡介
- 詳解C# WebApi 接口測試工具:WebApiTestClient
- c# 插入數(shù)據(jù)效率測試(mongodb)
- 京東聯(lián)盟C#接口測試示例分享
- C#/.Net 中快速批量給SQLite數(shù)據(jù)庫插入測試數(shù)據(jù)
- C#代碼性能測試類(簡單實用)
- C#控制臺下測試多線程的方法
- c#測試反射性能示例
- c#測試本機sql運算速度的代碼示例分享
- C# 單元測試全解析
相關文章
C#實現(xiàn)的封裝CURD到SqlHelper類用法簡單分析
這篇文章主要介紹了C#實現(xiàn)的封裝CURD到SqlHelper類用法,涉及數(shù)據(jù)庫相關配置方法及SqlHelper類的簡單使用技巧,代碼中包含了較為詳盡的注釋便于理解,需要的朋友可以參考下2017-11-11
在C#中List集合使用First()方法獲取第一個元素的操作
這篇文章主要介紹了在C#中List集合使用First()方法獲取第一個元素的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12

