AssertCalled 总是因 testify 库而失败

AssertCalled always fails with testify library

我正在使用 testify 来测试我的代码,我想检查是否调用了一个函数。

我正在做以下事情:

type Foo struct {
    mock.Mock
}

func (m Foo) Bar() {

}

func TestFoo(t *testing.T) {
    m := Foo{}
    m.Bar()
    m.AssertCalled(t, "Bar")
}

我得到的错误:

Error:      Should be true
Messages:   The "Bar" method should have been called with 0 argument(s), but was not.

mock.go:419: []

我调用函数 "Bar" 并立即询问它是否被调用但它 returns 错误。 我究竟做错了什么? 测试一个函数是否被 testify 调用的正确方法是什么?

查看 documentation of testify 我认为您必须显式调用 func (*Mock) Called 来告诉模拟对象已调用一个方法。

func (m *Foo) Bar() {
    m.Called()
}

作证测试有some examples

我试过这个并且有效:

type Foo struct {                                                                                                                                                    
    mock.Mock                                                                                                                                                          
}                                                                                                                                                                    

func (m *Foo) Bar() {                                                                                                                                                
    m.Called()                                                                                                                                                         
}                                                                                                                                                                    

func TestFoo(t *testing.T) {                                                                                                                                         
    m := &Foo{}                                                                                                                                                        
    m.On("Bar").Return(nil)                                                                                                                                            

    m.Bar()                                                                                                                                                            
    m.AssertCalled(t, "Bar")                                                                                                                                           
}

正如 Chris Drew 所述,您必须在 Bar 方法的声明中使用接收器指针。

此外,您必须将新结构实例化为指针并将该方法模拟为 return 一个值。

确保它是指针接收器而不是值接收器。

这将始终有 零调用

type Foo struct {
    mock.Mock
}

func (m Foo) Bar() 
    m.Called()
}

这将有 N 次调用

type Foo struct {
    mock.Mock
}

func (m *Foo) Bar() 
    m.Called()
}

当您 want/need 使用值接收器时,作为一个额外的解决方案,虽然不是那么干净,但将 Mock 指定为指针字段对我有用。

type Foo struct {
    m *mock.Mock
}

func (f Foo) Bar() {
    f.m.Called()
}

func TestFoo(t *testing.T) {
    f := Foo{m: &mock.Mock{}}
    f.Bar()
    f.m.AssertCalled(t, "Bar")
}