Jadual Kandungan
Kandungan soalan
Penyelesaian
repo.go
repo_test.go
Rumah pembangunan bahagian belakang Golang Gorm padam klausa ujian sqlmock

Gorm padam klausa ujian sqlmock

Feb 08, 2024 pm 10:30 PM
pergi bahasa

Gorm 删除子句 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)
Salin selepas log masuk

Ujian dengan klausa kini sentiasa gagal. Contohnya:

sqlMock.ExpectExec(`DELETE`)
    .WithArgs(expirationDate)
    .WillReturnResult(sqlmock.NewResult(1, 1))
Salin selepas log masuk

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
}
Salin selepas log masuk

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&#160;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)
    }
}
Salin selepas log masuk

Berikut adalah lebih banyak perubahan yang patut disebut:

  1. Saya instantiated anytime mengikut dokumentasi (anda boleh lihat pautan dalam komen).
  2. Saya meneka tetapan untuk dbmockgormdb tetapi saya fikir ia sepatutnya lebih kurang sama.
  3. Saya menukar penggunaan expectexec kepada expectquery kerana kami akan mengembalikan set hasil yang ditentukan oleh kaedah expectexec 的用法切换为 expectquery,因为我们将返回 clauses 文件中 repo.go dalam fail clauses.
  4. Anda mesti memasukkan expectquery 包装在 expectbeginexpectcommit.
  5. 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!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1663
14
Tutorial PHP
1263
29
Tutorial C#
1236
24
Bagaimana menyelesaikan masalah penukaran jenis user_id semasa menggunakan aliran redis untuk melaksanakan beratur mesej dalam bahasa Go? Bagaimana menyelesaikan masalah penukaran jenis user_id semasa menggunakan aliran redis untuk melaksanakan beratur mesej dalam bahasa Go? Apr 02, 2025 pm 04:54 PM

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? Apa yang perlu saya lakukan jika label struktur tersuai di Goland tidak dipaparkan? Apr 02, 2025 pm 05:09 PM

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 ...

Apakah masalah dengan thread giliran di crawler colly go? Apakah masalah dengan thread giliran di crawler colly go? Apr 02, 2025 pm 02:09 PM

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. � ...

Di Go, mengapa rentetan percetakan dengan fungsi println dan rentetan () mempunyai kesan yang berbeza? Di Go, mengapa rentetan percetakan dengan fungsi println dan rentetan () mempunyai kesan yang berbeza? Apr 02, 2025 pm 02:03 PM

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

Perpustakaan apa yang digunakan untuk operasi nombor terapung di GO? Perpustakaan apa yang digunakan untuk operasi nombor terapung di GO? Apr 02, 2025 pm 02:06 PM

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

Apakah perbezaan antara struktur definisi kata kunci `var` dan` type` dalam bahasa Go? Apakah perbezaan antara struktur definisi kata kunci `var` dan` type` dalam bahasa Go? Apr 02, 2025 pm 12:57 PM

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 disediakan oleh projek sumber terbuka yang terkenal? Perpustakaan mana yang dibangunkan oleh syarikat besar atau disediakan oleh projek sumber terbuka yang terkenal? Apr 02, 2025 pm 04:12 PM

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

Dalam pengaturcaraan GO, bagaimana untuk menguruskan sambungan dan melepaskan sumber antara MySQL dan Redis dengan betul? Dalam pengaturcaraan GO, bagaimana untuk menguruskan sambungan dan melepaskan sumber antara MySQL dan Redis dengan betul? Apr 02, 2025 pm 05:03 PM

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 ...

See all articles