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
Test mockをSnapshot testする
Search
Tomohiko Himura
September 14, 2023
Technology
170
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Test mockをSnapshot testする
Tomohiko Himura
September 14, 2023
More Decks by Tomohiko Himura
See All by Tomohiko Himura
Marpでmermaidは簡単だときいたけど
eiel
1
2.3k
バイナリ読むのにElixirしてみた
eiel
0
110
アジャイルはさておきMake People Awesomeしたい
eiel
0
220
レビューは最優先にするようにしている
eiel
0
350
再考 Fourkeys メトリクス
eiel
2
710
devenvに入門した
eiel
1
170
関数プログラミングの考え方
eiel
1
370
逆コンウェイ作戦はフィードバックループを作るために 逆向きの流れをつくること (5分版)
eiel
0
490
組織のパフォーマンスを高めるために 第1話 学習と文化
eiel
0
280
Other Decks in Technology
See All in Technology
MCP Appsを作ってみよう
iwamot
PRO
4
480
2026TECHFRESH畢業分享會 - Lightning Talk - 資料也要 CI/CD? 用 Airbyte 自動化資料同步
line_developers_tw
PRO
0
690
AIソロプレナー時代に2ヶ月で20人増員した事業創造会社の開発組織の話
miyatakoji
0
570
2026TECHFRESH畢業分享會 - 原生還是跨平台? App 開發踩坑實錄
line_developers_tw
PRO
0
710
社内 AI エージェント Synapse と セマンティックレイヤーの育て方
hiroakis
2
1.6k
Snowflakeと仲良くなる第一歩
coco_se
4
410
Building applications in the Gemini API family.
line_developers_tw
PRO
0
2.8k
なぜ Platform Engineering の土台に Kubernetes を選ぶのか
r4ynode
1
560
自律型AIエージェントは何を破壊するのか
kojira
0
150
EventBridge Connection
_kensh
5
690
10倍の生産性を実現するAI駆動並列エージェントのすべて
kumaiu
4
1.3k
小さく始める AI 活用推進 ― 日経電子版 Web チームの事例/nikkei-tech-talk47
nikkei_engineer_recruiting
0
200
Featured
See All Featured
The Curious Case for Waylosing
cassininazir
1
380
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
2k
How to Talk to Developers About Accessibility
jct
2
230
For a Future-Friendly Web
brad_frost
183
10k
The untapped power of vector embeddings
frankvandijk
2
1.8k
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
270
A Soul's Torment
seathinner
6
2.9k
How to build a perfect <img>
jonoalderson
1
5.6k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
How to Build an AI Search Optimization Roadmap - Criteria and Steps to Take #SEOIRL
aleyda
1
2.1k
Code Review Best Practice
trishagee
74
20k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
220
Transcript
Test mockを Snapshot testする 2023-09-14 ひむら ともひこ
自己紹介 ひむら ともひこ 最近遊びたいこと(希望) • 要求管理の仕組みをつくって遊びたい • さらっとリリースバーンアップが書けるツールつくって遊びたい
最近の自分のちょっとした 課題を解決したいだけの人生だった
概要 Test MockをSnapshot testする • なぜ Test MockをSnapshot testするか •
Test Mockとは • Snapshot testとは • Test MockをSnapshot testしてみる
なぜTest mockをSnapshot testするか
ちょっと楽しいから
別にやらなくていい
もしかしたら 考え方の幅が広がるかも ぐらいの小ネタです
Test mockとはなにか
みんな大好き(?) Mockオブジェクト
Test mockとは何か 単体テストをする際などに、 テスト対象から外部への呼び出しを正しく行ってい るか検証するためのオブジェクト 呼び出されたメソッドやその引数を記録している。 (呼び出し記録自体はTest spyでも行うが検証する場 合はMockと呼ばれる)
具体例
Test mock - Jestを使った例 • JestはJavaScriptで使われるテスティングフレームワーク • Test mockになっている関数を作る機能がある(mock関数) •
mock関数の呼び出しはmockプロパティに記録される const say = jest.fn() // mock関数 sayを作成している。 sayは呼び出せる say(‘hello’) // 引数 Helloで呼び出す say(‘bye’) // 引数 byeで呼び出す console.log(say.mock) /* ~> { calls: [ [ 'Hello' ], [ 'bye' ] ], // 引数 Helloとbyeで呼び出しがあった contexts: [ undefined, undefined ], // 実行環境の情報 instances: [ undefined, undefined ], invocationCallOrder: [ 1, 2 ], results: [ // 各呼び出しの戻り値の情報 { type: 'return', value: undefined }, { type: 'return', value: undefined } ], lastCall: [ 'bye' ] } */
say関数を検証する例 expect(say.mock.calls.length).toBe(2) // 2回呼び出されたことを検証する expect(say.mock.calls[0].toEqual([‘Hello’]) // 1回目の呼び出しの引数を検証する
Snapshot testとはなにか
みんな大好き(?) 期待値の自動生成ができる
Snapshot testとはなにか • 初回はテスト対象の出力を保存する • 2回目以降は保存した出力と比較する • 意図しない変更を検知するのに役立つテクニック
具体例
Snapshot test - Jestを使った例 test(“Snapshot Testの例”, () => { const
output = { calls: [‘hello’] } // 関数の出力とする expect(output).toMatchSnapshot() // まだ出力を保存していない場合は保存する }); /* __snapshot__ ディレクトリにファイル名に .snap をつけたファイルに以下が保存される // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`Snapshot Testの例 1`] = ` { "calls": [ "hello", ], } `; */
Snapshot Testの例 test(“Snapshot Testの例”, () => { const output =
{ calls: [‘bye’] } // 関数の出力とする値をわざと変更する expect(output).toMatchSnapshot() // 出力が保存済みなので、保存された結果と比較 }); /* – 実行時の出力 Error: expect(received).toMatchSnapshot() Snapshot name: `Snapshot Testの例 1` { "calls": [ - "hello", + "bye", ], }
Test mockをSnapshot testしてみる
説明する必要があるだろうか…
Test mockをSnapshot testする function greeting(say) { say(‘hello’); say(‘bye’); } test(‘greeting’,
() => { const say = jest.fn(); greeting(say); expect(say.mock).toMatchSnapshot(); });
Test mockをSnapshot testする - 処理を変更 function greeting(say) { say(‘こにゃにゃちわー’); say(‘ほなら’);
} test(‘greeting’, () => { const say = jest.fn(); greeting(say); expect(say.mock).toMatchSnapshot(); });
Test mockをsnapshot testする - 実行してみる Snapshot name: `greeting 1` -
Snapshot - 3 + Received + 3 @@ -1,12 +1,12 @@ { "calls": [ [ - "hello", + "こにゃにゃちわー ", ], [ - "bye", + "ほなら", ], ], "contexts": [ undefined, undefined, @@ -18,11 +18,11 @@ "invocationCallOrder": [ 1, 2, ], "lastCall": [ - "bye", + "ほなら", ], "results": [ { "type": "return", "value": undefined,
Test mockをSnapshot testするの用途 • 自動テスト書かれていないコードのさくっと自動テストをつくる ◦ リファクタリングに役に立つ • mockを使いたいが丁寧に検証するのが面倒なとき ◦
手抜きだけど、ないよりはましな場合がある • 丁寧に検証する前の確認として ◦ mockプロパティみたほうがはやくないか?
Jest以外でどうやるか • 調べてない • 調べかけてたけど、やりやすい環境がそもそも他に… • そのため、このネタはお蔵入りした
まとめ
まとめ Test mockをSnapshot testする • Test mock ◦ 期待どおりメソッドや関数が呼び出されるか確認するためのテク •
Snapshot test ◦ 実行結果を保存し、テストの期待値とするテク • Test mockをSnapshot testする ◦ mockに対して呼び出しに変化ないか簡単にテストできるテク