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
VueTestUtilbrのキホンの『キ』
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
ツノ
September 20, 2022
Technology
0
160
VueTestUtilbrのキホンの『キ』
ツノ
September 20, 2022
Tweet
Share
More Decks by ツノ
See All by ツノ
エンジニア達の_完全に理解した_-コードでの契約ってなんだ_.pdf
2nofa11
1
170
Vite完全に理解した その1
2nofa11
2
260
年末年始に「chibivue」で Vueヂカラをつけた
2nofa11
0
280
「世界一流のエンジニアの思考法」 を完全に理解した
2nofa11
1
290
書籍「プログラマー脳」を完全に理解した
2nofa11
0
76
VuexからPinia移行に向けて
2nofa11
0
440
一か月半かけて、TypeScript本を写経した話
2nofa11
0
830
Other Decks in Technology
See All in Technology
マルチロールEMが実践する「組織のレジリエンス」を高めるための組織構造と人材配置戦略
coconala_engineer
2
420
Oracle Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
4
1.6k
製造業ドメインにおける LLMプロダクト構築: 複雑な文脈へのアプローチ
caddi_eng
1
450
クラウド時代における一時権限取得
krrrr38
1
160
JAWS DAYS 2026 CDP道場 事前説明会 / JAWS DAYS 2026 CDP Dojo briefing document
naospon
0
140
Exadata Database Service on Dedicated Infrastructure(ExaDB-D) UI スクリーン・キャプチャ集
oracle4engineer
PRO
7
7.1k
新職業『オーケストレーター』誕生 — エージェント10体を同時に回すAgentOps
gunta
4
1.4k
GitLab Duo Agent Platform + Local LLMサービングで幸せになりたい
jyoshise
0
110
Agentic Software Modernization - Back to the Roots (Zürich Agentic Coding and Architectures, März 2026)
feststelltaste
1
170
研究開発部メンバーの働き⽅ / Sansan R&D Profile
sansan33
PRO
4
22k
白金鉱業Meetup_Vol.22_Orbital Senseを支える衛星画像のマルチモーダルエンベディングと地理空間のあいまい検索技術
brainpadpr
2
210
Bill One 開発エンジニア 紹介資料
sansan33
PRO
5
18k
Featured
See All Featured
Abbi's Birthday
coloredviolet
2
5.1k
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
280
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.6k
Mind Mapping
helmedeiros
PRO
1
110
Winning Ecommerce Organic Search in an AI Era - #searchnstuff2025
aleyda
1
1.9k
Designing Experiences People Love
moore
143
24k
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
430
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Build The Right Thing And Hit Your Dates
maggiecrowley
39
3.1k
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
280
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.7k
エンジニアに許された特別な時間の終わり
watany
106
240k
Transcript
Vue Test Utils のキホンの『キ』 ツノ:@2nofall
自己紹介:経歴 2016~2020 官公庁系の SIer:WF 型の SI 業務 2021~2022/9 SaaS の会社で営業部門の社内
SE GAS や RPA を使った業務の自動化 2022/10~ 部署異動し、フロントエンジニアに! Vue+TypeScript を使った自社プロダクト
自己紹介:趣味 銭湯・サウナ クライミング ゆっぽくん
LT 参加の背景 10 月に開発部署への異動 異動先はフロントエンドエンジニア ※前職は BE 周りで技術力に不安あり 異動先で使うスキルの以下習得が必須 Vue
TypeScript FE フレームワークのテスト知見 今回
LT の目的 アウトプットによる知識定着 1. 「ユニットテスト」について 2. Jest の使い方 3. 「モック」について
4. Vue Test Utils の使い方 ※学習した内容について、 誤りがあったらご指摘ください!
ユニットテストについて 言葉の定義 独立したソフトウェアの最小単位テスト 単体テスト・コンポーネントテストとも 広い意味で同義 重要性 コーディングによるバグを早期に検知修正 動く仕様書として活用
Jest について ユニットテストをするためのツール JavaScript テスティングフレームワークの 一つ フロントエンド FW (React Vue)との相性
本 LT では環境構築については省略
Jest の使い方(基本) 右の関数をテストする場合 const double = (arg) => arg**2; 今回は
② ~ ④ 部分を中心にお話します!
「モック」について 個人的なユニットテストつまづきポイント モックアップの直訳は「実物大の模型」 イメージ図は以下の通り
Jest での Mock について Jest でのモック生成 ⇛ jest.fn 以下例の場合、「user.addHobby」をモックとしてモック作成
ここまでの Jest を理解すれば、 Vue Test Utils も基本は使える! ※ここから先は Vue 初学者レベルの知識を要します
Vue Test Utils について 公式サイトより 実装の詳細に依存せずに コンポーネントテスト用のツール vue testing library
は、 vue-test-util をベースしたライブラリ (今回は対象外) vue-test-utils は Vue.js 向けの公式単体テストライブラ リです。 “ “
VTU:コンポーネントのマウント VTU とテスト対象のコンポーネントをインポート コンポーネントを mount し wrapper を利用 ※shallowMount を使うと子コンポーネントがスタブ化
VTU:props マウント時の第二引数として指定 props の値を途中で変えたいときには setProps を使用
VTU:slot マウント時の第二引数として指定 slots{ 名前:コンポーネント }として slot 先を指定
VTU:emit wrapper に対して emitted を使用して、発火されたイベントを取得
VTU:Vuex と Vue Router global.plugins : 実際の Store・Router をインポートしたテスト global.mocks
:Store・Router をモック化してテスト実行 ⇛global.mocks のほうが、対象をコンポーネントに向けられる。 今回は、 global.mocks の説明
VTU:Vuex mock として store を定義し、マウント時の第2引数として指定
VTU:Vue Router コンポーネントで使用する route の params、 mock として router を定義しマウント時に第二引数として指定
気づき Jest~Vue Test Utils について、 ちょっとわかる様になった。 コンポーネントに関してのテスト、 よく考えられているなと感じた。 モックやスタブの概念が曖昧だと つまづきやすい。