>  기사  >  백엔드 개발  >  쿼리가 동일하고 로그에 동일한 것으로 표시되는데도 `sqlmock`이 쿼리와 일치하지 못하는 이유는 무엇입니까?

쿼리가 동일하고 로그에 동일한 것으로 표시되는데도 `sqlmock`이 쿼리와 일치하지 못하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-08 12:02:01461검색

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"

ExpExec를 사용하여 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. 큰따옴표(")를 넣어보세요. 쿼리 문자열. 쿼리 문자열에 백틱(`)이 필요합니다. 이 문제를 해결하려면 큰따옴표를 백틱으로 바꾸세요.
  2. SQLmock에서는 SQL 표준 매개변수를 사용해야 합니다. 이 문제를 해결하려면 ? 자리 표시자를 $n으로 바꾸세요.

위 내용은 쿼리가 동일하고 로그에 동일한 것으로 표시되는데도 `sqlmock`이 쿼리와 일치하지 못하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.