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
Riverpod 移行を支えた LivMap のアーキテクチャ
Search
Chooyan
October 06, 2024
0
1.1k
Riverpod 移行を支えた LivMap のアーキテクチャ
Findy 主催「Flutter技術構成を紐解く クロスプラットフォーム開発の裏側」の LT 資料です。
https://findy.connpass.com/event/331062/
Chooyan
October 06, 2024
Tweet
Share
More Decks by Chooyan
See All by Chooyan
新規アプリ開発で Xamarin導入を見送った話
chooyan244
0
150
Azureもくもく会 #21 成果発表LT資料
chooyan244
0
290
CodeYourRubyでRubyを仕事にする全てのエンジニアに貢献する
chooyan244
1
290
CodeYourRubyでRubyを仕事にする全てのエンジニアに貢献する.pdf
chooyan244
0
260
Featured
See All Featured
Being A Developer After 40
akosma
91
590k
Bash Introduction
62gerente
615
210k
Statistics for Hackers
jakevdp
799
220k
Automating Front-end Workflow
addyosmani
1371
200k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
9
590
Typedesign – Prime Four
hannesfritz
42
2.8k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
114
20k
GraphQLとの向き合い方2022年版
quramy
49
14k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
132
19k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
15
1.7k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
29
2.7k
Making Projects Easy
brettharned
119
6.4k
Transcript
Riverpod 移行を支えた LivMap のアーキテクチャ ちゅーやん(中條 剛) @chooyan_i18n
https://livmap.co/
View input / output BusinessLogic データの流れ Repository データベース操作 LivMap のアーキテクチャ(ざっくり)
依存の方向
課題から考える 副業参加のメンバーが多い テストの体制が薄い 同機能の別アプリを作りたい バックエンドの役割が薄い Firebase が使えない別アプリがあり得る リアルな移動を伴うメイン機能がある いずれは Riverpod
に移行する ルールは最小限にする 自動テストの書きやすさを考える View を分離する BusinessLogic をひとつの層として設ける Repository を差し替え可能にする GPS を差し替え可能にする 状態管理パッケージは View のみが依存する から から から から から から から
View Business Logic Repository LivMap のアーキテクチャ (もう少し広い目で) Provider
View Business Logic Repository Riverpod 移行 Provider
View Business Logic Repository Riverpod 移行
Riverpod 移行 • View のみの修正 • 機能ごとの違いはほぼ影響無し • 「アプリ全体書き直し」感はなかった! •
依存関係を整理すると修正範囲を限定できる、を体験できた
課題 • 日々の開発に活かせていない ◦ ❌ とりあえず守ってもらう ◦ 🙆 開発効率アップに活用する •
守れていない部分も多々ある • 「テストが書きやすい」≠「テストが書けている」
“最適なアーキテクチャは変化するもの” ご清聴ありがとうございました
あわせて読みたい https://zenn.dev/chooyan/articles/eefc76dbd2ba25