如何嘲笑杜松子酒。上下文?

我一直在试图嘲笑杜松子酒。上下文,但我无法使其工作,我正在尝试他们在此解决方案中所做的工作,但它不适用于我的路由器,这是我一直得到的错误


r.POST("/urls", urlRepo.CreateUrl)


cannot use urlRepo.CreateUrl (value of type func(c controllers.Icontext)) as gin.HandlerFunc value in argument to r.POSTcompilerIncompatibleAssign


这是我为以后的模拟而创建的接口,也是我将要测试的方法


type Icontext interface {

  BindJSON(obj interface{}) error

  JSON(code int, obj interface{})

  AbortWithStatus(code int)

  AbortWithStatusJSON(code int, jsonObj interface{})

}


func (repository *UrlRepo) CreateUrl(c Icontext) {

    var url models.Url

    c.BindJSON(&url)

    if !validators.IsCreateJsonCorrect(url) {

        c.AbortWithStatusJSON(http.StatusBadRequest, gin.H{"error": "Error format in Short or Full"})

        return

    }

    err := repository.reposito.CreateUrl(repository.Db, &url)

    if err != nil {

        c.AbortWithStatusJSON(http.StatusInternalServerError, gin.H{"error": err})

        return

    }

    c.JSON(http.StatusOK, url)

而不是


func (repository *UrlRepo) CreateUrl(c Icontext)

它是


func (repository *UrlRepo) CreateUrl(c *gin.Context) 


拉莫斯之舞
浏览 142回答 2
2回答

料青山看我应如是

严格来说,你不能以有意义的方式“嘲笑”a,因为它是一个具有未导出的字段和方法。*gin.Contextstruct此外,不能传递给类型不是 定义为 的函数。处理程序的类型根本不匹配。r.POST()gin.HandlerFuncfunc(*gin.Context)CreateUrl(c Icontext)如果您的目标是对 Gin 处理程序进行单元测试,则绝对不必模拟 .您应该做的是将测试值设置到其中。为此,您可以简单地使用并手动初始化其中一些字段。更多信息请点击这里。*gin.Contextgin.CreateTestContext()如果出于其他原因,您的目标是提供在处理程序内部使用的功能的替代实现,则可以使用自己的替代方法定义自己的类型,并将其嵌入其中。*gin.Context*gin.Context在实践中:type MyGinContext struct {    *gin.Context}func (m *MyGinContext) BindJSON(obj interface{}) error {    fmt.Println("my own BindJSON")    return m.Context.BindJSON(obj) // or entirely alternative implementation}// Using the appropriate function signature nowfunc (repository *UrlRepo) CreateUrl(c *gin.Context) {    myCtx := &MyGinContext{c}    var url models.Url    _ = myCtx.BindJSON(&url) // will also print "my own BindJSON"    // ...    // other gin.Context methods are promoted and available on MyGinContext    myCtx.Status(200)} 但老实说,我不确定为什么你会想要覆盖.如果要提供不同的绑定逻辑,甚至不同的呈现,可以实现库已公开的接口。例如:*gin.Context实现绑定:c.ShouldBindWith()将一个接口作为第二个参数,您可以实现该接口:binding.Bindingtype MyBinder struct {}func (m *MyBinder) Name() string {    return "foo"}func (m *MyBinder) Bind(*http.Request, interface{}) error {    // stuff    return nil}func MyHandler(c *gin.Context) {   var foo struct{/*fields*/}   c.ShouldBindWith(&foo, &MyBinder{})}实现渲染器:type MyRenderer struct {}type Render interface {func (m *MyRenderer) Render(http.ResponseWriter) error {    // ...    return nil}func (m *MyRenderer) WriteContentType(w http.ResponseWriter) {    header := w.Header()    if val := header["Content-Type"]; len(val) == 0 {        header["Content-Type"] = "application/foo+bar"    }}func MyHandler(c *gin.Context) {   c.Render(200, &MyRenderer{})}

阿晨1998

如果您用作 http 路由器,则入口点的参数应为 .gin-gonic*gin.Context因此,例如,您应该替换以下内容:func (repository *UrlRepo) CreateUrl(c Icontext) {有了这个func (repository *UrlRepo) CreateUrl(c *gin.Context) {这样,您应该能够使用模拟杜松子酒上下文作为单元测试的参数
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go