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
VRTを自炊してコスト削減した話
Search
JunpeiKawamura
December 12, 2023
630
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
VRTを自炊してコスト削減した話
JunpeiKawamura
December 12, 2023
Featured
See All Featured
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
770
The Curious Case for Waylosing
cassininazir
1
380
YesSQL, Process and Tooling at Scale
rocio
174
15k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
Designing for Timeless Needs
cassininazir
1
250
Fireside Chat
paigeccino
42
3.9k
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
2
1.5k
It's Worth the Effort
3n
188
29k
Mozcon NYC 2025: Stop Losing SEO Traffic
samtorres
1
250
Unsuck your backbone
ammeep
672
58k
KATA
mclloyd
PRO
35
15k
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
200
Transcript
© 2023 Findy Inc. VRTを自炊してコスト削減した話 川村純平 (2023/12/12)
© 2023 Findy Inc. ◦ 川村純平(Junpei Kawamura) ◦ フロントエンド ◦
趣味: hip-hop ◦ 2021年に(株)JX通信社に入社し、新規事業『KAIZODE』の開発を担当 ◦ 2023年6月より(株)ファインディに入社し『Findy Team+』の開発を担当 ⾃⼰紹介
© 2023 Findy Inc. 今⽇話すこと
© 2023 Findy Inc. VRTを⾃炊することでやりたいことを 妥当なコストで全部できるようにした!
© 2023 Findy Inc. 1. VRTとはそもそも何か 2. 現状のChromaticを使ったUIレビューについて 3. VRTを構築した話
4. 運用してみて 5. まとめ ⽬次
© 2023 Findy Inc. VRTとは
© 2023 Findy Inc. VRTとは 参照: https://www.chromatic.com/features/visual-test
© 2023 Findy Inc. VRTとは 参照: https://www.chromatic.com/features/visual-test • Visual Regression
Testing(以降 VRT)とはフロントエンドの テストの⼀つ • UI のスナップショットをコード変更前後で取得し、ビジュア ルとしての⽐較差分を確認 • 意図せぬ UI の変更や新規 UI の追加など、UI の追加‧変更‧ 削除を Story をベースに検知することができる
© 2023 Findy Inc. 現状のChromaticを使ったUIレビューについて
© 2023 Findy Inc. Chromaticを使ったUIレビュー
© 2023 Findy Inc. Chromaticを使ったUIレビュー 1. リリースプルリクが作成される 2. ChromaticのUIレビューのリンクへ⾶び確認 3.
UI Reviewが不要な場合は⾃分で確認しApproveする a. 必要な場合はレビューワーをアサイン
© 2023 Findy Inc. Chromaticを使ったUIレビューの問題点 • ChromaticのRequiredを動作が安定するまでは解除するなどしてUIレ ビューが仕組み化されていない状態 • VRTをリリース、PR単位で気軽に動かすなどやりたいことをChromaticで
全部やろうとするとかなりのコストがかかることがわかった • 使い⽅次第ではとても優秀だが、コストに⾒合った運⽤ができていない
© 2023 Findy Inc. VRTを⾃炊してやりたいことを妥当な コストで全部できるようにする!💪
© 2023 Findy Inc. VRTを構築 https://reg-viz.github.io/reg-suit/
© 2023 Findy Inc. VRTを構築 といってもゼロから作るわけではなくツールがある reg-suit x Stroycap でVRTを構築できる
© 2023 Findy Inc. VRTを構築
© 2023 Findy Inc. VRTを構築 1. リリースプルリク作成時 GitHub Actions が起動
2. reg-suit の reg-keygen-git-hash-pluginプラグインにより、トピックブランチ (作業ブランチ)のソースである親のコミットを⾃動的に検出 3. トピックブランチにて Storycap により Storybook をクロールし、スクリーン ショット画像の取得を⾏います。(この時点では CI コンテナに⼀時的に保存 されます。) 4. reg-suit run コマンドにより差分の html レポートを AWS の S3 に保存し、作 成したプルリクにレポートコメントを残します。
© 2023 Findy Inc. VRTを構築 実質S3の料⾦だけ!
© 2023 Findy Inc. VRTを構築 差分の結果をコメントしてくれる
© 2023 Findy Inc. VRTを構築 レポートページにて確認できる
© 2023 Findy Inc. 運⽤してみてでた課題
© 2023 Findy Inc. 運⽤してみてでた課題 1. 全部のstoryをVRTにかける必要があるかどうか CIが4-5分程度で終わるので、全部のstoryをVRTに 全部のstoryに対して差分検知した⽅が予期せぬ事故を防げる 2.
flakyな差分に対してどうアプローチするか グラフ描画のコンポーネントでアニメーションが終わる前にスナッ プショットが撮影されていた Storycapのdelayを使いアニメーションが終わってからスナップ ショットを撮影するように対応
© 2023 Findy Inc. まとめ
© 2023 Findy Inc. 1. コストの削減と⾒直し 現状のツール⾒直しにより、より効率的で経済的に運⽤できるようになった。 2. VRTの効果 UIの変更やバグを早期に検知し、修正の負荷が下がる。予期せぬ画⾯崩れに気づける。
3. 課題への対応策 全storyをVRTにかける必要性や、flakyな差分に対するアプローチについて検討。 flakyなテストを容認してしまうと、本来気づく必要のあるUI差分を⾒逃す可能性がある。 4. 今後の展望 他部署‧フロントエンドチームへの導⼊促進や布教活動の展開、ノウハウの共有 VRTの更なる最適化 まとめ