Cara yang betul untuk menguji fungsi golang

PHPz
Lepaskan: 2024-04-27 08:45:01
asal
1109 orang telah melayarinya

Cara yang betul untuk menguji fungsi dalam Go termasuk: mencipta fail ujian yang berakhir dengan _test.go. Tulis fungsi ujian bermula dengan Ujian. Gunakan alat ujian tambahan seperti t.Fail(), t.Error(), t.Fatal(), dan t.Skip(). Sahkan keputusan yang dijangka dan sebenar menggunakan kaedah penegasan seperti t.Equal(), t.NotEqual(), dsb.

Cara yang betul untuk menguji fungsi golang

Cara ujian fungsi yang betul dalam bahasa Go

Pengujian fungsi dalam bahasa Go adalah penting kerana ia memastikan kod anda berjalan dengan betul dalam semua situasi. Artikel ini akan memperkenalkan cara yang betul untuk menggunakan pakej ujian bahasa Go untuk ujian fungsi. testing 包进行函数测试的正确方式。

1. 创建测试文件

首先,您需要为要测试的函数创建一个新的测试文件。测试文件名必须以 _test.go 结尾,并与被测函数放在同一个包中。例如,如果您要测试 mypackage/myfunc 函数,则测试文件应为 mypackage/myfunc_test.go

2. 编写测试函数

在测试文件中,您需要编写一个或多个测试函数。每个测试函数都应该以 Test 开头,后面紧跟测试函数的名称。例如,以下代码显示了如何测试 Add 函数:

import (
    "testing"

    "mypackage"
)

func TestAdd(t *testing.T) {
    // ...
}
Salin selepas log masuk

3. 使用辅助测试工具

testing 包提供了一些有用的辅助测试工具,可以简化测试编写。以下是其中一些最常用的工具:

  • t.Fail():当测试失败时中断测试函数。
  • t.Error():记录测试错误,但不会中断测试函数。
  • t.Fatal():记录测试错误并中断测试函数。
  • t.Skip():跳过测试函数。

4. 断言

断言用于验证测试预期和实际结果是否匹配。testing 包提供了几个断言方法,例如:

  • t.Equal(a, b):断言 ab 相等。
  • t.NotEqual(a, b):断言 ab 不相等。
  • t.True(b):断言 b 为真。
  • t.False(b):断言 b 为假。

实战案例

让我们编写一个测试 mypackage/myfunc 函数的测试文件:

import (
    "testing"

    "mypackage"
)

func TestAdd(t *testing.T) {
    type testCase struct {
        a, b, want int
    }

    tests := []testCase{
        {1, 2, 3},
        {4, 5, 9},
        {-1, -2, -3},
    }

    for _, tc := range tests {
        got := mypackage.Add(tc.a, tc.b)
        if got != tc.want {
            t.Errorf("Add(%d, %d) = %d, want %d", tc.a, tc.b, got, tc.want)
        }
    }
}
Salin selepas log masuk

这个测试案例定义了三个测试用例,每个测试用例都包含三个输入变量 (ab 和期望的输出 (want))。测试函数使用 for 循环遍历这些测试用例,并为每个测试用例调用 Add

🎜1. Buat fail ujian 🎜🎜🎜Mula-mula, anda perlu mencipta fail ujian baharu untuk fungsi yang ingin anda uji. Nama fail ujian mesti berakhir dengan _test.go dan diletakkan dalam pakej yang sama dengan fungsi yang sedang diuji. Sebagai contoh, jika anda ingin menguji fungsi mypackage/myfunc, fail ujian akan menjadi mypackage/myfunc_test.go. 🎜🎜🎜2. Tulis fungsi ujian 🎜🎜🎜Dalam fail ujian, anda perlu menulis satu atau lebih fungsi ujian. Setiap fungsi ujian hendaklah bermula dengan Ujian diikuti dengan nama fungsi ujian. Contohnya, kod berikut menunjukkan cara untuk menguji fungsi Add: 🎜rrreee🎜🎜3 Menggunakan alat ujian tambahan 🎜🎜🎜 Pakej testing menyediakan beberapa alat ujian tambahan yang berguna. yang boleh Memudahkan penulisan ujian. Berikut ialah beberapa alatan yang paling biasa digunakan: 🎜
  • t.Fail(): Mengganggu fungsi ujian apabila ujian gagal.
  • t.Error(): Merekod ralat ujian tetapi tidak mengganggu fungsi ujian.
  • t.Fatal(): Rekod ralat ujian dan ganggu fungsi ujian.
  • t.Skip(): Langkau fungsi ujian.
🎜🎜4. Penegasan🎜🎜🎜Penegasan digunakan untuk mengesahkan sama ada jangkaan ujian dan keputusan sebenar sepadan. Pakej testing menyediakan beberapa kaedah penegasan, contohnya: 🎜
  • t.Equal(a, b): Assert a Bersamaan dengan b.
  • t.NotEqual(a, b): Menegaskan bahawa a dan b adalah tidak sama.
  • t.True(b): Menegaskan bahawa b adalah benar.
  • t.False(b): Menegaskan bahawa b adalah palsu.
🎜🎜Kes praktikal🎜🎜🎜Mari kami menulis fail ujian yang menguji fungsi mypackage/myfunc: 🎜rrreee🎜Kes ujian ini mentakrifkan tiga kes ujian, setiap satu Setiap ujian case mengandungi tiga pembolehubah input (a, b dan output yang dikehendaki (mahu)). Fungsi ujian menggunakan gelung for untuk berulang melalui kes ujian ini dan memanggil fungsi Tambah untuk setiap kes ujian. Jika output fungsi tidak konsisten dengan nilai yang dijangkakan, ujian gagal dan mesej ralat direkodkan. 🎜

Atas ialah kandungan terperinci Cara yang betul untuk menguji fungsi golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan