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()
来代替。想知道是否有人可以提供一些见解。
解决方法
指向错误类型的指针不满足 error
接口,这就是为什么 as
的第二个参数的类型为 any
。为了将您想要的类型直接存储在 .err
字段中,该字段也必须是 any
类型。
但是,由于您已将此指针值包装在接口中,因此您将需要使用类型断言或反射来获取该值以供检查:
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的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!