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
DevTools と デバッグ と 私
Search
Koji NAKAMURA
May 30, 2024
Programming
2
3.4k
DevTools と デバッグ と 私
2024/05/31 Shinjuku.rb #92 好きなもの紹介LT大会
Koji NAKAMURA
May 30, 2024
Tweet
Share
More Decks by Koji NAKAMURA
See All by Koji NAKAMURA
龍昌餃子で理解するWebサーバーの並行処理モデル - 東葛.dev #9
kozy4324
1
270
Rubyで作る論理回路シミュレータの設計の話 - Kashiwa.rb #12
kozy4324
1
550
Rubyで作る論理回路シミュレータ - Shinjuku.rb #99
kozy4324
0
110
Steep導入したいRTA - Kashiwa.rb #11
kozy4324
0
180
これまで細々と作成したGemの紹介をします - Kashiwa.rb #9
kozy4324
0
260
東京Ruby会議12のお手伝いしてきた話
kozy4324
0
120
個人開発発表 LT - Shinjuku.rb #97
kozy4324
0
460
Ruby界隈を中心に2024をふりかえる - Kashiwa.rb #6
kozy4324
0
200
「今までで一番学びになった瞬間」発表 LT - Shinjuku.rb #96
kozy4324
0
400
Other Decks in Programming
See All in Programming
Swift ConcurrencyでよりSwiftyに
yuukiw00w
0
250
AI時代のソフトウェア開発でも「人が仕様を書く」から始めよう-医療IT現場での実践とこれから
koukimiura
0
140
RubyとGoでゼロから作る証券システム: 高信頼性が求められるシステムのコードの外側にある設計と運用のリアル
free_world21
0
240
The Past, Present, and Future of Enterprise Java
ivargrimstad
0
350
猫の手も借りたい!ので AIエージェント猫を作って社内に放した話 Claude Code × Container Lambda の Slack Bot "DevNeko"
naramomi7
0
260
Vuetify 3 → 4 何が変わった?差分と移行ポイント10分まとめ
koukimiura
0
100
encoding/json/v2のUnmarshalはこう変わった:内部実装で見る設計改善
kurakura0916
0
370
Claude Code、ちょっとした工夫で開発体験が変わる
tigertora7571
0
200
手戻りゼロ? Spec Driven Developmentとは@KAG AI week
tmhirai
1
180
受け入れテスト駆動開発(ATDD)×AI駆動開発 AI時代のATDDの取り組み方を考える
kztakasaki
2
550
今更考える「単一責任原則」 / Thinking about the Single Responsibility Principle
tooppoo
3
1.6k
S3ストレージクラスの「見える」「ある」「使える」は全部違う ─ 体験から見た、仕様の深淵を覗く
ya_ma23
0
180
Featured
See All Featured
DevOps and Value Stream Thinking: Enabling flow, efficiency and business value
helenjbeal
1
140
The Curse of the Amulet
leimatthew05
1
9.7k
Reality Check: Gamification 10 Years Later
codingconduct
0
2k
Making the Leap to Tech Lead
cromwellryan
135
9.8k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
1
190
How STYLIGHT went responsive
nonsquared
100
6k
B2B Lead Gen: Tactics, Traps & Triumph
marketingsoph
0
71
Information Architects: The Missing Link in Design Systems
soysaucechin
0
820
What's in a price? How to price your products and services
michaelherold
247
13k
GraphQLとの向き合い方2022年版
quramy
50
14k
エンジニアに許された特別な時間の終わり
watany
106
240k
Building a Modern Day E-commerce SEO Strategy
aleyda
45
8.8k
Transcript
DevTools と デバッグ と 私 2024/05/31 Shinjuku.rb #92 好きなもの紹介LT大会 Koji
NAKAMURA (@kozy4324)
自己紹介 - Koji NAKAMURA (@kozy4324) - Classi株式会社 - (フロントエンド開発歴の方が長いかもしれない)Railsエンジニア
好き - DevTools を使ってデバッグすること (ソフトウェアの仕組みや機序を動かしながら理解することが割と好き)
DevTools の推し機能3選 1. Copy as cURL 2. Block request URL
3. JavaScript デバッグツール
1. Copy as cURL API リクエストを繰り返しテストしたい時によく使う
2. Block request URL 特定のAPIリクエストがエラー時のフロントエンド挙動を確認したい時に使う
3. JavaScript デバッグツール
3. JavaScript デバッグツール ①ブレイクポイントで一時停止して、 ②スコープ変数が確認でき、 ③そのコンテキストでスクリプト実行して確認ができる
3. JavaScript デバッグツールの推しポイント Call Stackを移動して 確認することもできる
DevTools に最適化された人間が思うこと... - Ruby バックエンドも DevTools でデバッグがしたい
debug.gem で実現できる - debug.gem - https://github.com/ruby/debug - > You can
attach with external debugger frontend with VSCode and Chrome. - Rails 7 includes the debug gem - https://guides.rubyonrails.org/debugging_rails_applications.html#debugging-with-the-debug-ge m
debug.gem を使う
debug.gem を使う ②ブレイクポイントで一時停止されて、 ③コードを実行したり、色々確認できる ①ブレイクポイント設定する、binding.break, binding.b でも可
debug.gem から DevTools を起動する (rdbg) open chrome
debug.gem から DevTools を起動する (rdbg) open chrome Mac であれば Chrome
が起動する 起動しない場合は表示される devtools:// の URL を Chrome で開く
debug.gem w/ DevTools
debug.gem w/ DevTools JavaScriptの時と全く同じ操作感 Frame移動が超簡単、楽 FrameごとのRuby式の評価も出来る
遭遇した悩ましい挙動 🤔 - インスタンス変数を評価すると nil になる - ブロック付きメソッド呼び出しを評価しても nil になる
debug.gem をデバッグする - $ bundle open debug - lib/debug/server_cdp.rb#L962 あたりにprint文を仕込む
- https://github.com/ruby/debug/blob/v1.9.2/lib/debug/server_cdp.rb#L962 DEBUGGER: [:evaluate, {"id"=>21, "method"=>"Debugger.evaluateOnCallFrame", "params"=>{"callFrameId"=>"e8547272d5f75dfe567b420e26b2a42e", "expression"=>"", "objectGroup"=>"console", "includeCommandLineAPI"=>true, "silent"=>false, "returnByValue"=>false, "generatePreview"=>true}}, 0, "", "console"]
debug.gem をデバッグして分かったこと - 評価すべき文字列が空になっている - どうやら DevTools が投げてくる時点で空文字列 - コメントにも書いてあった
- https://github.com/ruby/debug/blob/v1.9.2/lib/debug/server_cdp.rb#L1044 - > Chrome doesn't read instance variables
こうなったら DevTools もデバッグだ! - https://github.com/ChromeDevTools/devtools-frontend - depot_toolsのインストール - $ git
clone https://chromium.googlesource.com/chromium/tools/depot_tools.git - $ export PATH="$PATH:$(pwd)/depot_tools" - ソースコードの取得 - $ mkdir devtools - $ cd devtools - $ fetch –nohistory devtools-frontend - ビルド - $ cd devtools-frontend - $ gclient sync - $ gn gen out/Default - $ autoninja -C out/Default
Google Chrome for Testing の実行 - $ ./third_party/chrome/chrome-mac/Google\ Chrome\ for\
Testing.app/Contents/MacOS/Google\ Chrome\ for\ Testing --disable-infobars --disable-features=MediaRouter --custom-devtools-frontend=file://$(realpath out/Default/gen/front_end) --use-mock-keychain - 起動したブラウザのアドレスバーに、debug.gem が出力する devtools:// のURLを 入力する - 表示した画面上で DevTools を起動する - option + command + I
None
RubyをデバッグしているDevTools 左側のDevToolsをデバッグしているDevTools
DevTools in DevTools の完成 - DevTools マニア歓喜 😂 🎉
DevTools をデバッグして分かったこと - DevTools 内でエラーが発生していた - > Uncaught SyntaxError: Unexpected
character '@' (1:0) - https://github.com/ChromeDevTools/devtools-frontend/blob/be0ed2fb4df509f39b73b84fe20a 94f7af948a24/front_end/panels/console/ConsolePrompt.ts#L378 - 入力文字列は JavaScript として parse されていた - https://github.com/ChromeDevTools/devtools-frontend/blob/be0ed2fb4df509f39b73b84fe20a 94f7af948a24/front_end/entrypoints/formatter_worker/Substitute.ts#L30-L33 - `@` やブロック付きメソッド呼び出しは JavaScript として Syntax Error だったというオチ - SourceMap を使って Transpile された変数名を解決するための置換処理が入っている模様 - ここでエラーになると空文字列にフォールバックされていた - DevTools のコンソールは JavaScript しか評価できない、という解釈を得た
ワークアラウンド - eval を使う - eval(‘@articles’) - eval('@articles.map(&:title).join(?,)')
終わり - DevTools を使って Ruby をデバッグする話をしようと思っていたら、DevTools を 使って DevTools をデバッグする話になっていたという回
- Ruby のデバッグや DevTools に関するノウハウ・ Tips を知るのが好き - オススメ情報があればぜひ教えてください!