为了账号安全,请及时绑定邮箱和手机立即绑定

如何将 protobuf 对象作为一行传递给 golang 中的 sqlmock.AddRow?

如何将 protobuf 对象作为一行传递给 golang 中的 sqlmock.AddRow?

Go
慕尼黑5688855 2023-03-21 10:29:29
我正在尝试使用 sqlmock 对我的 go 代码进行单元测试。这是我要测试的原始代码。func enrollCourse(db *gorm.DB, user_id string ,course_id string) error {    user := &usermodels.User{}    ref := db.First(user, "uuid = ?", user_id)    userPb := user.Protobuf()    fmt.Printf("user name %+v", user.name)    ....}这是我的单元测试func TestEnrollCourse(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{"user_id","user_name"}).        AddRow(1, "John")    mock.ExpectQuery(regexp.QuoteMeta(`SELECT * FROM "users" WHERE uuid = $1`)).WithArgs("user-fd3746c8-d32f-4fb8-8f6a-b6d72dcf2969").WillReturnRows(rows)        gdb, err := gorm.Open(postgres.New(postgres.Config{                       Conn: db,               }), &gorm.Config{})    enrollCourse(gdb, "user-fd3746c8-d32f-4fb8-8f6a-b6d72dcf2969", "english_course")    ....}我期待 fmt.Printf("user name %+v", user.name) 打印用户名,但它为零。如何正确地将 protobuf 对象传递给 addRow?
查看完整描述

1 回答

?
侃侃尔雅

TA贡献1801条经验 获得超15个赞

您用于 AddRow 的数据类型似乎是字符串。在 sqlmock 中使用 protobuf 的最佳方法是在存根文件中创建的构造函数的帮助下创建对象,并将其序列化为字符串形式并存储它。然后在实际方法 ( enrollCourse) 中,您可以获得此序列化消息并将unmarshal其转换为适当的模型。



查看完整回答
反对 回复 2023-03-21
  • 1 回答
  • 0 关注
  • 85 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信