Go言語のテスト関数の書き方と基本ルール(TestXxx)
生徒
「先生、Go言語でテストを書くときに名前のルールとかありますか?」
先生
「はい、Go言語の単体テストでは関数名をTestで始める必要があります。このルールを守ると、go testコマンドで自動的にテストが実行されます。」
生徒
「具体的にはどう書けばいいんですか?」
先生
「では、簡単な例を見ながら解説しましょう。」
1. テスト関数の基本構造
Go言語のテスト関数は、Testで始まる名前にして、引数にt *testing.Tを受け取ります。t *testing.Tはテストの状態を管理したり、失敗した場合にエラーを出力するために使います。
package main
import "testing"
func Multiply(a, b int) int {
return a * b
}
func TestMultiply(t *testing.T) {
result := Multiply(2, 3)
if result != 6 {
t.Errorf("Multiply(2,3) = %d; want 6", result)
}
}
この例では、Multiply関数が正しく掛け算できるかをチェックしています。結果が期待値と違う場合、t.Errorfでエラーを出力します。
2. TestXxxの命名ルール
テスト関数は必ずTestで始め、続けてアルファベットや数字を使った名前をつけます。例えばTestAddやTestCalculateSumなどです。このルールを守らないとgo testが関数を認識せず、テストが実行されません。
3. テストファイルの名前
テストを書くファイルは、xxx_test.goという名前にします。例えばmath.goというファイルのテストはmath_test.goとするのが一般的です。このルールにより、Goはどのファイルにテストがあるかを自動的に判断します。
4. 複数のテストケースを効率よく書く
一つの関数に対して複数の入力をテストしたい場合、テーブル駆動テストという方法が便利です。テーブル駆動テストでは、入力と期待値を配列にまとめ、ループで順番にチェックします。
func TestMultiplyTable(t *testing.T) {
tests := []struct {
a, b int
want int
}{
{2, 3, 6},
{4, 5, 20},
{0, 10, 0},
}
for _, tt := range tests {
result := Multiply(tt.a, tt.b)
if result != tt.want {
t.Errorf("Multiply(%d,%d) = %d; want %d", tt.a, tt.b, result, tt.want)
}
}
}
この方法で、たくさんのパターンを効率的にテストできます。どの入力で失敗したかもわかりやすく表示されます。
5. テスト実行の基本
テストを実行するには、ターミナルでgo testを使います。テストファイルが正しい名前で保存されていれば、自動的に全てのTestXxx関数を実行します。
go test
テストが全て成功すれば「ok」と表示され、失敗があればエラーの詳細が表示されます。これにより、関数が期待通りに動作しているかを簡単に確認できます。
6. 初心者向けのポイント
初心者はまず、関数ごとに一つずつ簡単なテストを書き、結果を確認することから始めると良いです。関数が増えてきたら、テーブル駆動テストを活用して効率よくテストを行いましょう。エラーメッセージには、どの入力で失敗したかを明確に書くと、原因の特定がしやすくなります。
Go言語のTestXxxルールとxxx_test.goファイル名のルールを守ることで、テストの自動化と効率化が簡単にできます。これにより、プログラムの品質を高めることができます。
【超入門】ゼロから始めるGo言語プログラミング:最速で「動くアプリ」を作るマンツーマン指導
「プログラミングの仕組み」が根本からわかる。Go言語でバックエンド開発の第一歩を。
本講座を受講することで、単なる文法の暗記ではなく、「プログラムがコンピュータの中でどう動いているか」という本質的な理解につながります。シンプルながら強力なGo言語(Golang)を通じて、現代のバックエンドエンジニアに求められる基礎体力を最短距離で身につけます。
具体的な開発内容と環境
【つくるもの】
ターミナル(黒い画面)上で動作する「対話型計算プログラム」や、データを整理して表示する「ミニ・ツール」をゼロから作成します。自分の書いたコードが形になる感動を体験してください。
【開発環境】
プロの現場でシェアNo.1のVisual Studio Code (VS Code)を使用します。インストールから日本語化、Go言語用の拡張機能設定まで、現場基準の環境を一緒に構築します。
この60分で得られる3つの理解
「なぜ動くのか」という設定の仕組みを理解し、今後の独学で詰まらない土台を作ります。
データの種類やメモリの概念など、他言語にも通じるプログラミングの本質を学びます。
ただ動くだけでなく、誰が見ても分かりやすい「綺麗なコード」を書くための考え方を伝授します。
※本講座は、将来的にバックエンドエンジニアやクラウドインフラに興味がある未経験者のためのエントリー講座です。マンツーマン形式により、あなたの理解度に合わせて進行します。
初めてのGo言語を一緒に学びましょう!