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
あけの
April 23, 2022
Programming
1
280
設計とテストの必要性について考える
あけの
April 23, 2022
Tweet
Share
More Decks by あけの
See All by あけの
Reactハンズオンラーニングを読んだので感想を語る
akeno
1
630
TypeScriptのエラー処理(ES2022の新機能を添えて)
akeno
3
2.8k
oapi-codegenを使ってみた
akeno
0
2.6k
こんな案件は嫌だ(※個人の感想です)
akeno
1
200
SQLアンチパターンから学ぶテーブル設計
akeno
0
580
VSCode Remote Containers のすすめ
akeno
0
280
Other Decks in Programming
See All in Programming
Constant integer division faster than compiler-generated code
herumi
2
670
CLI ツールを Go ライブラリ として再実装する理由 / Why reimplement a CLI tool as a Go library
ktr_0731
3
1.1k
AIレビュアーをスケールさせるには / Scaling AI Reviewers
technuma
2
210
コーディングは技術者(エンジニア)の嗜みでして / Learning the System Development Mindset from Rock Lady
mackey0225
2
540
『リコリス・リコイル』に学ぶ!! 〜キャリア戦略における計画的偶発性理論と変わる勇気の重要性〜
wanko_it
1
570
GitHub Copilotの全体像と活用のヒント AI駆動開発の最初の一歩
74th
8
3k
兎に角、コードレビュー
mitohato14
0
140
GUI操作LLMの最新動向: UI-TARSと関連論文紹介
kfujikawa
0
990
サーバーサイドのビルド時間87倍高速化
plaidtech
PRO
0
160
管你要 trace 什麼、bpftrace 用下去就對了 — COSCUP 2025
shunghsiyu
0
440
書き捨てではなく継続開発可能なコードをAIコーディングエージェントで書くために意識していること
shuyakinjo
1
290
CEDEC2025 長期運営ゲームをあと10年続けるための0から始める自動テスト ~4000項目を50%自動化し、月1→毎日実行にした3年間~
akatsukigames_tech
0
140
Featured
See All Featured
Become a Pro
speakerdeck
PRO
29
5.5k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
283
13k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
358
30k
The Illustrated Children's Guide to Kubernetes
chrisshort
48
50k
Visualization
eitanlees
146
16k
[RailsConf 2023] Rails as a piece of cake
palkan
56
5.8k
Scaling GitHub
holman
462
140k
A designer walks into a library…
pauljervisheath
207
24k
Code Reviewing Like a Champion
maltzj
525
40k
Intergalactic Javascript Robots from Outer Space
tanoku
272
27k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
PRO
23
1.4k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.5k
Transcript
@akeno_0810 2022.04.23 設計とテストの 必要性について考える つながる勉強会 #14
はじめに テストと設計が重要だということを 周りに語って広げることができる 目標 内容 用語の定義 今までのWeb系開発から得られた 「良かったこと」を話したい テスト=自動テスト(CIで回せるもの) 設計=どこにどんなコードを書くのかの考え方
About this talk
設計を考えなくても動く。 テストを書かなくても動く。 早く動くものを作るのが大事。 3年くらい前の私 積んでた本
出来るだけ早く動くものを作る これは正しい。 良さそうな設計を考えることは時間がかかる。 設計を守ってコードを書く、時にはリファクタリングするのは時間がかかる。 テストを書くのは時間がかかる。 動作が変わった時にテストを修正することにも時間がかかる。 テストの実行環境を整備することにも時間がかかる。 コストを支払ってでもやる価値はどこにあるのか?
設計とテストの必要性とは?
設計の必要性 変更への対応を最小限にする コピペコードを減らす DRY原則を守りやすい 共通部分の再利用 同じ変更を複数箇所で行う必要がなくなる 変更からの影響を最小限にする 作業領域の分担が容易になることによるスケール 他の作業からの影響を受けづらい 離れた箇所の変更の影響を受けない
コンフリクトの防止
テストの必要性 最低限の品質の保証 使用者を想定したコードが書ける テストを書く際にそのコードを呼び出す側の気持ちになる 実装者と使用者両方の視点からコードを検証できる 仕様・実装への理解が深くなる 変更のハードルを下げる テストを書いた部分は常に動作が保証されている コードの書き換えが気軽に行える 常に良いコードベースを保ちやすくなる
設計と テストの 共通項 +α 規模や期間が大きくなる ほど効果が高くなる 開発が進むにつれて、 コードに手を加えるのが 難しくなっていくため。 1つ1つのコードの役割が
明確になるため。 担当する機能への適切な テストが書ける。 テストが書きづらい→ 使いづらいということ。 設計が良くない可能性に 早く気付ける。 テストを書いていると、 設計を見直すことができる 変更に強い 設計をすればテストが 書きやすくなる
About this talk おわりに テストと設計が重要だということを 周りに語って広げることができる 目標 結果 テストが最低限の品質を保証すf
設計がテストのしやすさに繋がる、逆もあf この2つが変更の容易さと開発効率を決める ・設計について学ぶ際はどうテストしていくの かについて一緒に考えたい ・チームで認識を合わせることで必要のないや り取りが減る 取り組む際に考えたいこと
Thank you! お世話になっている本