Slide 1

Slide 1 text

Laravel でテストしやすいコードを書く5つのコツ 2020/11/14(土) Techpit nunulk

Slide 2

Slide 2 text

No content

Slide 3

Slide 3 text

御礼 100部突破 質問や要望など大歓迎ですので どしどしお寄せください!

Slide 4

Slide 4 text

Agenda • 自動化されたソフトウェアテストの重要性 • テストファースト vs. テストセカンド • Laravel でテストしやすいコードを書くコツ 5 MIN 5 MIN 40 MIN

Slide 5

Slide 5 text

自動化されたソフトウェアテストの重要性

Slide 6

Slide 6 text

自動化されたソフトウェアテストの重要性 共用しているモジュールの変更に 対する変更漏れを防ぐことができ ます。 変更検知 手動テストではテストケースの漏 れや確認ミスが発生しうるが、自 動テストであれば毎回すべてのテ ストケースが実行されます。 人為的ミスの回避 パターンの多いケースを手動で何 度もやるよりはコンピュータにや らせたほうが速くて安上がりで す。 コスト削減

Slide 7

Slide 7 text

テストファースト vs. テストセカンド

Slide 8

Slide 8 text

テストセカンド テストファースト

Slide 9

Slide 9 text

テストセカンド テストファースト

Slide 10

Slide 10 text

テストセカンド テストファースト ・仕様の理解が高い場合に向いている ・実装方法が明瞭な場合に向いている ・テストが書かれないことがある ・仕様の理解が低い場合に向いている ・実装方法が不明瞭な場合に向いている ・テストが確実に書かれる

Slide 11

Slide 11 text

Laravel でテストしやすいコードを書くコツ

Slide 12

Slide 12 text

テストしやすいコードとは? ファイルの読み書きや外部サービ スとのやりとりを分離しておくと テストが書きやすくなります。 副作用が少ない テスト対象のクラスや関数が依存 しているクラスや関数が少なくす ることでテストが書きやすくなり ます。 依存関係が少ない テストしたい対象をできるだけ小 さくすることで、テストが書きや すくなります。 関数が小さい

Slide 13

Slide 13 text

Laravel でテストしやすいコードを書くコツ 1/2 ファイルの読み書きや外部サービ スとのやりとりを分離しておくと テストが書きやすくなります。 副作用を分離する Dependency Injection は、引数に指 定されたクラスのインスタンスを 勝手に生成して渡してくれる仕組 みで、テストのときにクラスの差 し替えが簡単になります。 DI を使う テストしたい対象をできるだけ小 さくすることで、テストが書きや すくなります。 関数をできるだけ小さくす る

Slide 14

Slide 14 text

Laravel でテストしやすいコードを書くコツ 2/2 静的メソッドをモックするのは若 干面倒なので、インスタンス化し ても変わらない場合はインスタン スメソッドにしましょう。 できるだけ静的メソッ ドを使わない Eloquent を使ったモデルの場合プ ロパティが public になりますが、 プロパティアクセスはモックがで きないので、なるべくプロパティ アクセスを減らしましょう。 できるだけプロパティ にアクセスしない