Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
PHPUnitしか使ってこなかった 一般PHPerがPestに乗り換えた実録
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
mashirou1234
December 22, 2024
Programming
0
1.7k
PHPUnitしか使ってこなかった 一般PHPerがPestに乗り換えた実録
mashirou1234
December 22, 2024
Tweet
Share
More Decks by mashirou1234
See All by mashirou1234
AIと共に「使うOSS」から「育てるOSS」へ
mashirou1234
0
29
デザインパターンを掘り下げよう ~Singleton Pattern 編~
mashirou1234
3
800
PHP 8.3で追加されたjson_validate()を徹底的に深掘りしてみよう
mashirou1234
1
2.3k
Laravelで共通処理ってどうやるの?
mashirou1234
1
2.2k
改めて見返す「Laravel」とは
mashirou1234
0
430
PHPでドメイン駆動設計を浸透するためにやったことと現状
mashirou1234
0
1.3k
AWS_Lambda_にCustom_Runtimeで_PHPを導入したシステムに改修を加えて_UT導入まで行った話.pdf
mashirou1234
0
750
設計文化のないチームに文化を広めたが冴えない一手で混沌を招いた話を聞いてほしい.pdf
mashirou1234
0
1.7k
Factfullnessは思考ジャックできる良ツールな件について
mashirou1234
0
340
Other Decks in Programming
See All in Programming
「効かない!」依存性注入(DI)を活用したAPI Platformのエラーハンドリング奮闘記
mkmk884
0
220
AI 開発合宿を通して得た学び
niftycorp
PRO
0
170
Angular-Apps smarter machen mit Gen AI: Lokal und offlinefähig - Hands-on Workshop!
christianliebel
PRO
0
140
Nostalgia Meets Technology: Super Mario with TypeScript
manfredsteyer
PRO
0
110
How to stabilize UI tests using XCTest
akkeylab
0
140
実践ハーネスエンジニアリング #MOSHTech
kajitack
7
3.8k
DevinとClaude Code、SREの現場で使い倒してみた件
karia
1
1.1k
Geminiをパートナーに神社DXシステムを個人開発した話(いなめぐDX 開発振り返り)
fujiba
0
100
AIコードレビューの導入・運用と AI駆動開発における「AI4QA」の取り組みについて
hagevvashi
0
560
PHPのバージョンアップ時にも役立ったAST(2026年版)
matsuo_atsushi
0
250
Cyrius ーLinux非依存にコンテナをネイティブ実行する専用OSー
n4mlz
0
250
Reactive ❤️ Loom: A Forbidden Love Story
franz1981
2
160
Featured
See All Featured
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
860
End of SEO as We Know It (SMX Advanced Version)
ipullrank
3
4.1k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
199
73k
Data-driven link building: lessons from a $708K investment (BrightonSEO talk)
szymonslowik
1
980
Bioeconomy Workshop: Dr. Julius Ecuru, Opportunities for a Bioeconomy in West Africa
akademiya2063
PRO
1
75
Information Architects: The Missing Link in Design Systems
soysaucechin
0
840
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Being A Developer After 40
akosma
91
590k
Designing Powerful Visuals for Engaging Learning
tmiket
0
300
How to Think Like a Performance Engineer
csswizardry
28
2.5k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.6k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Transcript
PHPUnitしか使ってこなかった 一般PHPerがPestに乗り換えた実録 PHP Conference 2024 12/22 LT 17:20 ~ 柚口ましろう
アジェンダ ➔ 自己紹介 ➔ LaravelでPestを導入する! ➔ 実装する! ➔ テストコードを書こう! ➔
動かしてみよう! ➔ まとめ
自己紹介 株式会社 Gladiolus LAB 取締役CTO PHP歴:9年くらい 変遷のようなもの: 2014 ~ 2018:SES事業会社
所属 2018 ~ 2022:現親会社 C-Garden 取締役 2022 ~ 現在 :Gladiolus LAB 取締役 CTO 柚口ましろう 登壇させていただいたPHPカンファレンス関係 ・PHP Conference 2019 2023 2024 ← new! ・PHPerKaigi 2022 2024
突然ですが、
突然ですが、みなさん がテストをする時は何を 使いますか?
突然ですが、みなさん がテストをする時は何を 使いますか? 単体テストおよび結合テストを A. 温かみのある手動テストで目視確認! B. 自動テストで効率よく開発! C. とりあえずリリース!
あとのことはなんとかなる!
突然ですが、みなさん がテストをする時は何を 使いますか? 単体テストおよび結合テストを A. 温かみのある手動テストで目視確認! B. 自動テストで効率よく開発! C. とりあえずリリース!
あとのことはなんとかなる!
突然ですが、みなさん がテストをする時は何を 使いますか? みなさんがお使いの PHPテストツールはなんですか?
突然ですが、みなさん がテストをする時は何を 使いますか? みなさんがお使いの PHPテストツールはなんですか? A. PHPUnit B. PHPspec C.
CodeSniffer D. Codeception E. Pest
突然ですが、みなさん がテストをする時は何を 使いますか? みなさんがお使いの PHPテストツールはなんですか? A. PHPUnit B. PHPspec C.
CodeSniffer D. Codeception E. Pest
Pestについて
Pestについて ・BDDライクに振る舞いをチェーンするツール ・最小単位のテストから、ゴリゴリの Featureテ スト も得意としている ・ミューテーションテスト(テスト網羅されて いること を担保するテスト)も完備 ・Laravelに特化している (別にLaravelじゃなくても良い!) ・Jestユーザにはかなり親和性のある作り
Laravelで Pestを導入する! Pestを入れてみる
Laravelで Pestを導入する! Pestを入れてみる
実装しよう!
実装しよう! 流石に非公開コードを 公開するわけにはいかないよなぁ ……
実装しよう! 流石に非公開コードを 公開するわけにはいかないよなぁ …… あ、一から書いちゃお!
実装しよう! 流石に非公開コードを 公開するわけにはいかないよなぁ …… あ、一から書いちゃお! 地獄の扉が開かれました……
実装しよう! https://github.com/mashirou1234/demo-php-confe rence-2024/blob/main/app/Console/Commands/As signCleaningSchedule.php とりあえず作ってみた ・清掃スケジュール週次登録 バッチという「てい」 ・毎週土曜日になったらバッチ が 実行されて登録する
(スケジューラーは今回ス コー プアウトしました) ・首都圏3県を対象に清掃対象 物件に人を割り振る仕組み ※詳しくはGithubのURLをご参照くだ さい (実際にSailでコンテナ起動すれば動 かせるようになっています)
テストコードを 書こう! https://github.com/mashirou1234/demo-php-confe rence-2024/blob/main/tests/Feature/AssignCleanin gScheduleTest.php ざっくりテスト検証 ・それぞれの県の清掃対象物件を Factoryで仮想登録 ・それぞれの県で担当する人数分を Factoryで仮想登録
・とりあえずバッチ実行してスケジュール登録 ・スケジュール登録件数が一致していることを確認する (登録内容の完全一致のデータ検証も本来なら必要 だが、今回は割愛) ・細かいテストも書きました(詳細は Githubから)
テストコードを 書こう! https://github.com/mashirou1234/demo-php-confe rence-2024/blob/main/tests/Feature/AssignCleanin gScheduleTest.php ざっくりテスト検証 ・それぞれの県の清掃対象物件を Factoryで仮想登録 ・それぞれの県で担当する人数分を Factoryで仮想登録
・とりあえずバッチ実行してスケジュール登録 ・スケジュール登録件数が一致していることを確認する (登録内容の完全一致のデータ検証も本来なら必要 だが、今回は割愛) ・細かいテストも書きました(詳細は Githubから)
動かしてみよう!
動かしてみよう!
動かしてみよう! https://github.com/laravel/framework/issues/49502
動かしてみよう! https://github.com/laravel/framework/issues/49502 PHPUnit 11のバグらしいので 例外ハンドラを実行毎にリストア
動かしてみよう! https://github.com/laravel/framework/issues/49502 PHPUnit 11のバグらしいので 例外ハンドラを実行毎にリストア Q:いつ原因が判明したの?
動かしてみよう! https://github.com/laravel/framework/issues/49502 PHPUnit 11のバグらしいので 例外ハンドラを実行毎にリストア Q:いつ原因が判明したの? A:今日の13:50くらいに......
動かしてみよう!
所感 (主観) • PHPUnitでご飯を食べている人(ワイ) ◦ シナリオテストには向いてなさそう Feature系は、例えば単純な GET/POSTなら良いが、 複雑な処理や大掛かりな シナリオテストなると
条件付けが増えるにつれて Pestの旨味を活かした感じを体感仕切れて いない Pestの性質上PHPUnitと大した差はない
所感 (主観) • PHPUnitでご飯を食べている人(ワイ) ◦ シナリオテストには向いてなさそう Feature系は、例えば単純な GET/POSTなら良いが、 複雑な処理や大掛かりな シナリオテストなると
条件付けが増えるにつれて Pestの旨味を活かした感じを体感仕切れて いない Pestの性質上PHPUnitと大した差はない ◦ ユニットテストとの相性は抜群 細かいテストや連結系テストには 大変強い感覚がある Pest自体がLaravel特化なので、 Eloquentとかのコアパッケージが 混ざったテストが書きやすい
所感 (主観) Featureレベル Unitレベル
所感 (弊社メンバー) • テストコードを書いたことない場合 ◦ テストだけどコードを書く感覚は変わらないの でそんな悩まなくてすみそう
所感 (弊社メンバー) • テストコードを書いたことない場合 ◦ テストだけどコードを書く感覚は変わらないの でそんな悩まなくてすみそう • PHPUnitに触れたことない人だったら ◦
メソッドチェーンで書けるのはわかりやすい ◦ JUnitだと1シナリオで全部を盛り盛りにするこ とがあるから、結局4~5000行とかのテスト コードから追わなきゃなので結局面倒になる のがPHPUnitも同じと聞いていたので、Pest ならいいかも
まとめ ポジティブ • PHPUnitをクロージャで書いているような感覚 • DataProvider等でテスト内容を切り出すとかを しないでも良い (逆説的にデータを汎用に作れば良い) • いざコードを読んだときに感覚的に何している
かを把握しやすい ネガティブ • シナリオテストなどの大まかなテストは得意で なさそうなのでPHPUnitで書いた方が安全そう • (個人的に)UnitをPest、FeatureをPHPUnit (Codeception)にするのが良いかも?
まとめ テストフレームワークを 複数組み合わせるならPestほど 単体テストに向いているものはない 「流れに沿って書く」というスタイルが最も 強いので、変更しやすいので保守性が高 い(と思っています) 単体テストをこれから書きたいと思ってい るならPestを導入することをオススメしま す
おまけ! (時間が余ったら) ミューテーションテスト(Infectionみたいなもの)
EOF