カスタム関数の単体テストには、テスト ファイルの作成、テスト関数の定義、テスト ケースの作成、アサーションの実行が含まれます。失敗したテストのデバッグには、デバッグ情報の有効化、デバッガーの使用、およびブレークポイントの設定が含まれます。
カスタム Go 関数の実装をテストおよびデバッグする方法
Go では、カスタム関数のテストとデバッグが重要です。安全性と堅牢性は非常に重要です。この記事では、Go の組み込みテスト フレームワークとデバッグ ツールを使用した単体テストとカスタム関数のデバッグのプロセスを紹介します。
単体テスト
ステップ 1: テスト ファイルを作成する
テスト対象の関数の場合myfunc
、 myfunc_test.go
という名前のテスト ファイルを作成します。
ステップ 2: テスト関数を定義する
テスト ファイルで、func TestMyfunc
を使用して、テストする関数のテスト関数を定義します。 。テスト関数は Test
で始まり、その後にテストする関数の名前が続く必要があります。
ステップ 3: テスト ケースを作成する
テスト関数で t.Run
を使用して、さまざまなテスト ケースにネストされたテスト関数を追加します。入れ子になった各関数は、エラーや失敗を報告するためのアサーション メソッドを提供する testing.T パラメーターを受け取ります。
ステップ 4: アサーションの実行
testing
パッケージで提供されるアサーション関数 (t.Equal
など) を使用します。 、 t.Error
および t.FailNow
) を使用して、テスト ケースの予想される出力または動作を確認します。
実践的なケース: 文字列の長さを計算する関数のテスト
func TestStrlen(t *testing.T) { t.Run("Empty string", func(t *testing.T) { t.Equal("", strLen("")) }) t.Run("Non-empty string", func(t *testing.T) { t.Equal(5, strLen("Hello")) }) }
デバッグ
テストが失敗した場合、または関数が実行されない 期待どおりの場合は、Go のデバッグ ツールを使用してデバッグできます。
ステップ 1: デバッグ モードをオンにする
-gcflags="all=-N -l"
フラグを使用してプログラムをコンパイルして有効にします。デバッグ情報。
ステップ 2: デバッガーの使用
デバッガー (delve や gdb など) を起動し、実行中のプログラムに接続します。
ステップ 3: ブレークポイントを設定し、変数を検査します。
デバッガーを使用して、関数の実行中にブレークポイントを設定し、変数値を検査します。
ステップ 4: コードにステップインする
デバッガーのシングルステップ機能を使用して、コードを 1 行ずつステップ実行し、各ステップの後に変数値を調べます。 。
実践的なケース: フィボナッチ数列を計算する関数のデバッグ
デバッグには delve を使用します:
$ delve debug app (delve) b fibonacci # 设置断点 (delve) c # 继续执行 (delve) next # 单步执行 ... (delve) p fibonacci(5) # 检查变量值
以上がカスタム golang 関数の実装をテストおよびデバッグする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。