系列目录
使用前面讲过的方法基本上能够完成工作中的大部分任务了, 然而有些功能实现起来还是比较麻烦的, 比如说字符串相等性比较不区分大小写, 字符串是否匹配某一正则规则, 集合中的每一个 (某一个) 元素是否符合特定规则等, Nunit 提供了一些特定的方法用来实现一些用普通断言比较难以实现的扩展类型和方法.
下面介绍一下 StringAssert 类型下面的方法
StringAssert.AreEqualIgnoringCase(string expected,string actual)
此方法用于断言两个字符串在不区分大小写情况下是否相等, 需要提供两个参数, 第一个是期待的结果, 第二个是实际结果. 这个方法比较简单, 不再提供示例.
需要注意的是 Nunit 里有许多需要提供两个参数的方法, 一般情况下都是第一个是期待的结果, 第二个是实际结果
StringAssert.Contains
用于断言一个字符串是否包含另一字符串, 其中第一个参数为被包含的字符串, 第二个为实际字符串, 这个方法语义不是特别明确, 需要注意
- [Test]
- public void DemoTest()
- {
- StringAssert.Contains("hello", "hello,world");
- }
这段代码片段会返回成功
StringAssert.StartsWith
用于断言字符串是否以某 (几) 字符开始
- [Test]
- public void DemoTest()
- {
- StringAssert.StartsWith("h", "hello,world");
- }
- StringAssert.EndsWith
与 StringAssert.StartsWith 类似, string 类也有此方法, 相信大家都比较熟悉
StringAssert.IsMatch
用于断言指定字符串是否匹配某一正则规则
[warning]这个方法并没有大小写开关
下面介绍两个与文件 (目录) 有关的断言类 FileAssert 和 DirectoryAssert. 两个类下面的断言方法基本一样, 只是一个是断言文件, 一个是断言目录. 下面以 FileAssert 为例说明
FileAssert.AreEqual
这个方法用于断言两个文件是否是同一个文件, 接受字符串参数
需要说明的是, 字符串路径必须指向文件, 而不能是目录或者不存在的文件.
FileAssert.Exists
用于断言某个文件是否存在, 接受字符串参数或者 FileInfo 作为参数
DirectoryAssert 方法类似, 并且这些方法都对应的有相反方向的断言, 方法名包含 Not, 很容易理解
单元测试过程中, 我们很多时候都要处理集合, Nunit 里提供了一个 CollectionAssert 类用于处理对集合类型的断言
下面介绍一下这个类下面的断言方法
CollectionAssert.AllItemsAreInstancesOfType
用于断言集合里面的元素是否都是某一特定类型.
- [Test]
- public void DemoTest()
- {
- ArrayList ar = new ArrayList {"a", "b", "c"};
- CollectionAssert.AllItemsAreInstancesOfType(ar, typeof(string));
- }
以上断言会返回成功, 因为我们向 ArrayList 里添加的全是 string 类型的元素
需要注意, 很多断言方法第一个参数是期待类型, 第二个是实际类型, 而此方法则相反, 第一个是实际集合, 第二个是期待的类型
这里的类型支持父类, 比如说如果是 typeof(object)也同样能通过, 语义上来讲, 元素是 string 类型, 也是 object 类型, 讲得通的
CollectionAssert.AllItemsAreNotNull
用于断言集合里的元素全部不是 Null, 也即集合不包含 null 元素, 这个方法只有一个参数, 传入我们要判断的集合即可
CollectionAssert.AllItemsAreUnique
用于断言集合里面的元素全部是惟一的, 即集合里没有重复元素.
[warning]需要注意的是, 这个方法并没有提供一个重载支持自定义比较器, 它只能用于断言简单类型, 如 string,int,datetime 等是否惟一, 如果是类类型则需要重载 equals 和 gethashcode 但是通常我们并不这样做, 而是在类外部提供一个比较器, 如果判断复杂类型是否惟一, 我们在以后再介绍
下面举一个例子说明这个问题
- [Test]
- public void DemoTest()
- {
- Person[] psn = new Person[] {
- new Person { Name="sto",Age=32,BirthDay=DateTime.Today.AddYears(-10)},
- new Person { Name="sto",Age=32,BirthDay=DateTime.Today.AddYears(-10)}};
- CollectionAssert.AllItemsAreUnique(psn);
- }
以上代码测试会通过, 因为两个 new 出来的 Persn 不是同一个对象, 但实际业务中, 两个对象的属性完全相等时我们就认为它们是相等的, 以上我们期待的结果是 不通过
CollectionAssert.AreEqual
用于断言两个集合是否相等, 如果两个集合里的元素都是简单对象, 如果是复杂对象用这个方法并不是很方便(虽然此方法提供提供 IComparer 作为参数, 然而 IComparer 对集合并不是很方便)
[warning]这里的两个集合相等第一集合元素个数必须相等(不用多说), 第二集合元素的顺序必须一致的
还有一点需要说明还有一点需要说明, 如以上所说, 两个集合元素顺序一致, 并且在运行时类型是一致的就会被认为是相等, 这两个集合的类型不必一样, 比如说一个是 array, 一个是 list, 泛型参数也不必须一样
只要在运行时类型是一致的即可
请看下面一段代码
- [Test]
- public void DemoTest()
- {
- int[] a = {3, 4, 5};
- List<object> b =new List<object> {3, 4, 5};
- CollectionAssert.AreEqual(a, b);
- }
a 和 b 两个集合的集合类型不一样, 泛型类型也不一样, 但是运行的时候却是一样的, 因此以上代码执行会返回成功状态
CollectionAssert.AreEquivalent
这个方法用来判断两个集合的元素是否等价, 如果两个集合元素类型相同, 个数也相同, 即视为等价, 与上面的方法相比, 它不关心顺序
- [Test]
- public void DemoTest()
- {
- int[] a = {3, 4, 5};
- List<object> b =new List<object> {4,3, 5};
- CollectionAssert.AreEquivalent(a, b);
- }
以上代码测试是通过的
CollectionAssert.Contains
用于断言集合是否包含某一元素
需要说明的是. 要判断集合中是否包含某一元素, 只要集合运行时有特定元素和指定元素类型相同, 并且值相同, 即认为集合包含这一元素
请看以下代码片段
- [Test]
- public void DemoTest()
- {
- int[] a = {3, 4, 5};
- object element = 4;
- List<object> b =new List<object> {element,3, 5};
- CollectionAssert.Contains(b, 4);
- }
以上代码段中 b 集合虽然不包含值为 4 的 int 类型元素, 只有 object 类型的值为 4 的元素, 然而它在运行时真正的类型是 int, 因此以上测试也是通过的.
CollectionAssert.IsEmpty
用于断言某一集合是空集合, 即元素个数为 0
CollectionAssert.IsOrdered
用于断言集合元素是否按正序排列, 所谓正序列, 是指按阿拉伯数字或者字符表顺序正序排列.
CollectionAssert.IsSubsetOf
用于判断一个集合是否为另一个集合的子集, 与以上相同的是, 这两个集合不必是同一类集合(可以一个是 array, 一个是 list), 只要一个集合的元素完全包含在另一个集合中, 即认为它是另一个集合的子集
只要一个集合元素完全包含在另一个集合中即可, 顺序不必相同
CollectionAssert.IsSupersetOf
用于断言一个集合是否是另一个集合的父集, 与子集判断用法一样.
以上大部分方法都有一个判断相反的方法, 名称中多一个 Not, 这里不再罗列
来源: https://www.cnblogs.com/tylerzhou/p/11300896.html