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
テストってなんだろう?
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
itosho
July 24, 2018
Programming
1
300
テストってなんだろう?
クローズドな勉強会でのLT資料です。
itosho
July 24, 2018
Tweet
Share
More Decks by itosho
See All by itosho
【2025年版】インターネットサービスの育て方 / How to Grow and Scale Internet Services 2025
itosho
0
150
Windsurf Rulesでどう自分のクローンをつくるか / How can I make a clone of myself in Windsurf Rules
itosho
0
110
Text EditorとしてのWindsurf / Windsurf as a Text Editor
itosho
0
240
【2024年版】インターネットサービスの育て方 / How to Grow and Scale Internet Services
itosho
0
100
打線組という個人サービスを Goで開発している話 / Indie Service Development by Go
itosho
1
200
Components Reconsidered
itosho
1
2.3k
打線組を支える技術 / The Technology Behind Dasengumi
itosho
0
61
組織をスケールさせるためのTech Vision / Connehito Tech Vision for Growing Our Team
itosho
2
680
生きのびるためのインディー開発 / Indie Development to Survive
itosho
0
57
Other Decks in Programming
See All in Programming
AHC061解説
shun_pi
0
350
Geminiの機能を調べ尽くしてみた
naruyoshimi
0
200
AIとペアプロして処理時間を97%削減した話 #pyconshizu
kashewnuts
1
220
maplibre-gl-layers - 地図に移動体たくさん表示したい
kekyo
PRO
0
240
Agent Skills Workshop - AIへの頼み方を仕組み化する
gotalab555
15
8.4k
Ruby and LLM Ecosystem 2nd
koic
1
410
20260228_JAWS_Beginner_Kansai
takuyay0ne
5
470
Rで始めるML・LLM活用入門
wakamatsu_takumu
0
170
朝日新聞のデジタル版を支えるGoバックエンド ー価値ある情報をいち早く確実にお届けするために
junkiishida
1
780
nuget-server - あなたが必要だったNuGetサーバー
kekyo
PRO
0
220
「やめとこ」がなくなった — 1月にZennを始めて22本書いた AI共創開発のリアル
atani14
0
370
DevinとClaude Code、SREの現場で使い倒してみた件
karia
1
1k
Featured
See All Featured
Google's AI Overviews - The New Search
badams
0
930
A Soul's Torment
seathinner
5
2.4k
Navigating Team Friction
lara
192
16k
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.1k
A designer walks into a library…
pauljervisheath
210
24k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
KATA
mclloyd
PRO
35
15k
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
From π to Pie charts
rasagy
0
150
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
110
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
0
450
Transcript
テストってなんだろう? Connehito Inc. @itosho 1
▪ 自己紹介 ・伊藤 翔 @itosho ・所属:コネヒト株式会社 / リードエンジニア ・会社ではサーバーサイドエンジニアをやっています ・よく書く言語:PHP
/ Ruby / Golang ・家ではYome Driven Developmentをやっています ・つくっているサービス:カレンダー / 家計簿 / セール情報通知
▪ 今日話すこと ・事前にいただいたアンケートに沿って…! ・普段書いているテスト ・テストで苦労していること ・テストのメリット / デメリット ・運用についてのコネヒト社での事例 ・今日話さないこと
・E2Eテスト / 総合テスト ・TDD / BDD
1. テストを実装したことありますか 4
5
2. どのようなテストを実装しましたか 6
▪ 普段書いているテスト / ツール ・Web APIのIntegrationテスト / Unitテスト ・PHPUnit /
RSpec ・CLIツールのUnitテスト ・testingパッケージ(Golang) ・OSSのUnitテスト ・https://github.com/itosho/easy-query ・PHPUnit / codecov
3. テストを実装する際に苦労したことはなんですか 8
▪ 苦労している点 ・テストデータの管理・保守 ・”モノリシック”なFixtureデータ ・あるテストのためにデータを修正すると別のテストが壊れる ⇒FactoryBot(旧: FactoryGirl)を使って動的にデータを作る ・テストのためにミニ言語(DSL)を覚える必要がある ・RSpec /
FactoryBot等 ・高機能なツールであるほど学習コストが高い ⇒Golangでは標準のtestingパッケージのみを使う
▪ 苦労している点 ・外部サービス / コマンドとの連携 ・モックの実装が必要(難しい) ・意味のない壊れやすいスタブ ⇒外部とやりとりを行う境界をinterface(モックポイント)にする ⇒Consumer Driven
Test(あんまり詳しくないですが…) ref: https://deeeet.com/writing/2016/10/25/go-interface-testing/
4. テストを実装して感じたメリットはなんですか 11
▪ メリット ・リファクタ&仕様変更時のスピード&安心感 ・テストが”正しく”壊れる ・暖かみのある回帰テストが不要になる ・テストコードが生きたドキュメントになる ・コードの変更とほぼ自動的に同期される ・テストがあるOSSはダウンロードされやすい ・カバレッジがあるとさらにGood
5. テストを実装して感じたデメリットはなんですか 13
▪ デメリット ・慣れるまで(慣れても?)開発スピードが落ちる ・TDDはこの限りではない(設計技法なので) ・プロダクトが成長するとCIの実行時間が長くなりがち ・特にiOS / Androidのテスト ・教条主義的になりやすい(特にUnitテスト) ・Unitテストを書くとコードの品質が上がる
・Unitテストを書くと設計が綺麗になる ⇒正しいけど正しくない
6. 運用はうまく回っていますか 15
▪ コネヒト社でのCI/CD事例 ・Web APIに関しては原則テストコードを書く ・画面がないのでテストが書きやすい ・PHPUnitを利用 ・CIはTravis CIを利用 ・CI時に静的解析 /
Lintツールを実行 ・使用ツール ・Phan / PHP CodeSniffer ・reviewdog / Danger ⇒機械が出来ることは機械に任せる
まとめ 17
▪ テストとは… ・テストはお金を生まない ・Yome Drive Developmentにおいてテストを書く意味はない ・バグ出したらさっさと直すかケーキでも買ってきたほうがよい ・テストは保険 ・不具合による機会損失と運用コストを予め防ぐ ・自動化することでコスト圧縮が積分で効いてくる
ref: http://shyouhei.tumblr.com/post/73195212853/テストのめどい話 ⇒テストで自分たちの身を守っていこう!
宣伝 19
▪ コネヒトでも勉強会開催します! ・Connehito Marché #3〜iOS市〜 ・8/7(火)19:00〜21:30 ・LT枠 / オーディエンス枠ともに絶賛募集中! ・connpass:
https://connehito.connpass.com/event/95285/ ・Twitter: https://twitter.com/connehitomarche
ご清聴ありがとうございました 21