Keyboard shortcuts

Press or to navigate between chapters

Press S or / to search in the book

Press ? to show this help

Press Esc to hide this help

[インデックス 12087] ファイルの概要

このコミットは、Go言語の標準ライブラリnetパッケージにおけるテストデータファイルの配置に関する変更です。具体的には、hosts_testdataという名前のテストデータファイルを、Goプロジェクトの慣例に従いtestdata/hostsというパスに移動し、それに伴いテストコード内の参照パスを更新しています。

コミット

commit 6e4ddc6872fd5d884847b35ec5f3cfc0276aef50
Author: Mikio Hara <mikioh.mikioh@gmail.com>
Date:   Tue Feb 21 07:11:44 2012 +0900

    net: move hosts testdata to testdata folder
    
    R=golang-dev, rsc
    CC=golang-dev
    https://golang.org/cl/5687052

GitHub上でのコミットページへのリンク

https://github.com/golang/go/commit/6e4ddc6872fd5d884847b35ec5f3cfc0276aef50

元コミット内容

このコミットの元の内容は、src/pkg/net/hosts_testdataというテストデータファイルをsrc/pkg/net/testdata/hostsに移動し、それに合わせてsrc/pkg/net/hosts_test.go内のhostsPath変数の参照を更新するというものです。

変更されたファイル:

  • src/pkg/net/hosts_test.go: テストコード内のパス参照を修正。
  • src/pkg/net/{hosts_testdata => testdata/hosts}: テストデータファイルの名前変更と移動。

具体的な変更点:

  • src/pkg/net/hosts_test.goの37行目: - hostsPath = "hosts_testdata" + hostsPath = "testdata/hosts"

変更の背景

この変更の背景には、Go言語のプロジェクトにおけるテストデータの管理に関する慣習があります。Goでは、テストに関連する補助ファイル(テストケースの入力データ、期待される出力、設定ファイルなど)をtestdataという名前のディレクトリに配置することが推奨されています。これは、Goのツールチェインがtestdataディレクトリを特別扱いし、テスト実行時にその内容を無視しないようにするためです。

このコミット以前は、hosts_testdataというファイルがsrc/pkg/net/ディレクトリ直下に置かれていました。これをtestdata/hostsというサブディレクトリに移動することで、以下の利点が得られます。

  1. 慣習への準拠: Goコミュニティにおけるテストデータ配置の標準的な慣習に合わせることで、コードベースの可読性と保守性が向上します。
  2. 明確な役割分担: testdataディレクトリにテスト関連ファイルを集約することで、どのファイルがテストデータであるかが一目で分かりやすくなります。
  3. ツールとの連携: go testコマンドなどのGoツールはtestdataディレクトリを認識するため、将来的なツール連携や自動化が容易になります。

前提知識の解説

Go言語のnetパッケージ

netパッケージは、Go言語の標準ライブラリの一部であり、ネットワークI/O機能を提供します。TCP/IP、UDP、Unixドメインソケットなどのネットワークプロトコルを扱うための基本的なインターフェースや、DNSルックアップ、ホスト名解決などの機能が含まれています。このコミットで扱われているhosts_test.goは、netパッケージ内のホスト名解決機能(/etc/hostsファイルのような静的なホスト情報からの解決)のテストに関連しています。

/etc/hostsファイル

/etc/hosts(WindowsではC:\Windows\System32\drivers\etc\hostsなど)は、IPアドレスとホスト名のマッピングを定義するプレーンテキストファイルです。DNS(Domain Name System)が普及する以前から存在し、現在でも特定のホスト名解決をオーバーライドしたり、ローカル開発環境で特定のドメインをローカルIPアドレスに解決するために使用されたりします。netパッケージのホスト名解決機能は、このhostsファイルのような静的情報を参照する場合があります。

Go言語におけるtestdataディレクトリ

Go言語のテストにおいて、testdataという名前のディレクトリは特別な意味を持ちます。

  • go testコマンドは、testdataディレクトリ内のファイルをテストの入力として使用できます。
  • go buildコマンドは、testdataディレクトリ内のファイルをビルド対象から除外します。これにより、テストに必要な大きなデータファイルが最終的なバイナリに含まれるのを防ぎます。
  • この慣習は、テストコードとテストデータを明確に分離し、プロジェクトの構造を整理するのに役立ちます。

Go言語のコードレビューシステム (Gerrit/golang.org/cl)

https://golang.org/cl/5687052というリンクは、Goプロジェクトが当時使用していたコードレビューシステムであるGerritのチェンジリスト(CL: Change List)を指しています。Goプロジェクトでは、変更がメインリポジトリにマージされる前に、Gerritを通じてレビュープロセスを経ることが一般的でした。このリンクは、このコミットがマージされる前の議論や承認の履歴を示しています。

技術的詳細

このコミットの技術的な詳細は、主にファイルパスの変更と、それに伴うテストコードの修正に集約されます。

  1. ファイル移動とリネーム:

    • 元のファイル: src/pkg/net/hosts_testdata
    • 移動先: src/pkg/net/testdata/hosts
    • この変更は、単にファイル名を変更するだけでなく、testdataという新しいディレクトリを作成し、その中にファイルを配置するという構造的な変更を含んでいます。Gitのrename fromrename toの表示は、このファイルが移動・リネームされたことを示しています。similarity index 100%は、ファイルの内容が変更されていないことを意味します。
  2. テストコード内のパス参照の更新:

    • src/pkg/net/hosts_test.go内のhostsPath変数は、テストで使用される静的なホスト情報ファイルのパスを保持していました。
    • 変更前: hostsPath = "hosts_testdata"
    • 変更後: hostsPath = "testdata/hosts"
    • この修正により、テストコードが新しい場所にあるテストデータファイルを正しく参照できるようになります。これは、テストが引き続き機能するための必須の変更です。

この変更は、機能的な変更ではなく、コードベースの保守性とGoプロジェクトの慣習への準拠を目的としたリファクタリングの一種です。テストデータの配置を標準化することで、将来的に他の開発者がコードを理解しやすくなり、またGoのツールチェインが提供するtestdataの恩恵を受けることができます。

コアとなるコードの変更箇所

このコミットにおけるコアとなるコードの変更箇所は、src/pkg/net/hosts_test.goファイル内のhostsPath変数の初期化部分です。

diff --git a/src/pkg/net/hosts_test.go b/src/pkg/net/hosts_test.go
index 1bd00541c6..064e7e4328 100644
--- a/src/pkg/net/hosts_test.go
+++ b/src/pkg/net/hosts_test.go
@@ -34,7 +34,7 @@ var hosttests = []hostTest{
 
 func TestLookupStaticHost(t *testing.T) {
 	p := hostsPath
-	hostsPath = "hosts_testdata"
+	hostsPath = "testdata/hosts"
 	for i := 0; i < len(hosttests); i++ {
 		tt := hosttests[i]
 		ips := lookupStaticHost(tt.host)

そして、ファイルシステム上でのファイルのリネームと移動です。

diff --git a/src/pkg/net/hosts_testdata b/src/pkg/net/testdata/hosts
similarity index 100%
rename from src/pkg/net/hosts_testdata
rename to src/pkg/net/testdata/hosts

コアとなるコードの解説

src/pkg/net/hosts_test.go内の変更は、TestLookupStaticHostというテスト関数内でhostsPathというグローバル変数(またはパッケージレベル変数)の値を一時的に変更している部分です。

  • p := hostsPath: 元のhostsPathの値をpに保存しています。これはテストの実行後に元の状態に戻すための一般的なパターンです(このコミットのdiffには含まれていませんが、通常はdeferなどを使って元の値に戻します)。
  • - hostsPath = "hosts_testdata": 変更前のコードでは、テストデータファイルがhosts_testdataという名前で、テストコードと同じディレクトリにあることを想定していました。
  • + hostsPath = "testdata/hosts": 変更後のコードでは、テストデータファイルがtestdataというサブディレクトリ内のhostsという名前であることを示しています。

この変更は、テストが依存する外部ファイル(この場合は静的なホスト情報を提供するファイル)のパスを更新するものです。テストのロジック自体には変更がなく、単にその入力データがどこにあるかを指し示すパスが変更されただけです。

ファイルのリネームと移動は、Gitの観点からはrename fromrename toとして記録されており、これはファイルの内容が変更されずにパスだけが変わったことを意味します。similarity index 100%がその証拠です。これにより、Gitは効率的に変更を追跡できます。

関連リンク

参考にした情報源リンク