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

Go言語のテストでエラー出力を確認する方法と工夫

Go言語のテストでエラー出力を確認する方法と工夫
Go言語のテストでエラー出力を確認する方法と工夫

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

生徒

「Go言語でテストを書いているとき、エラー出力を確認するにはどうすればいいですか?」

先生

「Goではtestingパッケージのt.Errort.Errorfを使ってエラーを出力できます。また、標準出力や標準エラーに書き出すことで、どの部分で失敗したかを確認できます。」

生徒

「標準出力に書くのと、テスト結果で確認するのは違うんですか?」

先生

「はい、標準出力は実行中の情報を見るために使い、t.Errorはテストの失敗として記録されます。両方をうまく使うとデバッグがしやすくなります。」

1. エラー出力の基本

1. エラー出力の基本
1. エラー出力の基本

Go言語の単体テストでは、t.Errort.Errorfを使ってテスト失敗時にメッセージを出力します。t.Errorは文字列を出力してテストを失敗させます。t.Errorfはフォーマット付きでメッセージを出力できるので、変数の値も確認できます。

2. 基本的な使い方

2. 基本的な使い方
2. 基本的な使い方

次の例は、整数の加算関数をテストして、期待した値と異なる場合にエラー出力を確認する方法です。


package main

import "testing"

func Add(a, b int) int {
    return a + b
}

func TestAdd(t *testing.T) {
    got := Add(2, 3)
    want := 6
    if got != want {
        t.Errorf("Add(2, 3) = %d; want %d", got, want)
    }
}

この場合、gotの値がwantと異なるため、テストは失敗し、エラー出力が表示されます。

3. 標準出力を使ったデバッグ

3. 標準出力を使ったデバッグ
3. 標準出力を使ったデバッグ

テスト中に変数の値や処理の流れを確認したいときは、fmt.Printlnを使って標準出力に表示する方法もあります。テストが失敗する原因を特定するのに便利です。


import "fmt"

func TestAddDebug(t *testing.T) {
    a, b := 2, 3
    got := Add(a, b)
    fmt.Println("Debug: a =", a, "b =", b, "got =", got)
    want := 5
    if got != want {
        t.Errorf("Add(%d, %d) = %d; want %d", a, b, got, want)
    }
}

このように出力すると、どの値が想定と異なるかを確認できます。ただし、大量のテストでは出力が多くなるため、必要な箇所だけ出力する工夫が重要です。

4. エラー出力の工夫

4. エラー出力の工夫
4. エラー出力の工夫

複雑な関数をテストする場合、エラー出力をわかりやすくする工夫が役立ちます。例えば、テストケースに名前を付けたり、サブテストとして実行する方法があります。


func TestAddTable(t *testing.T) {
    tests := []struct {
        name string
        a, b int
        want int
    }{
        {"2と3の加算", 2, 3, 5},
        {"0と5の加算", 0, 5, 5},
    }

    for _, tt := range tests {
        t.Run(tt.name, func(t *testing.T) {
            got := Add(tt.a, tt.b)
            if got != tt.want {
                t.Errorf("Add(%d, %d) = %d; want %d", tt.a, tt.b, got, tt.want)
            }
        })
    }
}

このようにサブテストに名前をつけると、どのケースが失敗したか一目でわかります。エラー出力が整理され、デバッグが効率的になります。

Go言語を基礎からスッキリ学びたい人や、 文法だけでなく「実用的な使い方」まで押さえたい人には、 定番の入門書がこちらです。

基礎からわかるGo言語をAmazonで見る

※ Amazon広告リンク

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

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

初心者はまずt.Errort.Errorfを使ってエラー出力を確認することから始めましょう。テストケースに名前を付ける、標準出力で変数の値を確認する、必要に応じてサブテストを活用する、といった工夫で、テストの可読性とデバッグ効率が大きく向上します。Go言語のテストでエラー出力を上手に活用することは、バグを早く発見し、品質の高いプログラムを書くために重要なスキルです。

関連セミナーのご案内

【超入門】ゼロから始めるGo言語プログラミング:最速で「動くアプリ」を作るマンツーマン指導

「プログラミングの仕組み」が根本からわかる。Go言語でバックエンド開発の第一歩を。

本講座を受講することで、単なる文法の暗記ではなく、「プログラムがコンピュータの中でどう動いているか」という本質的な理解につながります。シンプルながら強力なGo言語(Golang)を通じて、現代のバックエンドエンジニアに求められる基礎体力を最短距離で身につけます。

具体的な開発内容と環境

【つくるもの】
ターミナル(黒い画面)上で動作する「対話型計算プログラム」や、データを整理して表示する「ミニ・ツール」をゼロから作成します。自分の書いたコードが形になる感動を体験してください。

【開発環境】
プロの現場でシェアNo.1のVisual Studio Code (VS Code)を使用します。インストールから日本語化、Go言語用の拡張機能設定まで、現場基準の環境を一緒に構築します。

この60分で得られる3つの理解

1. 環境構築の完全な理解

「なぜ動くのか」という設定の仕組みを理解し、今後の独学で詰まらない土台を作ります。

2. Go言語の基本構造(変数・型)

データの種類やメモリの概念など、他言語にも通じるプログラミングの本質を学びます。

3. 読みやすいコードの書き方

ただ動くだけでなく、誰が見ても分かりやすい「綺麗なコード」を書くための考え方を伝授します。

※本講座は、将来的にバックエンドエンジニアクラウドインフラに興味がある未経験者のためのエントリー講座です。マンツーマン形式により、あなたの理解度に合わせて進行します。

セミナー画像

初めてのGo言語を一緒に学びましょう!

カテゴリの一覧へ
新着記事
New1
Go言語
Go言語のスコープとは?ローカル変数・グローバル変数の違いと使い分け
New2
Go言語
Go言語の構文ルールまとめ!インデント・セミコロンなど最初に知っておくポイント
New3
Kotlin
KotlinのwithTimeoutでタイムアウト処理を設定しよう!初心者にもわかる非同期の安全な止め方
New4
Go言語
Go言語のマップの順序保証がない理由と扱い方の工夫をやさしく解説!初心者でもわかる基本知識
人気記事
No.1
Java&Spring記事人気No1
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.2
Java&Spring記事人気No2
Kotlin
Kotlinのsettings.gradleファイルを完全解説!初心者でもわかるプロジェクト設定の基本
No.3
Java&Spring記事人気No3
Go言語
Swiftの配列(Array)の使い方を完全ガイド!初心者でもわかるデータのまとめ方
No.4
Java&Spring記事人気No4
Go言語
Go言語でREST APIを作る設計と実装パターン完全ガイド!初心者でもわかるAPI開発
No.5
Java&Spring記事人気No5
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.6
Java&Spring記事人気No6
Go言語
Go言語のSQLインジェクション対策を完全解説!初心者でも安全なデータベース操作がわかる
No.7
Java&Spring記事人気No7
Go言語
Go言語のgo installコマンドの役割とインストール先の仕組みを徹底解説!
No.8
Java&Spring記事人気No8
Go言語
Go言語のトランザクション処理を完全解説!Begin・Commit・Rollbackを初心者向けにやさしく理解