カテゴリ: Go言語 更新日: 2026/01/03

Go言語のテスト関数の書き方と基本ルール(TestXxx)

Go言語のテスト関数の書き方と基本ルール(TestXxx)
Go言語のテスト関数の書き方と基本ルール(TestXxx)

先生と生徒の会話形式で理解しよう

生徒

「先生、Go言語でテストを書くときに名前のルールとかありますか?」

先生

「はい、Go言語の単体テストでは関数名をTestで始める必要があります。このルールを守ると、go testコマンドで自動的にテストが実行されます。」

生徒

「具体的にはどう書けばいいんですか?」

先生

「では、簡単な例を見ながら解説しましょう。」

1. テスト関数の基本構造

1. テスト関数の基本構造
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の命名ルール

2. TestXxxの命名ルール
2. TestXxxの命名ルール

テスト関数は必ずTestで始め、続けてアルファベットや数字を使った名前をつけます。例えばTestAddTestCalculateSumなどです。このルールを守らないとgo testが関数を認識せず、テストが実行されません。

3. テストファイルの名前

3. テストファイルの名前
3. テストファイルの名前

テストを書くファイルは、xxx_test.goという名前にします。例えばmath.goというファイルのテストはmath_test.goとするのが一般的です。このルールにより、Goはどのファイルにテストがあるかを自動的に判断します。

4. 複数のテストケースを効率よく書く

4. 複数のテストケースを効率よく書く
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. テスト実行の基本

5. テスト実行の基本
5. テスト実行の基本

テストを実行するには、ターミナルでgo testを使います。テストファイルが正しい名前で保存されていれば、自動的に全てのTestXxx関数を実行します。


go test

テストが全て成功すれば「ok」と表示され、失敗があればエラーの詳細が表示されます。これにより、関数が期待通りに動作しているかを簡単に確認できます。

6. 初心者向けのポイント

6. 初心者向けのポイント
6. 初心者向けのポイント

初心者はまず、関数ごとに一つずつ簡単なテストを書き、結果を確認することから始めると良いです。関数が増えてきたら、テーブル駆動テストを活用して効率よくテストを行いましょう。エラーメッセージには、どの入力で失敗したかを明確に書くと、原因の特定がしやすくなります。

Go言語のTestXxxルールとxxx_test.goファイル名のルールを守ることで、テストの自動化と効率化が簡単にできます。これにより、プログラムの品質を高めることができます。

カテゴリの一覧へ
新着記事
New1
Go言語
Go言語とは何か?初心者向けに特徴・できること・インストール手順までやさしく解説
New2
Kotlin
Kotlinのコーディング規約(公式スタイルガイド)とは?読みやすいコードを書くための基本ルール
New3
Kotlin
Kotlinの関数型を整理するパッケージ・ファイル構造の例を初心者向けにやさしく解説!
New4
Swift
Swiftデータ型まとめ|String・Int・Bool・Arrayの基本を初心者向けに解説
人気記事
No.1
Java&Spring記事人気No1
Go言語
Go言語の関数パラメータ!値渡しと参照渡しの違いを理解しよう
No.2
Java&Spring記事人気No2
Swift
Swift開発環境の構築方法を徹底解説!Xcode・Windows・Linux対応
No.3
Java&Spring記事人気No3
Kotlin
Kotlinの演算子一覧と使い方!算術・比較・論理演算子の基本を解説
No.4
Java&Spring記事人気No4
Go言語
Go言語のWebアプリにおけるセキュリティベストプラクティス集
No.5
Java&Spring記事人気No5
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.6
Java&Spring記事人気No6
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.7
Java&Spring記事人気No7
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.8
Java&Spring記事人気No8
Kotlin
Kotlinのインストール方法まとめ!Windows・Mac・Linux別にステップ解説