Go での単体テストと統合テストの区別
Go では、単体テストと統合テストを分離することは、テスト プロセスを合理化し、効率的な実行。
確立されたベストプラクティス
GoLang の testify フレームワークには明示的に定義されたベスト プラクティスはありませんが、いくつかの効果的な手法が存在します。
1.ビルド タグの利用
SoundCloud の Go プラクティスで推奨されているように、ビルド タグ (ビルド パッケージの「ビルド制約」セクションで説明) を利用すると、タグに基づいて特定のテストを選択的に実行できます。
// +build integration var fooAddr = flag.String(...) func TestToo(t *testing.T) { f, err := foo.Connect(*fooAddr) // ... }
go test -tags=integration を呼び出すと、統合ビルド タグで指定されたテストのみを実行できます。あるいは、 // build !unit を使用してデフォルトを設定し、 go test -tags=unit.
2 を実行して無効にすることもできます。テスト メタデータの実装
testing.T タイプの Metadata() 関数を使用すると、テストにメタデータを追加できます。たとえば、値「integration」を持つタグ キーを定義して、テストを統合テストとしてマークできます。
import ( "testing" ) func TestIntegration(t *testing.T) { t.Metadata("Tag", "integration") // ... }
その後、 go test -run integration を使用して、このメタデータに基づいてテストをフィルタリングできます。
3.カスタム フラグの定義
提案したように、メインでカスタム フラグを作成できます:
var runIntegrationTests = flag.Bool("integration", false , "Run the integration tests (in addition to the unit tests)")
各統合テストの開始時に if ステートメントを使用します:
if !*runIntegrationTests { this.T().Skip("To run this test, use: go test -integration") }
このアプローチは簡単ですが、フラグを手動でメンテナンスし、各統合に if ステートメントを追加する必要があります。 test.
ビルド タグまたはテスト メタデータを利用すると、単体テストと統合テストを分離するプロセスを自動化し、テスト ワークフローを簡素化できます。
以上がGo で単体テストと統合テストを効果的に区別するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。