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
540
agemonoにあたった話
初心者がはじめて出会った業務用アプリを消化しようと試みたときの話。
MOK
March 25, 2021
Tweet
Share
Other Decks in Programming
See All in Programming
Jetpack XR SDKから紐解くAndroid XR開発と技術選定のヒント / about-androidxr-and-jetpack-xr-sdk
drumath2237
1
220
マスタデータ問題、マイクロサービスでどう解くか
kts
0
160
Flutter On-device AI로 완성하는 오프라인 앱, 박제창 @DevFest INCHEON 2025
itsmedreamwalker
1
170
[AI Engineering Summit Tokyo 2025] LLMは計画業務のゲームチェンジャーか? 最適化業務における活⽤の可能性と限界
terryu16
1
110
HTTPプロトコル正しく理解していますか? 〜かわいい猫と共に学ぼう。ฅ^•ω•^ฅ ニャ〜
hekuchan
2
560
Rubyで鍛える仕組み化プロヂュース力
muryoimpl
0
230
AI Agent Dojo #4: watsonx Orchestrate ADK体験
oniak3ibm
PRO
0
120
モデル駆動設計をやってみようワークショップ開催報告(Modeling Forum2025) / model driven design workshop report
haru860
0
290
脳の「省エネモード」をデバッグする ~System 1(直感)と System 2(論理)の切り替え~
panda728
PRO
0
130
Java 25, Nuevas características
czelabueno
0
120
Cap'n Webについて
yusukebe
0
160
組み合わせ爆発にのまれない - 責務分割 x テスト
halhorn
1
170
Featured
See All Featured
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
94
The Language of Interfaces
destraynor
162
26k
A brief & incomplete history of UX Design for the World Wide Web: 1989–2019
jct
1
270
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.2k
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
180
Tell your own story through comics
letsgokoyo
0
770
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
9.8k
Faster Mobile Websites
deanohume
310
31k
Technical Leadership for Architectural Decision Making
baasie
0
190
Being A Developer After 40
akosma
91
590k
Facilitating Awesome Meetings
lara
57
6.7k
Scaling GitHub
holman
464
140k
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
本当に大事なことはだいたい 公 式ドキュメントに書いてある 同じ文章も理解の段階で読み取 れる内容も変わってくる
ご清聴ありがとうございました