1 回答

TA貢獻1829條經驗 獲得超13個贊
如果你想測試B,看看它是否真的調用了A的Foo函數,你需要模擬出A對象。由于您要檢查的函數是Foo
,只需創建一個僅包含該函數的簡單Fooer
接口(這就是您在 Go 中所稱的函數加上 'er')。將 B 對 A 的引用替換為對 Fooer 的引用,就可以了。我在 Go Playground 上根據您的代碼創建了一個小示例:
package main
import "testing"
type A struct {
}
func (a *A) Foo() {}
type Fooer interface {
? ? Foo()
}
type B struct {
? ? a Fooer
}
func (b *B) Bar() {
? ? b.a.Foo()
}
func main() {
? ? var a A
? ? var b B
? ? b.a = &a
? ? b.Bar()
}
// in your test:
type mockFooer struct {
? ? fooCalls int
}
func (f *mockFooer) Foo() {
? ? f.fooCalls++
}
func Test(t *testing.T) {
? ? var mock mockFooer
? ? var bUnderTest B
? ? bUnderTest.a = &mock
? ? bUnderTest.Bar()
? ? if mock.fooCalls != 1 {
? ? ? ? t.Error("Foo not called")
? ? }
}
- 1 回答
- 0 關注
- 154 瀏覽
添加回答
舉報