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
agemonoにあたった話
Search
MOK
March 25, 2021
Programming
0
420
agemonoにあたった話
初心者がはじめて出会った業務用アプリを消化しようと試みたときの話。
MOK
March 25, 2021
Tweet
Share
Other Decks in Programming
See All in Programming
Rethinking UI building strategies @ SFI 2024
letelete
0
270
Scalable Customer Journey Orchestration (CJO)
lewuathe
0
170
⼤規模⾔語モデルの拡張(RAG)が 終わったかも知れない件について
nearme_tech
23
15k
Prepare for Jakarta EE 11 - Performance and Developer Productivity
ivargrimstad
0
750
Ruby GitHub Packages
bkuhlmann
0
630
MicrosoftのPlatform Engineeringガイドを読んで実際になにかやってみた
ymd65536
1
310
Hanami and htmx
bkuhlmann
0
210
HUIT新歓2024「競技プログラミング、やってみませんか?」
slephy2784
1
270
DMMプラットフォームがTiDB Cloudを採用した背景
pospome
8
4k
VS Code をプロダクトにどう取り込むか
onomax
1
360
PHPはいつから死んでいるかの調査
chiroruxx
1
400
StoreKit2によるiOSのアプリ内課金のリニューアル
kangnux
0
110
Featured
See All Featured
Designing for humans not robots
tammielis
248
25k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
7
1k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
352
28k
Unsuck your backbone
ammeep
663
57k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
19
1.7k
Web development in the modern age
philhawksworth
202
10k
ParisWeb 2013: Learning to Love: Crash Course in Emotional UX Design
dotmariusz
104
6.6k
Design by the Numbers
sachag
274
18k
Stop Working from a Prison Cell
hatefulcrawdad
266
19k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
241
1.2M
Dealing with People You Can't Stand - Big Design 2015
cassininazir
357
22k
Rails Girls Zürich Keynote
gr2m
91
13k
Transcript
agemonoにあたった話 株式会社トリクトラック M. OKawara
自己紹介 ▪ 3年ほど前、東京から福岡に移住し、愛知の会社にフルリモートで就職 - 業務システムを主に開発している会社 - 現在はブロックチェーンを利用した企業システムと学校業務で使用するシステム が主な事業 ▪ 入社時のIT知識、最低限(なんならシステム開発会社と知らなかった)
- お客さんとの調整業務を中心に担当 - ローカルでRailsアプリを立ち上げて動作確認はできるようになりました
Fukuoka.rb・Ruby Kaigi・Rails Girls Fukuoka.rbの100回目LT大会に参加 → ぼちぼち勉強してたらRuby会議が福岡でやるらしいのでお手伝い → Rails Gilrsが福岡でやるから参加 → Fukuoka.rbが200回記念LT大会ということで参加を決めました
大まかな構成 「CapybaraにGherkinを食 わせて、Cucumberじゃなく てTurnipなんだけど…」 え?? 「agemonoでまず動作確認 をしてから各学校に組み込 んで…」 え??? <<
Rails Engine >> UserB画面【natane】 Version1の場合のみマウント << Gem >> 【miso/tare】 Version切替 DB << Rails Engine >>【agemono】 コントローラ JSON API UserA認証・管理者認証 管理機能 << React >> UserA画面Ver1 << React >> UserA画面ver2 Web API << npm plugin >> 画面コンポーネント 【nimono】 React on Rails React on Rails これがさらに他の複数システムと Web APIで連携
なるほど わからない
「agemonoはGemでkoromoをつけて仕上げる」 - 『GemってRubyのGemのこと?』 - なんとなくわかるが、説明を聞いてもしっくりこない、わからない - (でも毎日の業務でなんとなく立ち上げてPRの動作確認してお客さんに説明して いる分には問題ない、とはいえ気になる) → 公式ページのRails Engineのページを読め
- なるほど書いてありました
agemonoの正体(実際の構成) 社内で作ったRails Engine たまにコアとかGemとか呼ばれる - よく見ると最初に渡された図にちゃんと 「Rails Engine」と書いてあった - agemono単体で立ち上げて動作確認をし
て、各学校に組み込んで動作確認をして … を繰り返すうちに、Railsガイドに書いてある ページの意味がわかるようになってきた - でもいつまでもわからない部分がある
『RailsエンジンってGemだから』 - Gemってつまり何? - RubyとかRailsの機能をとりだしてパーツにしたもの - Railsエンジンってつまり何? - 『RailsエンジンってGemだから』 つまり『Railsエンジン==Gem』? → まったくわからない
Railsエンジンって何? - 勉強するにつれどんどんわからなくなるGemとRailsエンジンの違い - それどころかRailsアプリとRailsエンジンの差すらわからない - 公式ページを読んでなるほどと思っても余計にわからない では何がわからなかったか?
つまりRailsエンジンとはこういうこと? Gem Rails エンジン - GemとRailsエンジン、全然イコールじゃなかっ た - 『Gem=小さなRailsアプリ』だという思い込みが 先に発生してしまい、何がRailsエンジンの特殊
性か全然わからなかった - Gemは確かに、機能を取り出してパーツにした ものだったが、モデル・コントローラー・ビューを 普通は提供しなかった
我々のRailsエンジンの使い方 - Agemono(=Railsエンジン)側で機能を追加して、それを各学校のアプリに組 み込めば、学校側のアプリで個別に機能を追加しなくても大丈夫 - 実際の開発工程でも、agemonoを開発してそこで動作確認をしてから、各学校 のアプリに組み込んでもう一度動作確認する工程を踏んでいる - 自分が担当してるのは学校側の要望を聞き取り、エンジニアに伝えつつ、ちょっ とした文言レベルやヘルプの文言などは自分で修正(たまにagemono側での文
言修正もある)
初対面のRailsアプリを『普通』と思い 込み過ぎ何もわからなかった
何がわからないのか - agemonoだけでもデザインとかは簡素だけどとりあえず動いているわけ で、ユーザー画面のデザインはnimonoが担当しているのでは? - 『各学校のアプリはうすいRailsの層』『agemonoは邪悪』…etc 言われている全く意味がわかってなかったが、各学校のアプリには本当に 自分が修正しているちょっとした文言しか存在してなかった
ちなみにagemonoがそれだけで動いた理由 本ガイドでの説明用に作成するエンジンには「 blorgh」(blogのもじり) という名前を付けます。このエン ジンはホストアプリケーションにブログ機能を追加し、記事とコメントを作成できます。 本ガイドでは、最 初にこのエンジンを単体で動作するようにし、次にこのエンジンをアプリケーションにフックします 。 https://railsguides.jp/engines.html 当然のようにあるこの記述の通り、agemonoに最初からテスト
用のアプリが組み込まれているだけだった
書いてあっても理解できてなかった - まだまだ、Railsガイドに書いてある内容に新発見がある日々 - どの追加開発・修正なら個別に対応できるか、全体に影響するのか、最 終的にはエンジニアに確認するのは当然だが、自分にある程度知識が あると多少は難易度がわかるので精神的に楽になる (自分で修正できるか、エンジニアに渡す必要があるか等…) (ただし生兵法が一番怖い) (知らない方が実は気楽なのかもしれない)
補足 - miso/tareはagemonoに吸収、学 校の種類による機能の切替は Feature Togglesで実施 - nataneをGem化する利点は現状 なしという判断 -
今後Agemonoとは別々にnatane (UserB画面の機能)を開発する必 要があるかどうか
Railsアプリって 大変なんだなあ (サンプル数1) 「RubyのGemとは何か」勉強してたつもりでいても、あと「agemonoはコアになるエン ジンです」と言われていても、なんとなくわかってるだけだった 同じ文章を読んで、改めて新しい発見が沢山ある日々(お得) nimonoがなんでnimonoなのかはまだ全然わかってない
最後の要点 何が専門用語で、何が社内用語 かわかるようになりたい でも名前はもう少しわかりやすくても良かったかもしれない
十分に発達したテクノロジーは、 魔法と見分けがつかない - Arthur C. Clarke
本当に大事なことはだいたい 公 式ドキュメントに書いてある 同じ文章も理解の段階で読み取 れる内容も変わってくる
ご清聴ありがとうございました