Nunit 2.5.5的使用总结

2024-04-28 04:48
文章标签 总结 使用 2.5 nunit

本文主要是介绍Nunit 2.5.5的使用总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

引入必要的命名空间:
using NUnit.Framework;

 

引用组件:
nunit.framework.dll

 

1.使用Unit的最佳实践:
a.新建一个名为Test的souce folder, 用于存放测试类源代码。
b.目标类与测试类应该位于同一个包下面,这样测试类就不必导入源代码所在的包,因为他们位于
同一包下面。
c.测试类命名规则:假如目标类是Culculator,那么测试类应该命名为TestCalculator或者是CalculatorTest

 

2.Xunit的口号:Keep the bar green to keep the code clean.

 

3.单元测试不是为了证明你是对的,而是为了证明你没有错误。

 

4.测试用例:(Test Case) 是单元测试的一个很重要的方面。

 

5.单元测试主要是用来判断程序的执行结果与自己期望的结果是否一致。

 

6.测试方法需要满足如下原则:
a.  public的
b.  void的
c.  无方法参数
d.  方法名称必须以test开头
e.  方法前面要加上特性[Test]
f.   测试类的前面要加上[TestFixture]

 

7.TestCast之间一定要保持完全的独立性,不允许出现在任何的依赖关系。

 

8.我们不能依赖于测试方法的执行顺序。

 

9.DRY(Don't  Repeat Yourself),当你的测试中有重复代码出现时,可以用SeTup和TearDown两个特性,表示
在每个测试方法执行前,调用什么,每个测试方法执行结束之后调用什么.
private int a;
复制代码
private   int  b;

        
private  Calc calc;

        [SetUp]
        
public   void  init()
        {
            calc 
=   new  Calc();
            a 
=   10 ;
            b 
=   2 ;
        }

        [TearDown]
        
public   void  Destroy()
        {

        }
复制代码

10.关于SetUp与TearDown方法的执行顺序:

a.  setup
b.  testAdd
c.  teardown

11.测试之前是什么状态,测试执行完毕后就应该是什么状态,而不应该由于测试执行的原因导致

状态发生了变化。

13.测试类的私有方法时可以采取两种方式:

a.修改方法的访问修饰符,将private修改为default或public(但不推荐使用)
b.使用反射在测试类中调用目标类的私有方法(推荐)。
[Test]
复制代码
         public   void  TestAdd()
        {
            
try
            {
                Calc2 calc2 
=   new  Calc2();
                Type type 
=  calc2.GetType();
                MethodInfo method 
=  type.GetMethod( " Add " ,BindingFlags.NonPublic | BindingFlags.Instance);
                
object  result  =  method.Invoke(calc2,  new   object [] {  2 3  });
                Assert.AreEqual(
5 , result);

            }
            
catch  (Exception ex)
            {
               Assert.Fail();
            }
        }
复制代码

14.Test Suite(测试套件):可以将多个测试组合到一起,同时执行多个测试。

[TestFixture]
复制代码
     public   class  AllTests
    {
        
using  NUnit.Framework;
        
using  NUnit.Core;

        [Suite]
        
public   static  TestSuite Suite
        {
            
get
            {
                TestSuite suite 
=   new  TestSuite( " All Tests " );
                suite.Add(
new  Calc2Test());
                suite.Add(
new  LargestTest());
                suite.Add(
new  StackTest());

                
return  suite;
            }
        }
    }
复制代码
还有两种更为简单的方法:
其一:
复制代码
namespace  CalcTest
{
    
using  NUnit.Framework;

    [TestFixture]
    
public   class  AllTests
    {
        [Suite]
        
public   static  IEnumerable Suite
        {
            
get
            {
                ArrayList suite 
=   new  ArrayList();
                suite.Add(
new  Calc2Test());
                suite.Add(
new  LargestTest());
                suite.Add(
new  StackTest());
                
return  suite;
            }
        }
    }
}
复制代码
其二:
复制代码
namespace  CalcTest
{
    
using  NUnit.Framework;

    [TestFixture]
    
public   class  AllTests
    {
        [Suite]
        
public   static  IEnumerable Suite
        {
            
get
            {
                ArrayList suite 
=   new  ArrayList();
                suite.Add(
typeof (Calc2Test));
                suite.Add(
typeof (LargestTest));
                suite.Add(
typeof (StackTest));
                
return  suite;
            }
        }
    }
}
复制代码

15.在对数据库进行单元测试的时候,为了避免连接的重复建立,可以调用TestFixtureSetUp和TestFixtureTearDown两个特性:

[TestFixtureSetUp]
复制代码
         public   void  ConnectionSetup()
        {

        }

        [TestFixtureTearDown]
        
public   void  ConnectionDestroy()
        {

        }
复制代码

16.当在单元测试中,想不执行某个单元测试方法时,可以用Ignore特性,表示不永远不会被执行:

[Test]
复制代码
        [Ignore( " This case is ignored. " )]
        
public   void  TestSubtract()
        {
            
int  actual  =  calc.Subtract(a, b);
            
int  expect  =   8 ;
            Assert.AreEqual(expect, actual);
        }
复制代码

17.当在单元测试中,如果不想对某个方法进行单元测试,只是在它被选中时才进行测试的话,可以调用Explicit特性

[Test]
复制代码
        [Explicit]
        
public   void  TestMultiple()
        {
            
int  actual  =  calc.Multiple(a, b);
            
int  expect  =   20 ;
            Assert.AreEqual(expect, actual);
        }
复制代码

18.如果要对测试方法进行分组时,可以用Category特性

[Test]
复制代码
        [Category( " GroupA " )]
        
public   void  TestAdd()
        {
            
int  actual  =  calc.Add(a, b);
            
int  expect  =   12 ;
            Assert.AreEqual(expect,actual);
        }

        [Test]
        [Category(
" GroupA " )]
        
public   void  TestSubtract()
        {
            
int  actual  =  calc.Subtract(a, b);
            
int  expect  =   8 ;
            Assert.AreEqual(expect, actual);
        }

        [Test]
        [Category(
" GroupB " )]
        
public   void  TestMultiple()
        {
            
int  actual  =  calc.Multiple(a, b);
            
int  expect  =   20 ;
            Assert.AreEqual(expect, actual);
        }

        [Test]
        [Category(
" GroupB " )]
        
public   void  TestDevide()
        {
            
int  actual  =   0 ;
            
try
            {
                actual 
=  calc.Devide(a, b);
            }
            
catch  (Exception ex)
            {
                Assert.Fail();
            }

            
int  expect  =   5 ;
            Assert.AreEqual(expect, actual);
        }
复制代码

19.一个方法的测试可能要写很多个测试方法,这都是正常的:

一个冒泡排序类:
复制代码
namespace  Calculator
{
    
public   class  BubbleSortClass
    {
        
public   int [] BubbleSort( int [] array)
        {
            
if  ( null   ==  array)
            {
                Console.Error.WriteLine(
" Prameters shouldn't be null. " );
                
return   new   int [] { };
            }

            
for  ( int  i  =   0 ; i  <  array.Length  -   1 ++ i)
            {
                
bool  swap  =   false ;
                
for  ( int  j  =   0 ; j  <  array.Length  -  i  -   1 ++ j)
                {
                    
if  (array[j]  >  array[j  +   1 ])
                    {
                        
int  temp  =  array[j];
                        array[j] 
=  array[j  +   1 ];
                        array[j 
+   1 =  temp;
                        swap 
=   true ;
                    }
                }
                
if  ( ! swap)
                {
                    
return  array;
                }
            }

            
return  array;
        }
    }
}
复制代码
一个测试冒泡排序的类,尽可能的考虑到所有的情况:
复制代码
namespace  CalcTest
{
    
using  NUnit.Framework;

    [TestFixture]
    
public   class  BubbleSortTest
    {
        BubbleSortClass bubble;

        [SetUp]
        
public   void  Init()
        {
            bubble 
=   new  BubbleSortClass();
        }

        [Test]
        
public   void  TestBubbleSort()
        {
            
int [] array  =  {  1 4 8 4 9 5 7 4 - 10  };
            
int [] result  =  bubble.BubbleSort(array);
            
int [] expect  =  {  - 10 1 4 4 4 5 7 8 9  };

            Assert.AreEqual(expect, result);
        }

        [Test]
        
public   void  TestBubbleSort2()
        {
            
int [] arr  =   null ;
            
int [] result  =  bubble.BubbleSort(arr);
            
int [] expect  =  { };
            Assert.AreEqual(expect, result);
        }

        [Test]
        
public   void  TestBubbleSort3()
        {
            
int [] arr  =  { };
            
int [] result  =  bubble.BubbleSort(arr);
            
int [] expect  =  { };
            Assert.AreEqual(expect, result);
        }
    }
}
复制代码

20.如果你期望你的测试方法能抛出异常,可以用ExpectedException特性,它通常用于异常的测试:

[Test]
复制代码
        [ExpectedException( typeof (DivideByZeroException))]
        
public   void  TestDevideByZero()
        {
            
int  actual  =   0 ;

            actual 
=  calc.Devide( 2 0 );
        }
复制代码

21.当你而要对一个测试方法进行多组数据测试时,可以用一个文件将数据保存起来,然后编写程序去读取

,达到多组数据测试的目的,方式比较灵活,可以用xml,txt等格式.
首先写一个要测试的类:
复制代码
namespace  Calculator
{
    
public   class  Largest
    {
        
public   int  GetLargest( int [] array)
        {
            
if  ( null   ==  array  ||   0   ==  array.Length)
            {
                
throw   new  Exception( " 数组不能为空! " );
            }

            
int  result  =  array[ 0 ];
            
for  ( int  i  =   0 ; i  <  array.Length; i ++ )
            {
                
if  (result  <  array[i])
                {
                    result 
=  array[i];
                }
            }

            
return  result;
        }
    }
}
复制代码
然后写单元测试:
复制代码
namespace  CalcTest
{
    
using  NUnit.Framework;
    
using  System.IO;

    [TestFixture]
    
public   class  LargestTest2
    {
        Largest largest ;

        [SetUp]
        
public   void  init()
        {
            largest 
=   new  Largest();
        }

        [Test]
        
public   void  TestGetLargest()
        {
            var lines 
=  File.ReadAllLines( " http://www.cnblogs.com/LargestTest.txt " );

            
foreach  (var line  in  lines)
            {
                
if  (line.StartsWith( " # " ))
                {
                    
continue ;
                }

                
string [] arr  =  line.Split( '   ' );

                
int  expect  =  Convert.ToInt32(arr[ 0 ]);

                var list 
=   new  List < int > ();
                
int  temp = 0 ;
                
for  (var i  =   1 ; i  <  arr.Length;  ++ i)
                {
                    temp 
=  Convert.ToInt32(arr[i]);
                    list.Add(temp);
                }

                
int [] finalArr  =  list.ToArray();

                
int  result  =  largest.GetLargest(finalArr);
                Assert.AreEqual(expect, result);
            }
        }

    }
}
复制代码

22.如果想要让Nunit和Visaul Studio无缝地集成,用TestDriven,可以到TestDriven.net下载.

功能远比Nunit强大.有的公司要求测试的覆盖率,TestDriven就提供了这个功能.
除些之外它还支持测试调试,这个功能还是不错的,.当你写的测试方法有问题时,它就派上用场了.
还可以直接在net输出窗口输出测试结果等.
博文出自:http://www.cnblogs.com/anllin/articles/2006181.html

这篇关于Nunit 2.5.5的使用总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942359

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四