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
巨大モジュラーモノリスのテスト戦略.pdf
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Shinobu Hayashi
October 23, 2025
Technology
96
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
巨大モジュラーモノリスのテスト戦略.pdf
Shinobu Hayashi
October 23, 2025
More Decks by Shinobu Hayashi
See All by Shinobu Hayashi
AI フレンドリーなエラー監視を TypeScript で実現する
shinyaigeek
2
280
ESLint Rule により事業, 技術ドメインに沿った制約と誓約を敷衍させるアプローチのすゝめ
shinyaigeek
1
5.9k
Big “heart” of mud, 10000 lines VCL generated from .vcl.handlebars
shinyaigeek
0
320
Managing "side effect" in Frontend Development
shinyaigeek
3
4.1k
爆速の日経電子版開発の今
shinyaigeek
3
3.2k
加速するEdge Computing
shinyaigeek
6
7.1k
ブラウザ作りのすゝめ
shinyaigeek
1
580
ASTをいじいじして僕のかんがえた最強のDXを得る
shinyaigeek
0
500
フロントエンド
shinyaigeek
0
230
Other Decks in Technology
See All in Technology
"何を作るか"を任される エンジニアは、どう育つのか
yutaokafuji
1
270
AWSシリコン最前線 〜AI時代のチップ選択を読み解く〜
htokoyo
2
290
DevOps Agentで始めるAWS運用 〜フロンティアエージェントが変える運用の現場〜
nyankotaro
1
340
AmazonRoute 53ではじめてのドメイン取得!HTTPS化までの道のりを整理してみた
usanchuu
3
120
サプライチェーンセキュリティの空白地帯 - 信頼できる”依存性”の未来を考える
rung
PRO
2
800
「エンジニア進化論」2028年の開発完全自動化、エンジニアはどう進化するか
cyberagentdevelopers
PRO
2
210
生成 AI × MCP で切り拓く次世代 SRE!自律型運用への挑戦と開発者体験の進化
_awache
0
170
Platform Engineering as a Product: Criteria for Improvement and Multi-Tenant Design
kumorn5s
0
530
AI-DLCを活用した高品質・安全なAI駆動開発実践 / AI Driven Development with AI-DLC
yoshidashingo
0
160
あなたの AI ワークスペースに、 専門コーダーを連れてくる - Amazon Quick Desktop 最新情報
kawaji_scratch
1
120
Building applications in the Gemini API family.
line_developers_tw
PRO
0
2.4k
Snowflakeと仲良くなる第一歩
coco_se
3
310
Featured
See All Featured
The browser strikes back
jonoalderson
0
1.2k
Odyssey Design
rkendrick25
PRO
2
690
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
560
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
<Decoding/> the Language of Devs - We Love SEO 2024
nikkihalliwell
1
240
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
940
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
150
Balancing Empowerment & Direction
lara
6
1.1k
Building a Scalable Design System with Sketch
lauravandoore
463
34k
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
770
Speed Design
sergeychernyshev
33
1.8k
Transcript
巨大モジュラーモノリスのテスト戦略 2025 / 10 / 23 Ubie株式会社 Shinobu Hayashi/Shinyaigeek Nihonbashi.js
#10
2 whoami • Shinobu Hayashi/Shinyaigeek ◦ X: https://x.com/Shinyaigeek ◦ GitHub:
https://github.com/Shinyaigeek • Software Engineer@Ubie(25/08~) ◦ プロダクトの技術基盤の開発運用やら • Interest: HTTP, Frontend Toolchain, Platform Engineering
3 Agenda • Ubie におけるモジュラーモノリス ◦ なぜモジュラーモノリスか ◦ プロダクト開発を支える設計 •
自動テスト実行における課題とその解消アプローチの紹介 ◦ なぜ自動テストがボトルネックになっていたか ◦ 自動テスト実行数を削ってしまうアプローチ
4 ubie.app の システムアーキテクチャ
5 ubie.app のフロントエンド • Full “JavaScript” & “React” Stack ◦
Web アプリケーション: Next.js ◦ モバイルアプリケーション: React Native • 複数の機能を内包しており , ストリームアラインドチーム的に独立して開発されてい る ◦ 問診サービス ◦ 医療情報サービス ◦ オンライン診療サービス ◦ etc…
6 ubie.app のバックエンド • Nest.js 製バックエンドアプリケーション ◦ フロントエンドと同じく TypeScript で記述できるため機能開発をシームレスに行
える • プロダクトの諸機能に密なロジックとデータ永続化層を持っている ◦ ≠ JUST マイクロサービスの Gateway • 機能開発を行う際には , フロントエンドだけでなくバックエンドも併せて触ることにな る • モジュラーモノリスアーキテクチャの採用
7 モジュラーモノリスの恩恵 • それぞれの機能開発の独立性を担保しつつ分散システムの複雑さを回避できる ◦ 機能ごとにモジュールとして独立している eg) 問診(qa), オンライン診療(telemedicine) ◦
アプリケーション境界を担う controller 層と、モジュール境界を担う service 層それぞれを提供してい る • マイクロサービスとの通信などロジックを共有できる • 機能ごとのコラボレーションも容易に • 全員が同じリポジトリで開発を行うため、共有知を形成できる ◦ coding agent 向けのドキュメント ◦ シンプルに参考にできるコードが身近に • パッケージなどのバージョン管理を一元化でき運用がシンプルに
8 モジュラーモノリス運用で見 ててきた課題
9 モジュラーモノリスの課題 • エラー監視時のオーナーシップの線引きの難しさ • コードベースの巨大さ ◦ lint, fmt, tsc
の遅さ ◦ 自動テスト実行ケースの多さ ←ココ • モジュール間依存の複雑性による負債
10 モジュラーモノリスにおける自動テストの課題 • 数多くのロジックを抱えるためそれに比例してテストケースの数が膨大に ◦ テストファイル数だけで 314⋯! • 自動テストの出力もテストケースの数に比例して膨大に ◦
coding agent のコンテキストを逼迫する原因に • 自動テスト実行時間もテストケースに比例して伸びることに ◦ CI 上においては 2並列で走らせても 9min の実行時間がかかる規模 ◦ テスト用の DB を立て永続化層込みでテストをしているためデッドロック問題により並行実行にも難点 が⋯
11 自動テストの実行数を減らす戦略 • まずは手軽に行える、自動テストの実行数自体を減らしていく戦略をとっていくことに ◦ 併せて coding agent のコンテキスト問題も緩和できる ◦
並行実行可能な状態にするのもよいが Invest が大きいと予見されたため後回し • モジュラーモノリスであるが故に取りやすい戦略でもある ◦ 複数のビジネスロジック、機能がモジュールとして独立して存在している状況にある ◦ モジュール間の依存についてある程度クリーンな状況が実装上担保される ◦ テストにおいて、他モジュールへの依存に関してはインターフェースと Mock によってその実装にまで は踏み込まない状況が担保されている ◦ → あるモジュールを変更した際に、実行されるべきテストを絞り込むことを機械的に行いやすい且 つ効果的に絞り込める土壌と言える
12 自動テストの実行数を減らす戦術 • jest においては `--changedSince=${git commit-ish}`, vitest においては `vitest
related` によって, 「ある地 点」から今に至るまでの差分を元に実行されるべきテストを絞り込むためのオプションがすでに存在している ◦ git レベルで diff を読んで差分ファイルを検出 ◦ その差分を元に, 変更のあったファイルに依存している実装とそのテストを算出している • For 手元での実行時向け : ◦ `npm run test:diff` という形で, 差分実行だけを行うオプションを提供 • For CI での実行時向け: ◦ PR 上では差分のみを実行 , trunk (=main branch) においては全てのテストケースを実行 , という形に ◦ リリースパイプラインにおいては安全に倒す形に
13 差分ファイルと依存関係ベースでのテスト実行の注意点 • git の差分レベルを足掛かりに実行すべきテストを絞り込んでいるため、差分に検知されないものへの依 存は検知されない ◦ node_modules 配下のパッケージ ◦
gitignore されるような自動生成されるようなファイル • また設定ファイルの変化など、 ESM レベルでの依存関係は存在していないが挙動に変更を及ぼすような変 化にも注意が必要になる ◦ また tsconfig の paths alias を利用してるケースなども jest/vitest 側に設定ファイルで明示的にそれ を伝える必要がある • 本来実行されてほしいテストケースまで意図せず絞り込まれていないかは注意が必要
14 差分ファイルと依存関係ベースでのテスト実行の注意点 • node_modules 配下のパッケージ、設定系のファイルについては CI 上でアドホックに検知しテストケースを 全実行する • 自動生成されたコードに依存しているケースについては、アプリケーションごとに判断を行う
◦ 大抵のアプリケーション大抵の自動生成されたコードに依存するケースとしては、 DB や RPC(grpc, graphql, REST API)、CSS など JavaScript から見た際の副作用の取り扱いを行うケースがほとんど ◦ 外部環境との副作用を取り扱う以上、自動生成されたファイルによって挙動に破壊的な影響が出る際 には、"型" レベルに影響が出るはずで型検査ででも影響を検知できるはず
15 得られたもの • CI/ローカル環境 でのテスト実行時間の減少 🎉 ◦ 改善の性質上 PR の種類に依存するが
... ◦ 開発の中で変更の流量が多くなりがちな、具体機能にまつわる (=依存関係の末尾にいる )モジュール の変更に対して特に実行時間の改善が顕著に現れる ◦ 多くのモジュールで利用されるようなモジュールの変更時でも実行数はおよそ ⅔ にまで • coding agent がテストを実行した際のコンテキスト逼迫問題も改善