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
レガシーな開発現場にUTを入れてCIを導入した話
Search
Leko
November 16, 2016
Technology
0
6.3k
レガシーな開発現場にUTを入れてCIを導入した話
Web Tech Tokyo #2 CI会
Leko
November 16, 2016
Tweet
Share
More Decks by Leko
See All by Leko
エンジニアと治療アプリ®
leko
0
1.2k
Node.jsにContributeして一ヶ月でCollaboratorになった
leko
5
7.3k
React NativeアプリでE2Eテストを回してみた
leko
8
2.8k
IntersectionObserverはいいぞ
leko
3
3.1k
React Nativeで医療機器作ってます
leko
4
1.7k
趣味では使っているが 仕事には使ってないツール
leko
1
210
MySQLがゆるふわなのはどう考えてもSQLモードが悪い!
leko
1
310
Other Decks in Technology
See All in Technology
2025/6/21 日本学術会議公開シンポジウム発表資料
keisuke198619
0
140
AIコーディング新時代を生き残るための試行錯誤 / AI Coding Survival Guide
tomohisa
9
12k
Whats_new_in_Podman_and_CRI-O_2025-06
orimanabu
3
170
Long journey of Continuous Delivery at Mercari
hisaharu
1
210
讓測試不再 BB! 從 BDD 到 CI/CD, 不靠人力也能 MVP
line_developers_tw
PRO
0
150
バクラクのモノレポにおける AI Coding のための環境整備と {Roo,Claude} Code活用事例 / AI Coding in Bakuraku's Monorepo: Environment Setup & Case Studies with {Roo, Claude} Code
upamune
9
6k
SFTPコンテナからファイルをダウンロードする
dip
0
120
Copilot Agentを普段使いしてわかった、バックエンド開発で使えるTips
ykagano
1
480
成立するElixirの再束縛(再代入)可という選択
kubell_hr
0
230
RubyOnRailsOnDevin+α / DevinMeetupJapan#2
ginkouno
0
310
Securing your Lambda 101
chillzprezi
0
250
「どこにある?」の解決。生成AI(RAG)で効率化するガバメントクラウド運用
toru_kubota
2
380
Featured
See All Featured
For a Future-Friendly Web
brad_frost
179
9.8k
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
StorybookのUI Testing Handbookを読んだ
zakiyama
30
5.8k
Why You Should Never Use an ORM
jnunemaker
PRO
56
9.4k
What's in a price? How to price your products and services
michaelherold
245
12k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
657
60k
Bash Introduction
62gerente
614
210k
How to Ace a Technical Interview
jacobian
276
23k
Six Lessons from altMBA
skipperchong
28
3.8k
Fireside Chat
paigeccino
37
3.5k
Statistics for Hackers
jakevdp
799
220k
Optimising Largest Contentful Paint
csswizardry
37
3.3k
Transcript
レガシーな開発現場にUTを 入れてCIを導入した話 井上 真吾
24歳、鎌倉住まい ブログ: http://leko.jp Twitter: @L_e_k_o Github: Leko 会社:Hamee株式会社 QAIT リーダー
入社2年半、小田原、目黒勤務 品質向上と自動化を追い求めるチーム 井上 真吾(れこ)
話すこと、話さないこと • 話します ◦ つらみを救ってくれたのは CIでした • 話せないです ◦ イケてる会社の最新の事情
◦ 技術負債と向き合う話
2500社近くが導入する、ECのバックエンド一元管理サービス 自社。内製で提供するWebアプリは30近く サービス開始から9年目 PHP, Java, Rubyが主 サポート切れてるバージョンを使ってるサービスも... サービス開始当初は僅かでも経験があれば即採用 仕様書レス、テストレス、レビューレス、仕様レス 動作は手で確かめる。ただしい動きは誰かが知ってる、はず
レガシーな開発現場
• 一部上場、予算も増えて人も増える ◦ 案件開始 → 仕様書もテストもない → 聞いてもわからない → とにかくコード読む ◦ 案件ついでにリファクタ → 安定のデグレ → 誰も触れない化物 ◦
仕様書書き出す → 機能が多すぎる → 形骸化or中途半端な情報 ◦ レビューなし → しょうもない凡ミス → 何も学ばないで二の鉄を踏む ◦ スピード出ない、品質担保で精一杯 • 契約企業が増えれば負荷も増えるし責任も増す ◦ 寿命によるハードウェア障害、スロークエリ、 CPU高沸 etc… • でも売れてる ◦ 売れたまま、スピード感が出せるように加速させたい レガシーが悪いわけではない、が。
• 新卒が「技術力足りない」と思うくらいには低かった • 人も実力者も増え、今やそうではなくなった よろしい、ならば改善だ
• コードレビュー開始 • Doxygen入れてAPIドキュメント生成 • 仕様置き場の確保、旗振り • General logをパースしてERD作成 •
UT書き始める。UT書く案件にはベネフィット持たせて書かせる • ST書き始める。とてもじゃないけど手が回らない • オフショアに頼る。ベトナムに飛んでコミュニケーション取る • オフショアといい感じにUT埋めてる ← いまここ 改善の前段
要は長い、煩雑 メンバーが増えると こっちの管理コスト 増加、凡ミス頻発。 当初の業務フロー
テスト書いてもらうならCIだ
• 社内にCIという文化がない • もう勢いで入れてしまえ、あとでその有用性を分からせる • 動作環境がめちゃくちゃレガシー ◦ CircleCI(phpenv)ではサポートしてくれてないバージョン ◦ chefで作られた超大なレシピ
• Dockerで凌ぐ ◦ Packer + Dockerでコンテナ生成 ◦ 環境がchef製なのが幸いした CIへの壁
CI後の業務フロー 手元でテストを実行 する という不確実な手順 を排除
• ユニットテストを書く文化づくり • 効率化、省力化の文化づくり • 他の製品へのCI横展開 ◦ Java製アプリのビルド・デプロイ自動化 • ドキュメントもCIしたい。lintかけたい。
• 成果:バグ数軽減、精神衛生向上 • ゆくゆくは開発効率の向上につなげたい。 今後
ありがとうございました! これからも レガシーを駆逐し てゆきます