首页  >  文章  >  后端开发  >  在迭代测试结构时使用errors.As(),将第二个参数返回给errors.As 不应该是*error

在迭代测试结构时使用errors.As(),将第二个参数返回给errors.As 不应该是*error

PHPz
PHPz转载
2024-02-15 14:06:07486浏览

在迭代测试结构时使用errors.As(),将第二个参数返回给errors.As 不应该是*error

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中文网其他相关文章!

声明:
本文转载于:stackoverflow.com。如有侵权,请联系admin@php.cn删除