Saya seorang pengaturcara yang berpengalaman tetapi masih baru untuk pergi. Saya sedang menulis beberapa ujian pembalakan dan untuk tujuan ini saya hasilkan logsink
类的模拟(使用 mockgen
). Memandangkan bahagian itu semuanya dijana secara automatik, saya fikir kita boleh menganggap tidak ada sebarang isu di sana.
Ini kod ujian saya:
func TestLogging(t *testing.T) { ls := mock.NewMockLogSink(gomock.NewController(t)) ls.EXPECT().Init(gomock.Any()) const logLevel = 1 ls.EXPECT().Enabled(gomock.Any()).AnyTimes().Do(func(level int) bool { return level <= logLevel }) log.Set(logr.New(ls)) ls.EXPECT().Info(gomock.Any(), "Foo").Times(1) log.Info("Foo") ls.EXPECT().Info(gomock.Any(), "Bar").Times(0) log.V(2).Info("Bar") }
Tetapi ujian ini gagal kerana log "foo" tidak pernah dipanggil. Saya melangkah melalui kod dan menemui expect().do()
代码按预期被调用,并返回 true
,但在模拟代码中,它将 logger.sink.enabled()
的结果视为 false
saya !
Apa salah saya? Adakah saya kehilangan suis rahsia?
Nah, ternyata .do()
sengaja mengabaikan nilai pulangan. Berikut ialah dokumentasi dalam kod:
// Do declares the action to run when the call is matched. The function's // return values are ignored to retain backward compatibility. To use the // return values call DoAndReturn.
Keserasian ke belakang. Betul. Lubang berdarah domain awam, jika anda bertanya kepada saya...
Atas ialah kandungan terperinci Gomock tidak mengembalikan nilai yang diharapkan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!