リファクタリング前にテストコードを書く #
Description #
ソフトウェア開発の現代世界において、GitHub Copilotのようなツールが手元にあると、リファクタリングは楽しく魅力的なタスクになるかもしれません。変更を加えることは非常に簡単ですが、適切なテストがない場合、最も有望なコードの変更でも予期せぬ結果につながることがあります。このパターンは、コードをリファクタリングする前にテストを記述して機能が一貫していることを確認する重要性を強調しています。テストを安全ネットと考えてください。問題が深刻化する前に問題を検出します。
Example #
ショッピングカートの合計価格を計算する関数があるとし、これをより明確にリファクタリングしたいと考えたとします。以下は元のコードです:
def total_price(items):
return sum(item['price'] * item['quantity'] for item in items)
リファクタリング前に、既存の機能が保持されていることを確認するためにテストを記述します:
def test_total_price():
items = [
{'price': 5, 'quantity': 2},
{'price': 3, 'quantity': 1}
]
assert total_price(items) == 13
これでコードをリファクタリングして、可読性を向上させることができます:
def total_price(items):
total = 0
for item in items:
total += item['price'] * item['quantity']
return total
テストはまだ合格しますので、リファクタリングによって期待される結果が変わっていないことを保証します。
Exercise #
- エクササイズ 1: リファクタリングが必要な関数を記述し、それに対応するテストを記述します。
- エクササイズ 2: テストが合格することを確認しながら関数をリファクタリングします。
- エクササイズ 3: リファクタリングした関数に誤った変更を加えてエラーが発生する状況を模倣し、テストがエラーを検出する過程を観察します。
Checklist for Further Learning #
- コードの重要な側面をすべてカバーするためにテストがどのように確認されますか?
- 選択したプログラミング言語で、テストを記述して実行するためのツールやフレームワークは何ですか?
- リファクタリング時にテスト駆動開発(TDD)のプラクティスをどのように適用できますか?
- テストを整理するためのベストプラクティスは何ですか?
- コードが進化するにつれてどのようにメンテナンスや更新ができますか?