Gorm padam klausa ujian sqlmock
Editor PHP Xinyi memperkenalkan kepada anda ujian sqlmock klausa pemadaman Gorm. Gorm ialah rangka kerja ORM yang sangat baik dalam bahasa Go, dan sqlmock ialah alat ujian untuk Gorm, digunakan untuk mensimulasikan operasi pangkalan data. Apabila membangunkan Gorm, kita sering perlu menguji operasi pemadaman pangkalan data Pada masa ini, kita boleh menggunakan sqlmock untuk mensimulasikan operasi pemadaman pangkalan data untuk ujian unit dan ujian integrasi. Artikel ini akan memperkenalkan anda secara terperinci cara menggunakan Gorm dan sqlmock untuk menguji klausa pemadaman, membantu anda menjalankan kerja pembangunan berkaitan pangkalan data dengan lebih baik.
Kandungan soalan
Saya ada gorm delete, hasil pulangan ialah:
expirationdate := time.now().utc().add(-(48 * time.hour)) var deletedusers users res := gormdb.withcontext(ctx). table("my_users"). clauses(clause.returning{columns: []clause.column{{name: "email"}}}). where("created_at < ?", expirationdate). delete(&deletedusers)
Ujian dengan klausa kini sentiasa gagal. Contohnya:
sqlMock.ExpectExec(`DELETE`) .WithArgs(expirationDate) .WillReturnResult(sqlmock.NewResult(1, 1))
Ralat terima:
"Memanggil pertanyaan 'padam daripada "pengguna_saya" di mana create_at < $1 mengembalikan "e-mel"' dengan parameter [{name: ordinal:1 value:2023-01-18 06:15:34.694274 +0000 utc}] tidak dijangka, Jangkaan seterusnya ialah: expectedexec => menjangkakan exec atau execcontext di mana: n - sepadan dengan sql: 'delete'n - mengambil hujah: n 0 - 2023-01-18 06:15:34.694274 +0000 utc n - harus kembali dengan Keputusan untuk: n lastinsertid: 1n rowsaffected: 1"
Saya mencuba banyak jangkaan sqlmock lain tetapi mereka mempunyai masalah yang sama. Selain itu, kami tidak mempunyai nilai pulangan dalam expectexec, hanya dalam expectquery... Adakah sesiapa perlu menguji pertanyaan gorm dengan klausa?
Penyelesaian
Saya berjaya menguruskan keperluan anda. Mula-mula, izinkan saya berkongsi fail yang saya tulis, dan kemudian saya akan membimbing anda melalui semua perubahan yang berkaitan. Fail ini adalah untuk kegunaan pengeluaran repo.go
和用于测试代码的 repo_test.go
.
repo.go
package gormdelete import ( "context" "time" "gorm.io/gorm" "gorm.io/gorm/clause" ) type users struct { email string } func delete(ctx context.context, gormdb *gorm.db) error { expirationdate := time.now().utc().add(-(48 * time.hour)) var deletedusers users res := gormdb.withcontext(ctx).table("my_users").clauses(clause.returning{columns: []clause.column{{name: "email"}}}).where("created_at < ?", expirationdate).delete(&deletedusers) if res.error != nil { return res.error } return nil }
Memandangkan anda tidak memberikan fail lengkap, saya cuba meneka apa yang hilang.
repo_test.go
package gormdelete import ( "context" "database/sql/driver" "testing" "time" "github.com/DATA-DOG/go-sqlmock" "github.com/stretchr/testify/assert" "gorm.io/driver/postgres" "gorm.io/gorm" ) // this is taken directly from the docs // https://github.com/DATA-DOG/go-sqlmock#matching-arguments-like-timetime type AnyTime struct{} // Match satisfies sqlmock.Argument interface func (a AnyTime) Match(v driver.Value) bool { _, ok := v.(time.Time) return ok } func TestDelete(t *testing.T) { db, mock, err := sqlmock.New() if err != nil { t.Fatalf("an error was not expected: %v", err) } conn, _ := db.Conn(context.Background()) gormDb, err := gorm.Open(postgres.New(postgres.Config{ Conn: conn, })) row := sqlmock.NewRows([]string{"email"}).AddRow("<a href="https://www.php.cn/link/89fee0513b6668e555959f5dc23238e9" class="__cf_email__" data-cfemail="9febfaecebdffae7fef2eff3fab1fcf0f2">[email protected]</a>") mock.ExpectBegin() mock.ExpectQuery("DELETE FROM \"my_users\" WHERE created_at < ?").WithArgs(AnyTime{}).WillReturnRows(row) mock.ExpectCommit() err = Delete(context.Background(), gormDb) assert.Nil(t, err) if err = mock.ExpectationsWereMet(); err != nil { t.Errorf("not all expectations were met: %v", err) } }
Berikut adalah lebih banyak perubahan yang patut disebut:
- Saya instantiated
anytime
mengikut dokumentasi (anda boleh lihat pautan dalam komen). - Saya meneka tetapan untuk
db
、mock
和gormdb
tetapi saya fikir ia sepatutnya lebih kurang sama. - Saya menukar penggunaan
expectexec
kepadaexpectquery
kerana kami akan mengembalikan set hasil yang ditentukan oleh kaedahexpectexec
的用法切换为expectquery
,因为我们将返回clauses
文件中repo.go
dalam failclauses
. - Anda mesti memasukkan
expectquery
包装在expectbegin
和expectcommit
. - Akhir sekali, perhatikan perbezaan dalam cara pemandu mengharapkan parameter dalam pernyataan sql. Dalam kod pengeluaran anda mempunyai pilihan untuk menggunakan
?
或。但在测试代码中,只能使用
?
, jika tidak, ia tidak berkelakuan seperti yang diharapkan.
Semoga ia membantu, jika tidak sila beritahu saya!
Atas ialah kandungan terperinci Gorm padam klausa ujian sqlmock. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Masalah menggunakan redisstream untuk melaksanakan beratur mesej dalam bahasa Go menggunakan bahasa Go dan redis ...

Apa yang perlu saya lakukan jika label struktur tersuai di Goland tidak dipaparkan? Apabila menggunakan Goland untuk Pembangunan Bahasa GO, banyak pemaju akan menghadapi tag struktur tersuai ...

Masalah Threading Giliran di GO Crawler Colly meneroka masalah menggunakan Perpustakaan Colly Crawler dalam bahasa Go, pemaju sering menghadapi masalah dengan benang dan permintaan beratur. � ...

Perbezaan antara percetakan rentetan dalam bahasa Go: perbezaan kesan menggunakan fungsi println dan rentetan () sedang ...

Perpustakaan yang digunakan untuk operasi nombor terapung dalam bahasa Go memperkenalkan cara memastikan ketepatannya ...

Dua cara untuk menentukan struktur dalam bahasa Go: perbezaan antara VAR dan jenis kata kunci. Apabila menentukan struktur, pergi bahasa sering melihat dua cara menulis yang berbeza: pertama ...

Perpustakaan mana yang dibangunkan oleh syarikat besar atau projek sumber terbuka yang terkenal? Semasa pengaturcaraan di GO, pemaju sering menghadapi beberapa keperluan biasa, ...

Pengurusan Sumber dalam Pemrograman GO: MySQL dan Redis Connect dan Lepaskan dalam Pembelajaran Cara Mengurus Sumber Sumber dengan betul, terutamanya dengan pangkalan data dan cache ...
