SQLMock을 사용하여 쿼리를 모의할 때 일치할 것으로 예상한 쿼리가 표시됨에도 불구하고 일치하지 않는 상황이 발생할 수 있습니다. 로그 출력에서도 동일합니다. 이 문서에서는 이러한 불일치에 대한 일반적인 이유를 논의하고 해결 방법을 제공합니다.
첫 번째 단계는 쿼리가 실제로 예상 쿼리와 동일한지 확인하는 것입니다. 그러나 구문이나 인수 처리의 미묘한 차이로 인해 불일치가 발생할 수 있습니다.
쿼리에서 특수 문자를 사용할 때 한 가지 일반적인 문제가 발생합니다. SQLMock은 이러한 문자를 코드와 다르게 해석할 수 있습니다. 정확한 일치를 보장하려면 regexp.QuoteMeta() 함수를 사용하여 쿼리 문자열을 이스케이프할 수 있습니다. 예:
mock.ExpectQuery(regexp.QuoteMeta(`SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = ?)) ORDER BY "storage_pools"."id" ASC LIMIT 1`))
이렇게 하면 모든 특수 문자가 리터럴로 처리되어 불일치가 방지됩니다.
Select 문은 그렇지 않다고 언급했습니다. ExpectExec()을 사용하여 작업합니다. 이는 ExpectExec()이 select 문이 아닌 업데이트 또는 삽입 문을 기대하기 때문입니다. select 문에는 대신 ExpectQuery()를 사용하세요.
mock.ExpectQuery(`SELECT \* FROM "storage_pools"`). WithArgs(c.givenPool.PoolId).WillReturnResult(sqlmock.NewResult(1, 1))
위 내용은 내 SQLMock 쿼리가 일치하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!