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
LayerXにおけるセキュリティ管理の現在地と次の一手
tosho
0
250
アジャイルな経理と Claude Code と経営の未来
kawaguti
PRO
3
170
Oracle AI Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
4
3k
IaC コードを資産へ:AWS CDK 社内ライブラリと横断展開 / aws-summit-japan-2026
gotok365
9
1.3k
徹底討論!ECS vs EKS!
daitak
3
950
エラーバジェットのアラートのタイミングを考える.pdf
kairim0
0
180
AI駆動開発を通して感じた、 AI時代のデザイナーの役割変化
whisaiyo
4
2.3k
自分が詳しくない領域でAIを使う #プロヒス2026
konifar
17
5.9k
AIのReact習熟度を測る
uhyo
2
660
AIネイティブな開発のサプライチェーンリスク対策 〜激動の開発現場でリスクに立ち向かう〜【ZennFes】
cscengineer
PRO
2
140
2026年6月23日 Syncable Tech + Start Python Club にて
hamukazu
0
140
PostgreSQL 19 新機能概要 OSC Hokkaido 2026
nori_shinoda
0
180
Featured
See All Featured
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
610
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
28
3.5k
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
250
Between Models and Reality
mayunak
4
340
Building a Modern Day E-commerce SEO Strategy
aleyda
45
9.1k
Code Reviewing Like a Champion
maltzj
528
40k
Why Mistakes Are the Best Teachers: Turning Failure into a Pathway for Growth
auna
0
160
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
49
10k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
38
2.9k
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
340
The State of eCommerce SEO: How to Win in Today's Products SERPs - #SEOweek
aleyda
2
11k
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に対して呼び出しに変化ないか簡単にテストできるテク