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
6k
レガシーな開発現場にUTを入れてCIを導入した話
Web Tech Tokyo #2 CI会
Leko
November 16, 2016
Tweet
Share
More Decks by Leko
See All by Leko
エンジニアと治療アプリ®
leko
0
940
Node.jsにContributeして一ヶ月でCollaboratorになった
leko
5
6.8k
React NativeアプリでE2Eテストを回してみた
leko
8
2.6k
IntersectionObserverはいいぞ
leko
3
2.8k
React Nativeで医療機器作ってます
leko
4
1.5k
趣味では使っているが 仕事には使ってないツール
leko
1
180
MySQLがゆるふわなのはどう考えてもSQLモードが悪い!
leko
1
250
Other Decks in Technology
See All in Technology
Azureの基本的な権限管理の勉強会
yhana
1
2.1k
推しは推せるときに推せ! プロダクトにフィードバックしていこう
nakasho
0
460
一生覚えておきたい「システム開発=コミュニケーション」〜初めての実務案件振り返りLT〜
maimyyym
2
300
BPStudyの200回を中心にIT業界を振り返る。そしてこれから
haru860
3
390
DMM.com アルファ室採用案内資料
hsugita
1
220
Azure Container Apps + Bicep 〜 こんな感じで運用しています
kaz29
3
620
Rustで「プリズモイダル法」を利用して「土量計算」をガチでやる
nokonoko1203
1
280
コードファーストの考え方。 Amplify Gen2から学ぶAWS次世代のWeb開発体験
yoshiitaka
1
310
Cypress or Playwright?
rainerhahnekamp
0
170
MapLibreとAmazon Location Service
dayjournal
1
180
EM完全に理解した と思ったけど、 やっぱり何も分からなかった話 / EM Night Fukuoka #1
hirutas
0
280
AOAI をきっかけに 社内の Azure 管理を見直した話
recruitengineers
PRO
1
450
Featured
See All Featured
Git: the NoSQL Database
bkeepers
PRO
423
63k
How GitHub (no longer) Works
holman
305
140k
Building a Modern Day E-commerce SEO Strategy
aleyda
21
6.4k
The Mythical Team-Month
searls
216
42k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
126
32k
Why Our Code Smells
bkeepers
PRO
331
56k
Designing for humans not robots
tammielis
248
25k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
21
1.4k
Atom: Resistance is Futile
akmur
260
25k
Java REST API Framework Comparison - PWX 2021
mraible
PRO
19
6.9k
Happy Clients
brianwarren
92
6.4k
Code Reviewing Like a Champion
maltzj
515
39k
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かけたい。
• 成果:バグ数軽減、精神衛生向上 • ゆくゆくは開発効率の向上につなげたい。 今後
ありがとうございました! これからも レガシーを駆逐し てゆきます