比较 gorm 中使用 go-sqlmock 进行测试时,查询与 mock.ExpectQuery 和 regexp.QuoteMeta 的用法
来源:stackoverflow
时间:2024-02-06 14:18:21 428浏览 收藏
从现在开始,我们要努力学习啦!今天我给大家带来《比较 gorm 中使用 go-sqlmock 进行测试时,查询与 mock.ExpectQuery 和 regexp.QuoteMeta 的用法》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!
问题内容
我在比较预期查询与 gorm 的真实查询时遇到问题,这是我的代码:
package repository
import (
"regexp"
"testing"
"github.com/data-dog/go-sqlmock"
"your_go_root/pkg/domain"
"github.com/stretchr/testify/assert"
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
var successgettransaction domain.transaction = domain.transaction{
id: 2,
buyerid: 2,
sellerid: 5,
itemid: 2,
messageid: 2,
expireddate: "2022-09-010 01:01:00",
createdat: "2022-09-08 01:01:00",
}
func testsuccessgettransactionbyid(t *testing.t) {
db, mock, err := sqlmock.new()
assert.noerror(t, err)
gdb, err := gorm.open(mysql.new(mysql.config{
conn: db,
skipinitializewithversion: true,
}), &gorm.config{})
assert.noerror(t, err)
rows := sqlmock.newrows([]string{"id", "buyer_id", "seller_id", "item_id", "message_id", "expired_date", "created_at"}).
addrow(2, 2, 5, 2, 2, "2022-09-010 01:01:00", "2022-09-08 01:01:00")
mock.expectquery(regexp.quotemeta("select * from transaction where id = ?;")).willreturnrows(rows)
repo := defaultclient(gdb)
actualsectionlist, _ := repo.gettransactionbyid(2)
assert.equal(t, successgettransaction, actualsectionlist, "ambas listas deberian ser iguales")
assert.noerror(t, mock.expectationsweremet())
}
这是模块域:
package domain
type transaction struct {
id int64 `gorm:"primarykey;column:id"`
buyerid int64 `gorm:"column:buyer_id"`
sellerid int64 `gorm:"column:seller_id"`
itemid int `gorm:"column:item_id"`
messageid int `gorm:"column:message_id"`
expireddate string `gorm:"column:expired_date"`
createdat string `gorm:"column:created_at"`
}
func (transaction) tablename() string {
return "transaction"
}
type transactionstatus struct {
id int64 `gorm:"primarykey;column:id"`
transactionid int64 `gorm:"column:transaction_id"`
status int `gorm:"column:status"`
notificationid int `gorm:"column:notification_id"`
createdat string `gorm:"column:created_at"`
}
func (transactionstatus) tablename() string {
return "transaction_status"
}
这是我正在测试的功能:
package repository
import (
"fmt"
"your_go_root/pkg/domain"
"gorm.io/gorm"
)
type repositoryclient interface {
gettransactionbyid(id int) (domain.transaction, error)
}
type repositoryclient struct {
db *gorm.db
}
func defaultclient(db *gorm.db) repositoryclient {
return &repositoryclient{
db: db,
}
}
func (rc repositoryclient) gettransactionbyid(id int) (domain.transaction, error) {
trans := domain.transaction{}
status := rc.db.where("id = ?", id).find(&trans)
if status.error != nil {
return domain.transaction{}, status.error
}
if trans == (domain.transaction{}) {
return domain.transaction{}, fmt.errorf("error finding transaction id %v", id)
}
return trans, nil
}
这是我从控制台收到的错误:
Query: could not match actual sql: "SELECT * FROM `transaction` WHERE id = ?" with expected regexp "SELECT \* FROM transaction WHERE id = \?;"[0m[33m[0.218ms] [34;1m[rows:0][0m SELECT * FROM `transaction` WHERE id = 2
在本节中存在一个用“select(.*)”替代的答案,但根据我读到的内容,这不是真正的解决方案
正确答案
让我尝试帮助解决这个问题。我下载了您的所有文件,并且 domain.go 和 repository.go 对我来说看起来不错。
但是,我在 repository_test.go 文件中发现了一些小问题:
- 您编写的 sql 查询中缺少反引号
- 查询末尾额外的
; - 缺少对
withargs(2)方法的调用
如果您调整了这些小问题,您应该得到如下所示的代码:
// ... omitted for brevity
func TestSuccessGetTransactionByID(t *testing.T) {
db, mock, err := sqlmock.New()
assert.NoError(t, err)
gdb, err := gorm.Open(mysql.New(mysql.Config{
Conn: db,
SkipInitializeWithVersion: true,
}), &gorm.Config{})
assert.NoError(t, err)
rows := sqlmock.NewRows([]string{"id", "buyer_id", "seller_id", "item_id", "message_id", "expired_date", "created_at"}).AddRow(2, 2, 5, 2, 2, "2022-09-010 01:01:00", "2022-09-08 01:01:00")
mock.ExpectQuery(regexp.QuoteMeta("SELECT * FROM `transaction` WHERE id = ?")).WithArgs(2).WillReturnRows(rows)
repo := DefaultClient(gdb)
actualSectionList, _ := repo.GetTransactionByID(2)
assert.Equal(t, successGetTransaction, actualSectionList, "ambas listas deberian ser iguales")
assert.NoError(t, mock.ExpectationsWereMet())
}
然后,如果您尝试运行测试,它应该可以工作。
如果这解决了您的问题,请告诉我,谢谢!
今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
139 收藏
-
204 收藏
-
325 收藏
-
478 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习