我正在使用gomock,我有一段示例代碼,我想測(cè)試一下。type StructA struct { client map[string]Foo}type Foo interface { foo.methodFoo() string}func (a *structA) MethodA(name string) string { client := a.client[name] return client.methodFoo() }在我的測(cè)試中,我為 foo 生成了一個(gè)模擬,稱為 mockFoo。使用模擬 v1.6.0 為接口 foo 生成模擬。我的測(cè)試代碼為:func Test_MethodA(t *testing.T) { type fields struct { client map[string]*mockFoo } tests := []struct { fields fields want string } { // test cases } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { a := &StructA { client: tt.fields.client //this has an error, saying that we cannot use map[string]*mockFoo as the type map[string]foo } ... }) }}TLDR 是不能用作類型 。map[string]*mockFoomap[string]Foovar foo1 Foovar mockFoo1 *mockFoofoo1 = mockFoo1 // no problemvar fooMap map[string]Foovar mockFooMap map[string]*mockFoofooMap = mockFooMap // problematic我能知道我在這里是否做錯(cuò)了什么,或者這是否是預(yù)期的行為嗎?謝謝。
1 回答

回首憶惘然
TA貢獻(xiàn)1847條經(jīng)驗(yàn) 獲得超11個(gè)贊
根據(jù)您的描述,是一個(gè)接口,并實(shí)現(xiàn)該接口。因此,每當(dāng)需要 時(shí),都可以使用 。Foo*mockFooFooFoo*mockFoo
類型 與 類型 不同。兩者都是具體類型(它們不是接口),因此不能用一個(gè)替換另一個(gè)。map[string]Foomap[string]*mockFoo
但是,您可以使用 ,并將值放入該映射中,根據(jù)我從您的代碼中看到的情況,這是您應(yīng)該做的。將映射聲明為 ,并在其中使用值。如果需要將映射的值引用為 ,則可以鍵入斷言映射值以獲取該值,即:map[string]Foo*mockFoomap[string]Foo*mockFoo*mockFoo*mockFoo
fooMap=map[string]Foo{}
fooMap["key"]=mockFoo1
...
value:=foomap["key"].(*mockFoo)
- 1 回答
- 0 關(guān)注
- 115 瀏覽
添加回答
舉報(bào)
0/150
提交
取消