php小编草莓在迭代测试结构时发现了一个错误。使用errors.As()时,将第二个参数返回给errors.As时应该是一个指向error的指针,而不是一个error。这个错误可能会导致程序出现异常或者不正确的行为。所以在使用errors.As()时,务必要注意参数的类型,确保传递的是一个指向error的指针,以免引发问题。这个问题可能会在迭代测试结构时出现,因此在使用errors.As()时要特别注意。
我目前正在为一个包编写一些单元测试,其中函数可以返回多种类型的错误。我将结构定义为:
tests := []struct { name string data string url string status int }
并且想使用 errors.as()
在我测试的错误中查找 test.err
。我在测试中使用的示例结构如下:
{ name: "url not available", err: &url.error{}, data: srvdata, url: "a", status: http.statusok, },
我想将 errors.as
用于实现错误接口的不同结构类型。因此,正如您在结构中看到的那样,我将 err 定义为错误。可以看出,我使用 &url.error{}
,它应该实现错误接口。
t.run(test.name, func(t *testing.t) { data, err := i.getid(url) if err != nil { require.notnil(t, test.err) assert.true(t, errors.as(err, &test.err)) } else { // ... } })
但是,如上所述使用 errors.as
返回
second argument to errors.As should not be *error
现在据我了解,errors.as() 接受 any
作为第二个参数,所以我很困惑为什么不能使用 *error。
我还尝试将测试结构中的 err
字段更改为 interface{} ;然而,这样做会使所有断言通过,无论目标是否存在于错误中。
我找不到如何使用 errors.as()
来实现以与上面类似的方式实现错误接口的不同类型的解决方案,所以现在我依靠使用 contains()
来代替。想知道是否有人可以提供一些见解。errors.as()
来实现以与上面类似的方式实现错误接口的不同类型的解决方案,所以现在我依靠使用 contains()
来代替。想知道是否有人可以提供一些见解。
指向错误类型的指针不满足 error
接口,这就是为什么 as
的第二个参数的类型为 any
。为了将您想要的类型直接存储在 .err
字段中,该字段也必须是 any
error
接口,这就是为什么 as
的第二个参数的类型为 🎜。为了将您想要的类型直接存储在 .err
字段中,该字段也必须是 🎜 类型。🎜
🎜但是,由于您已将此指针值包装在接口中,因此您将需要使用类型断言或反射来获取该值以供检查:🎜
var testErr any = new(*url.Error) _, err := http.Get("http://error.error/") if errors.As(err, testErr) { fmt.Println(reflect.ValueOf(testErr).Elem()) }
以上是在迭代测试结构时使用errors.As(),将第二个参数返回给errors.As 不应该是*error的详细内容。更多信息请关注PHP中文网其他相关文章!