第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何將 protobuf 對(duì)象作為一行傳遞給 golang 中的 sqlmock.AddRow?

如何將 protobuf 對(duì)象作為一行傳遞給 golang 中的 sqlmock.AddRow?

Go
慕尼黑5688855 2023-03-21 10:29:29
我正在嘗試使用 sqlmock 對(duì)我的 go 代碼進(jìn)行單元測(cè)試。這是我要測(cè)試的原始代碼。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)    ....}這是我的單元測(cè)試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 對(duì)象傳遞給 addRow?
查看完整描述

1 回答

?
侃侃爾雅

TA貢獻(xiàn)1801條經(jīng)驗(yàn) 獲得超16個(gè)贊

您用于 AddRow 的數(shù)據(jù)類型似乎是字符串。在 sqlmock 中使用 protobuf 的最佳方法是在存根文件中創(chuàng)建的構(gòu)造函數(shù)的幫助下創(chuàng)建對(duì)象,并將其序列化為字符串形式并存儲(chǔ)它。然后在實(shí)際方法 ( enrollCourse) 中,您可以獲得此序列化消息并將unmarshal其轉(zhuǎn)換為適當(dāng)?shù)哪P汀?/p>



查看完整回答
反對(duì) 回復(fù) 2023-03-21
  • 1 回答
  • 0 關(guān)注
  • 138 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)