首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >go中的可测试数据库/sql sql.Rows

go中的可测试数据库/sql sql.Rows
EN

Stack Overflow用户
提问于 2017-02-15 23:37:14
回答 1查看 499关注 0票数 1

测试/模拟将sql.Rows扫描成结构的函数有没有好的做法?

代码语言:javascript
复制
func parseUsers(r *sql.Rows) (users []User, err error) {
    for r.Next() {
        var u User
        if err = r.Scan(&u.Username,
            &u.DisplayName,
            &u.EmailAddress,
            &u.IsEnabled,
            &u.PhoneNumber); err != nil {
            return []User{}, err
        }
        users = append(users, u)
    }
    err = r.Err()
    return
}

但是尝试做一些类似的事情:

代码语言:javascript
复制
func TestParseUsers(t *testing.T) {
    //make mock sql.Rows
    u, err := parseUsers(fakeRows)
    //Do tests...
}

我看过sqlx,但希望保留数据库/sql结构。我检查了go-sqlmock,但我正在寻找没有大量积聚的东西。

对于这类测试,有没有好的策略?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-02-16 00:21:42

go的方法是使用一个接口作为输入。

在您的示例中,它可能如下所示:

代码语言:javascript
复制
type Scanner interface {
  Next()
  Scan(User)
}

该函数应如下所示:

代码语言:javascript
复制
func parseUsers(s Scanner) (users []User, err error) {
  // ...
}

现在测试非常简单,因为您可以创建一个mock scanner,它实现接口并记住调用方法时使用的参数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42253698

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档