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.4k
バイナリ読むのにElixirしてみた
eiel
0
110
アジャイルはさておきMake People Awesomeしたい
eiel
0
220
レビューは最優先にするようにしている
eiel
0
350
再考 Fourkeys メトリクス
eiel
2
720
devenvに入門した
eiel
1
170
関数プログラミングの考え方
eiel
1
380
逆コンウェイ作戦はフィードバックループを作るために 逆向きの流れをつくること (5分版)
eiel
0
500
組織のパフォーマンスを高めるために 第1話 学習と文化
eiel
0
280
Other Decks in Technology
See All in Technology
Oracle Cloud Infrastructure:2026年6月度サービス・アップデート
oracle4engineer
PRO
0
150
【Cyber-sec+】経営層を"動かす"ための考え方
hssh2_bin
0
200
Lightning近況報告
kozy4324
0
210
データサイエンスを価値につなげるプロジェクト設計 〜 DS一年目が現場で得た気づき 〜
ysd113
1
290
FPGAの開発コンペでZephyrを使ってみた
iotengineer22
0
150
AIのReact習熟度を測る
uhyo
2
660
iAEONの段階的リアーキテクト戦略 / iAEON's_Gradual_Re-architecture_Strategy
aeonpeople
0
230
マルチアカウント環境での コーディングエージェントを使った障害調査が大変なので AIエージェントにReadOnly権限を付与してみた / ReadOnly AI Agents for Multi-Account AWS Incident Response
yamaguchitk333
2
110
SONiCの統計情報を取得したい
sonic
0
240
AWS Security Agent といっしょに脅威モデリングをやってみよう
amarelo_n24
1
180
人材育成分科会.pdf
_awache
4
300
コミュニティの有益性 ~JAWS Days 2026 での体験を通して~ / The Benefits of a Community ~Through My Experience at JAWS Days 2026~
seike460
PRO
0
190
Featured
See All Featured
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.5k
Un-Boring Meetings
codingconduct
0
320
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
310
The Anti-SEO Checklist Checklist. Pubcon Cyber Week
ryanjones
0
170
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
12
1.7k
Principles of Awesome APIs and How to Build Them.
keavy
128
18k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
360
30k
Documentation Writing (for coders)
carmenintech
77
5.4k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
950
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
250
Designing for Performance
lara
611
70k
svc-hook: hooking system calls on ARM64 by binary rewriting
retrage
2
300
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に対して呼び出しに変化ないか簡単にテストできるテク