首頁 > 後端開發 > Golang > 為什麼「sqlmock」無法匹配查詢,即使查詢相同且日誌顯示它們相同?

為什麼「sqlmock」無法匹配查詢,即使查詢相同且日誌顯示它們相同?

Susan Sarandon
發布: 2024-11-08 12:02:01
原創
487 人瀏覽過

Why is `sqlmock` failing to match a query even though the queries are identical and the logs show them to be the same?

sqlmock 不符查詢,但查詢相同且日誌輸出顯示相同

在編寫使用Gorm 和sqlmock 測試程式碼時遇到一個問題,主要是有關更新函數。

第一個工作流程部分僅從資料庫中查詢記錄。即使日誌輸出顯示它們相同,我也無法使其與我的 SQL 相符。

錯誤訊息如下:

(database.go:263)
[2020-01-08 10:29:40]  查询:无法匹配实际 SQL:“SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = ?)) ORDER BY "storage_pools"."id" ASC LIMIT 1” with expected regexp "SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = ?)) ORDER BY "storage_pools"."id" ASC LIMIT 1"
登入後複製

我也嘗試使用 ExpectExec 插入 ExpectQuery。

  for _, c := range cases {
    db, mock, err := sqlmock.New()
    if err != nil {
      t.Fatal(err)
    }
    DB, err := gorm.Open("sqlite3", db)
    if err != nil {
      t.Fatal(err)
    }
    DB.LogMode(true)

    mock.ExpectQuery(`SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = ?)) ORDER BY "storage_pools"."id" ASC LIMIT 1`)

    err = UpdateStoragePool(DB, &c.givenPool)
    if !reflect.DeepEqual(c.wantedError, err) {
      t.Fatalf("expecting errror %q, got %q", c.wantedError, err)
    }

    // 如果事务期间没有发生任何错误,则检查是否满足所有预期
    if c.wantedError == nil {
      if err := mock.ExpectationsWereMet(); err != nil {
        t.Fatalf(err.Error())
      }
    }
  }
登入後複製

我也試過:

mock.ExpectQuery(`SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = '1')) ORDER BY "storage_pools"."id" ASC LIMIT 1`).WithArgs(1)  
mock.ExpectExec(`SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = ?)) ORDER BY "storage_pools"."id" ASC LIMIT 1`)  
mock.ExpectExec(`SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = '1')) ORDER BY "storage_pools"."id" ASC LIMIT 1`).WithArgs(1)
登入後複製

這個問題的原因可能有兩種可能:

  1. 嘗試將雙引號(")放二引號(")在查詢字串中。 sqlmock 要求使用SQL 標準的參數佔位符$n。

以上是為什麼「sqlmock」無法匹配查詢,即使查詢相同且日誌顯示它們相同?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板