これは2019年5月31日に開催したPHPerイベントYYPHP#86のイベントレポートです。
YYPHPは一言で「PHPerの部室」です。PHPについて、雑に、ゆるく、ワイワイ話し合う集いです。毎回お題を決めずに雑談を出発点にいろいろなことを突発的にやります。集まった人でコードリーディングをすることもあれば、一緒に開発ツールを触ってみたり、フレームワークについての情報交換をすることもあります。開催はほぼ毎週、高田馬場にて。
今回の配信動画
YYPHP https://t.co/2GytPg1hRe
— suin❄️PHPでオブジェクト指向 (@suin) 2019年5月31日
過去回の配信動画
雑談
みんなPHPでどんな仕事をしているのか? (やぎ)
- Laravelのほうが人気という情報を聞いているので、Laravelを勉強しておいたほうがいいと感じている。
- なぜLaravelがCakePHPより人気?
- Laravelのほうが開発が活発
- コミュニティが大きい
- コードがきれい
- Laravelカンファレンスは聞くけど、CakePHPカンファレンスはあまり聞かない
- Laravelのほうが開発が活発
- 最近のプロジェクトだったらLaravel
- Laravelの方が新規案件は圧倒的に多いのは間違いないとして、あえて他の視点で聞きたいんだけど、初学者がMVCフレームワークの理解をしたいって意味でもやっぱLaravel?
- 他のフレームワークでも変わらないと思う
- 機能的にはどう違うのでしょうか?
- CakePHP3のほうが機能が少ない
- DI, アセットパイプラインなどがない
- Laravelのほうが公式パッケージが豊富: 認証、決済など
- CakePHP3のほうが機能が少ない
- CakePHPは3系から良くなったと聞いた
- 物自体は良くなったけど、いろいろが犠牲になった
- バージョンアップするごとに不具合が出る?
- 不具合というより互換性が崩れる
- いまのLaravelはごちゃついてきているので、今後が不安なところ。6系になったときにクリーンになってほしいところ
- PRでゴミがじょじょに溜まってきてる感じ
- 意外とCakePHPの案件は多いんですよね。Lancersとかで見ると、件数ではCakePHPの案件がLaravelの倍以上あったりする。保守案件が多いんですかね?
- 保守な気がする
- 新規案件ではほぼチョイスされていない気がするけど
- 過去のコードは直していくか?
- 実質難しい
単体テストをやっていきたい (しゅんすけ)
Tinker、PHPUnitを使ったテストをやっていきたいので、テストプロのsuinさんに聞きたい。
- Psysh, TinkerはREPL
- 簡単な動作確認
- アドホックなテスト
- PHPUnitはテストフレームワーク
- しきい値、境界値とかのテスト
- テーブルドリブンテスト
- dataProvider
- テーブルドリブンテスト
- 型のテストする?
- 型のテストは方宣言があるのでしない
- 新しく作るものは
declare(strict_types=1)
で書く主義- (PhpStormのテンプレートに入れた)
- PHPUnitでテストする項目ってどうやって決めている?
- 仕様(spec) → テスト → 実装
- ATDD (acceptance test driven development)
- 受け入れテスト駆動開発
- README.md
- テスト書きにくいときはだいたいなにか間違っている(だいたい機能がごちゃっとからまって分離できていない)
- いいテスト、悪いテスト
- 仕様によるもの、テストコードによるものどっちもある
- テストコードをプロダクションコードとみなしていないと陥りがち
- 何千行もあるような
- 単体テストって足かせ
- 変な単体テストがいっぱいあるとテスト対象コードを変えにくくなっちゃう
-
assert
だらけのテストメソッド: 悪い - ドキュメントになっている
- Test Code as a Document
- 仕様によるもの、テストコードによるものどっちもある
- DIはテストしやすくなる
- 自動化にはJenkins?CircleCI?を使っていますか
- CI: Continuous Integration (継続的インテグレーション)
- CIの目的
- 継続的にインテグレーションする
- インテグレーションとは、チームで作っているコード(などいろいろな成果物)を頻繁に統合すること
- ビルドを頻繁にやるところがCIの起原
- 継続的にインテグレーションする
- CIの目的
- CircleCI: SaaS。サービスで使えるプラグインで拡張できる範囲。
- Jenkins: セルフホスト。柔軟性は高い。
- セキュリティ上外部にホストしたくないとき
- GitLab CIが好き
- SaaSもある
- CI: Continuous Integration (継続的インテグレーション)
コントローラの重複した処理をどうまとめたらいいか (しゅんすけ)
実装プロのsuinさんに、聞きたい。
顧客登録と管理者側での顧客登録があるが、それぞれのコントローラに同じ処理を書いてしまった。
キレイな実装はどうするべきだったのか聞きたい。
- まとめるべき
- Serviceを作る
- CustomerRegisterationService
- CustomerRegisterationController → CustomerRegisterationService
- AdminCustomerRegisterationController → CustomerRegisterationService
- Serviceを作る
- BaseControllerとか継承でまとめるのは良くない
オブジェクト指向を知りたいですかぁ? (reoring)
何を知ったらオブジェクト指向がわかったという感覚になるのか?
おぶじぇくとしこうってなんですか?
- よく言われるやつ: 継承、カプセル化、ポリモーフィズム
- オブジェクト指向の実装技術で本質ではない気がする
- pure fabrication(純粋人工物?)
- Repository、Factory、Filter……
- オブジェクトモデルには出てこないけど、プログラムとして動かすには必要不可欠なオブジェクト。
- 変更に強いコードを書きたい、バグが少ないコードを書きたいと思ったときに、オブジェクト指向が歴史的に知見が溜まってそうだから
- アジャイルソフトウェア開発の奥義 第2版 オブジェクト指向開発の神髄と匠の技 | ロバート・C・マーチン, Robert C. Martin, 瀬谷 啓介 |本 | 通販 | Amazon
- OOA、OOD、OOP
フレームワークを使うときって基礎をわかってる必要がありますか? (たける)
- PHPの基礎
- ある程度わかってないとどっちがPHPかフレームワークなのか混乱しそう
- Laravelでなんかあったときに問題の切り分けとかができない気がする
- SQLの基礎
- ORM便りだとなんかあったときに何もできないので
- N+1問題
- インデックス
- フレームワークが裏で何をしてるのか理解する必要があるのか気になりました。
- 知っといたほうがいいけどマストではないと思う
YYPHPは毎週やってます
PHPについてワイワイ話したい方は、YYPHPのイベント情報をチェックしてみて下さい。
以上、YYPHPのレポートでした。次回もワイワイやっていきたいと思います! では、また来週!