登录
首页 >  Golang >  Go问答

为何"mock.ExpectQuery"会返回"空参数"

来源:stackoverflow

时间:2024-03-03 08:45:25 323浏览 收藏

从现在开始,我们要努力学习啦!今天我给大家带来《为何"mock.ExpectQuery"会返回"空参数"》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!

问题内容

下面是我的单元测试文件:

func TestAddLike(t *testing.T) {
    db, mock, err := sqlmock.New()

    if err != nil {
        t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
    }

    defer db.Close()

    rows := sqlmock.NewRows([]string{"id", "title", "body"}).
        AddRow(1, "post 1", "hello").
        AddRow(2, "post 2", "world")

    mock.ExpectQuery("SELECT (.+) FROM testmock").
        WillReturnRows(rows)

    if err := mock.ExpectationsWereMet(); err != nil {
        t.Errorf("there were unfulfilled expectations: %s", err)
    }

}

框架:gin

数据库:gorm

我想编写一个单元测试..

我有两个问题:

  1. sqlmock.new()如何选择数据库?
  2. 为什么 mock.expectquery 返回 is 而不带参数

提前致谢。


解决方案


  1. sqlmock.new()如何选择数据库?

答:它不会实际调用数据库。它是一个 mock,这意味着不是真正的数据库。

  1. 为什么mock.expectquery返回不带参数

答案: 我在 testaddlike(t *testing.t) 中没有看到对 addlike() 的调用。也尝试这样写:

func TestAddLike(t *testing.T) {
    db, mock, err := sqlmock.New()

    if err != nil {
        t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
    }

    defer db.Close()

    rows := sqlmock.NewRows([]string{"id", "title", "body"}).
        AddRow(1, "post 1", "hello").
        AddRow(2, "post 2", "world")

    mock.ExpectQuery("SELECT (.+) FROM testmock").
        WillReturnRows(rows)
 
    AddLike() // <- Add the call to actual function here. Before mock.ExpectationsWereMet

    if err := mock.ExpectationsWereMet(); err != nil {
        t.Errorf("there were unfulfilled expectations: %s", err)
    }

}
  1. 我想检查我的数据库是否增加了

回答:你不可以。编写单元测试的主要目的是隔离(独立于实际的数据库调用或对某些服务器的 api 调用)函数并根据这些依赖项的输出测试函数的逻辑(例如:db 抛出 errorapi 调用返回不同的反应)。调用实际的数据库将打破该规则。这就是集成测试发挥作用的地方。

现在,作为单元测试的一部分,您只需检查:

  • 是否将正确的 sql 查询传递给 sql 模拟
  • 返回数据库的 mock 响应后,验证函数的输出是否为 expected

以上就是《为何"mock.ExpectQuery"会返回"空参数"》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>