RhinoMock入门(4)——次序和委托

简介: (一)次序(Ordered) 在rhinomock中,可以按次序调用方法。默认条件下,方法调用没有顺序。如果按次序录制,那么在调用方法时必须按录制时相同的次序进行。   请看: public interface ICustomer{   string ShowTitle(string ...

(一)次序(Ordered

rhinomock中,可以按次序调用方法。默认条件下,方法调用没有顺序。如果按次序录制,那么在调用方法时必须按录制时相同的次序进行。

 

请看:

public   interface  ICustomer
{
   string  ShowTitle( string  str);
   int  Unid {  get set ; }
   string  CustomerName {  get set ; }
   string  Address {  get set ; }
}

 

测试:

public   void  TestNoOrder()
{
    MockRepository mocks 
=   new  MockRepository(); 
    ICustomer customer 
=  mocks.StrictMock < ICustomer > (); 

    
// 默认条件下是没顺序的
    Expect.Call(customer.Unid).Return( 1 );
    Expect.Call(customer.CustomerName).Return(
" 宋江 " );
    Expect.Call(customer.Address).Return(
" 山东 " ); 

    mocks.ReplayAll(); 

    Assert.AreEqual(
" 宋江 " , customer.CustomerName);
    Assert.AreEqual(
1 , customer.Unid);
    Assert.AreEqual(
" 山东 " , customer.Address);
}

 

 

当使用次序时:

public   void  TestOrder()
{
    MockRepository mocks 
=   new  MockRepository(); 
    ICustomer customer 
=  mocks.StrictMock < ICustomer > ();
    
using  (mocks.Ordered())
    {
        Expect.Call(customer.Unid).Return(
1 );
        Expect.Call(customer.CustomerName).Return(
" 宋江 " );
        Expect.Call(customer.Address).Return(
" 山东 " );
    } 

    mocks.ReplayAll();

    Assert.AreEqual(
" 宋江 " , customer.CustomerName);
    Assert.AreEqual(
1 , customer.Unid);
    Assert.AreEqual(
" 山东 " , customer.Address);
}

 

这时,如果调用时没有按期望时的次序进行,那就会出错,抛出异常。

这种次序可以灵活使用,例如可以次序一个mock,然后期望条件达到后,再不按次序进行。注意:在进行回播前要退出次序。

 

(二)模拟委托

先定义委托:

public   delegate   void  DoThing( string  strMsg);

  

然后模拟委托:

[Test]
public   void  TestDelegate1()
{
    MockRepository mocks 
=   new  MockRepository();
    var oo 
=  mocks.DynamicMock < DoThing > ();
    oo(
"" );
    mocks.ReplayAll();
    oo(
"" );
    mocks.VerifyAll();
}

 

有两个系统定义的委托Func<TResult>Action<T>

前是带返回值的委托,后者不带返回值,现在通过Action<T>来实现上例

[Test]
public   void  TestDelegate2()
{
    MockRepository mocks 
=   new  MockRepository();
    var oo 
=  mocks.DynamicMock < Action < string >> ();

    oo(
"" );
    mocks.ReplayAll();
    oo(
"" );
    mocks.VerifyAll();
}

 

再来一个Func,即带返回值的委托的例子:

[Test]
public   void  TestDelegateFunc()
{
    MockRepository mocks 
=   new  MockRepository();
    var oo 
=  mocks.DynamicMock < Func < string string >> ();

    Expect.Call(oo(
"" )).Return( " abc " );
    mocks.ReplayAll();
    Assert.AreEqual(
" abc " , oo( "" ));
}

 

 

再来一个例子:

public   class  Customer
{
     Func
< string string >  _fun;
     
public  Customer(Func < string string >  fun)
     {
          _fun 
=  fun;
     }

     
public   void  DoSomething( string  strMsg)
     {
          Console.WriteLine(_fun(strMsg));
     }
}

 

 

测试:

[Test]
public   void  TestDelegateFunc()
{
    MockRepository mocks 
=   new  MockRepository();
    var oo 
=  mocks.DynamicMock < Func < string string >> ();
    Expect.Call(oo(
"" )).Return( " abc " );
    mocks.ReplayAll(); 

    var customer 
=   new  Customer(oo);
    customer.DoSomething(
"" );
}

 

于对这两种委托请见:http://www.cnblogs.com/jams742003/archive/2009/10/31/1593393.html

 

 

博客园大道至简

http://www.cnblogs.com/jams742003/

转载请注明:博客园

目录
相关文章
|
11月前
|
机器学习/深度学习 存储 Java
分支结构 && 方法的创建和调用 && 方法递归 && 数组的创建和使用 && 类和对象的认识 && 内部类 && 认识继承
分支结构 && 方法的创建和调用 && 方法递归 && 数组的创建和使用 && 类和对象的认识 && 内部类 && 认识继承
54 0
|
4月前
在实现链表的代码中,为什么要使用继承而不是组合?
在实现链表的代码中,为什么要使用继承而不是组合?
30 3
何为构造函数
Java构造函数,也叫构造方法,是Java中一种特殊的函数。函数名与对应类名相同,无返回值。
126 0
|
存储 Java
Java面向对象(3.1)--方法的重载,可变个数的形参,值传递机制,递归
Java面向对象(3.1)--方法的重载,可变个数的形参,值传递机制,递归
110 0
|
Java Scala 开发者
特质构造的顺序|学习笔记
快速学习特质构造的顺序。
C#编程:如何理解委托-2
C#编程:如何理解委托-2
100 0
|
Java 开发者
方法的定义与使用(方法递归调用)|学习笔记
快速学习 方法的定义与使用(方法递归调用)
100 0
方法的定义与使用(方法递归调用)|学习笔记
C#编程:如何理解委托
C#编程:如何理解委托
176 0
|
Java 编译器 C++
“生而有值”—教你使用构造函数 | 带你学《Java面向对象编程》之五
本节结合多组实例从多个方面介绍了重写构造函数的意义以及构造函数与setter函数的异同,指出了一些编写构造函数相关的注意事项。
“生而有值”—教你使用构造函数   | 带你学《Java面向对象编程》之五
|
Java 数据库 数据安全/隐私保护
规则之间-方法覆写限制 | 带你学《Java面向对象编程》之四十
本节向读者介绍了覆写方法过程中的一些限制,并拓宽读者对访问权限控制符的认识,帮助读者进行有效的方法覆写。