Maison  >  Article  >  développement back-end  >  En utilisant error.As() lors de l'itération de la structure de test, renvoyez le deuxième paramètre à error.As ne devrait pas être *error

En utilisant error.As() lors de l'itération de la structure de test, renvoyez le deuxième paramètre à error.As ne devrait pas être *error

PHPz
PHPzavant
2024-02-15 14:06:07484parcourir

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

l'éditeur php Strawberry a trouvé une erreur lors de l'itération de la structure de test. Lors de l'utilisation d'erreurs.As(), le deuxième paramètre renvoyé à erreurs.As devrait être un pointeur vers une erreur, pas une erreur. Cette erreur peut entraîner un comportement inattendu ou incorrect du programme. Par conséquent, lorsque vous utilisez error.As(), veillez à faire attention au type du paramètre et à ce qu'un pointeur vers error soit transmis pour éviter de causer des problèmes. Ce problème peut survenir lors d'une itération sur des structures de test, soyez donc particulièrement attentif lorsque vous utilisez error.As().

Contenu de la question

J'écris actuellement des tests unitaires pour un package où les fonctions peuvent renvoyer plusieurs types d'erreurs. Je définis la structure comme :

tests := []struct {
    name   string
    data   string
    url    string
    status int
}

et je souhaite utiliser errors.as() 在我测试的错误中查找 test.err . L'exemple de structure que j'ai utilisé dans mes tests est le suivant :

{
    name:   "url not available",
    err:    &url.error{},
    data:   srvdata,
    url:    "a",
    status: http.statusok,
},

Je souhaite ajouter errors.as 用于实现错误接口的不同结构类型。因此,正如您在结构中看到的那样,我将 err 定义为错误。可以看出,我使用 &url.error{} , qui devrait implémenter l'interface d'erreur.

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 {
        // ...
    }
})

Cependant, utiliser errors.as comme ci-dessus renvoie

second argument to errors.As should not be *error

Maintenant, d'après ce que j'ai compris, erreurs.as() accepte any comme deuxième argument, donc je ne comprends pas pourquoi *error ne peut pas être utilisé.

J'ai également essayé de changer le champ err dans la structure de test en interface{} ; cependant, cela a permis à toutes les assertions de passer, que la cible soit présente ou non dans l'erreur.

Je ne trouve pas comment utiliser errors.as() pour implémenter un autre type de solution qui implémente l'interface des erreurs de la même manière que ci-dessus, alors maintenant je compte sur l'utilisation de contains () code> à la place. Je me demande si quelqu'un peut donner un aperçu. errors.as() 来实现以与上面类似的方式实现错误接口的不同类型的解决方案,所以现在我依靠使用 contains() 来代替。想知道是否有人可以提供一些见解。

解决方法

指向错误类型的指针不满足 error 接口,这就是为什么 as 的第二个参数的类型为 any。为了将您想要的类型直接存储在 .err 字段中,该字段也必须是 any

Solution

Le pointeur vers le type d'erreur ne satisfait pas l'interface error, c'est pourquoi le deuxième paramètre de as est de type 🎜. Afin de stocker le type souhaité directement dans le champ .err, le champ doit également être de type 🎜. 🎜 🎜Cependant, puisque vous avez enveloppé cette valeur de pointeur dans une interface, vous devrez utiliser une assertion de type ou une réflexion pour obtenir la valeur à inspecter : 🎜
var testErr any = new(*url.Error)
_, err := http.Get("http://error.error/")

if errors.As(err, testErr) {
    fmt.Println(reflect.ValueOf(testErr).Elem())
}

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer