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
意外と知らない状態遷移テストの世界
Search
nihonbuson
PRO
December 20, 2025
Technology
1
390
意外と知らない状態遷移テストの世界
WACATE 2025 冬
での投影資料です。
nihonbuson
PRO
December 20, 2025
Tweet
Share
More Decks by nihonbuson
See All by nihonbuson
クラシフィケーションツリー技法
nihonbuson
PRO
1
47
「品質のつくりこみ」と「リリース後に行うとよいテスト活動」を体験する
nihonbuson
PRO
1
240
ホリスティックテスティングの右側も大切にする 〜2つの[はか]る〜 / Holistic Testing: Right Side Matters
nihonbuson
PRO
0
1.7k
テストを実施する前に考えるべきテストの話 / Thinking About Testing Before You Test
nihonbuson
PRO
18
3.4k
テストコードにはテストの意図を込めよう(2025年版) #retechtalk / Put the intent of the test 2025
nihonbuson
PRO
17
3.5k
ソフトウェアテスト 最初の一歩 〜テスト設計技法をワークで体験しながら学ぶ〜 #JaSSTTokyo / SoftwareTestingFirstStep
nihonbuson
PRO
6
1k
リーダブルテストコード 〜メンテナンスしやすい テストコードを作成する方法を考える〜 #DevSumi #DevSumiB #JaSST #JaSSTTokyo / Readable test code
nihonbuson
PRO
14
23k
開発スピードは上がっている…品質はどうする? スピードと品質を両立させるためのプロダクト開発の進め方とは #DevSumi #DevSumiB / Agile And Quality
nihonbuson
PRO
2
10k
シフトライトなテスト活動を適切に行うことで、無理な開発をせず、過剰にテストせず、顧客をビックリさせないプロダクトを作り上げているお話 #RSGT2025 / Shift Right
nihonbuson
PRO
3
4.1k
Other Decks in Technology
See All in Technology
Next.js 16の新機能 Cache Components について
sutetotanuki
0
210
ECS_EKS以外の選択肢_ROSA入門_.pdf
masakiokuda
1
120
re:Invent2025 セッションレポ ~Spec-driven development with Kiro~
nrinetcom
PRO
2
160
BidiAgent と Nova 2 Sonic から考える音声 AI について
yama3133
2
140
2025-12-27 Claude CodeでPRレビュー対応を効率化する@機械学習社会実装勉強会第54回
nakamasato
4
1.4k
戰略轉變:從建構 AI 代理人到發展可擴展的技能生態系統
appleboy
0
170
All About Sansan – for New Global Engineers
sansan33
PRO
1
1.3k
ESXi のAIOps だ!2025冬
unnowataru
0
470
Data Hubグループ 紹介資料
sansan33
PRO
0
2.5k
田舎で20年スクラム(後編):一個人が企業で長期戦アジャイルに挑む意味
chinmo
1
270
First-Principles-of-Scrum
hiranabe
1
420
アラフォーおじさん、はじめてre:Inventに行く / A 40-Something Guy’s First re:Invent Adventure
kaminashi
0
210
Featured
See All Featured
Google's AI Overviews - The New Search
badams
0
880
Technical Leadership for Architectural Decision Making
baasie
0
200
Site-Speed That Sticks
csswizardry
13
1k
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
61
51k
Designing Powerful Visuals for Engaging Learning
tmiket
0
190
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
27
Leading Effective Engineering Teams in the AI Era
addyosmani
9
1.4k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.1k
Building a Scalable Design System with Sketch
lauravandoore
463
34k
[RailsConf 2023] Rails as a piece of cake
palkan
58
6.2k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
6.8k
We Have a Design System, Now What?
morganepeng
54
8k
Transcript
意外と知らない 状態遷移テストの世界 ブロッコリー (@nihonbuson)
自己紹介 • 風間裕也(ブロッコリー) • 株式会社10X 品質管理チーム • 副業…B-Testing(個人事業主)として ◦ 株式会社MonotaRO(テストコンサルタント)
他数社でお手伝い • 社外活動 ◦ WACATE実行委員長 ◦ JaSST Review実行委員長 ◦ Developers Summitコンテンツ委員 ◦ SReEE(ソフトウェアレビューを エンジニアリングっぽく捉える会)リーダー • 猫派 SNS上の アイコン
状態遷移テストとは何か
状態遷移テストとは何か ブラックボックステスト技法のひとつ。状態遷移モデルの 要素を実行するようにテストケースを設計する。 状態遷移テスト(state transition testing) - ISTQB Glossary
例題を用いて説明 ストップウォッチの 「スタート/ストップ」ボタンと 「リセット」ボタンについて どんなテストをしますか? ※計測部分は正確であり、 テスト対象外とする ※ラップ機能は搭載していないとする スタート /ストップ
リセット https://goo.gl/iAvVm8
状態遷移図の作成
状態遷移図とは何か 状態遷移図は、システムの取り得る状態と有効な遷移を 示すことで、システムの振る舞いをモデル化する。 遷移は、イベントによって開始され、さらにガード条件に よって限定されることがある。 遷移は瞬時に起きることを想定しており、遷移によってソ フトウェアがアクションを起こす場合がある。 ISTQBテスト技術者資格制度 Foundation Level
シラバス 日本語版 Version 2023V4.0.J02 4.2.4 状態遷移テスト
状態遷移図の作成 待機中
状態遷移図の作成 待機中 状態
状態遷移図の作成 待機中 開始擬似 状態
状態遷移図の作成 待機中 計測中 スタート/ ストップ 押下
状態遷移図の作成 待機中 計測中 スタート/ ストップ 押下 イベント
状態遷移図の作成 待機中 計測中 遷移 スタート/ ストップ 押下
状態遷移図の作成 待機中 計測中 一時停止中 スタート/ ストップ 押下 スタート/ ストップ 押下
状態遷移図の作成 待機中 計測中 一時停止中 スタート/ ストップ 押下 スタート/ ストップ 押下
スタート/ ストップ 押下
状態遷移図の作成 待機中 計測中 一時停止中 リセット 押下 スタート/ ストップ 押下 スタート/
ストップ 押下 スタート/ ストップ 押下
状態遷移図を積極的に作成すべきパターン① 待機中 計測中 スタート/ ストップ 押下 一時停止中 同じイベントでも前状態によって 遷移先の状態が異なる場合に作成すると良い スタート/
ストップ 押下 スタート/ ストップ 押下 リセット 押下
状態遷移図を積極的に作成すべきパターン② 待機中 計測中 一時停止中 同じ状態でもイベントによって 遷移先の状態が異なる場合に作成すると良い スタート/ ストップ 押下 スタート/
ストップ 押下 スタート/ ストップ 押下 リセット 押下
状態表の作成
状態表は、状態遷移図に相当するモデルである。 行は状態を表し、 列はイベント(存在する場合はガード条件)を表す。 テーブルの項目(セル)は遷移を表し、 ターゲット状態、ガード条件、 および定義されている場合は結果のアクションを含む。 状態遷移図とは対照的に、状態表は無効な遷移を明示的に 示し、空のセルで表す。 ISTQBテスト技術者資格制度 Foundation
Level シラバス 日本語版 Version 2023V4.0.J02 4.2.4 状態遷移テスト 状態表
状態表の作成 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下
スタート/ ストップ 押下 リセット 押下 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 一時停止中
状態表の作成 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下
スタート/ ストップ 押下 リセット 押下 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 計測中 一時停止中
状態表の作成 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下
スタート/ ストップ 押下 リセット 押下 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 計測中 一時停止中 一時停止中
状態表の作成 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下
スタート/ ストップ 押下 リセット 押下 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 計測中 一時停止中 一時停止中 計測中
状態表の作成 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下
スタート/ ストップ 押下 リセット 押下 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 計測中 一時停止中 一時停止中 計測中 待機中
状態表の作成 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下
スタート/ ストップ 押下 リセット 押下 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 計測中 一時停止中 一時停止中 計測中 待機中
状態表の作成 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下
スタート/ ストップ 押下 リセット 押下 リセット 押下 リセット 押下 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 計測中 一時停止中 一時停止中 計測中 待機中
状態表の作成 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下
スタート/ ストップ 押下 リセット 押下 リセット 押下 リセット 押下 自己遷移は ハイフンで表現する ※通例の表現 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 ー 計測中 一時停止中 ー 一時停止中 計測中 待機中
もしもリセットボタンが非活性になる場合… 動作 スタート/ストップ押下 リセット押下 前状態 待機中 計測中 N/A 計測中 一時停止中
N/A 一時停止中 計測中 待機中 待機中 計測中 スタート/ ストップ 押下 一時停止中 スタート/ ストップ 押下 スタート/ ストップ 押下 リセット 押下 起こり得ない遷移は N/A(Not Applicable)で 表現する ※通例の表現
テストケース例 # 前状態 操作 期待結果 1 0:00で停止している スタート/ストップ ボタン押下 カウントアップが始まる
2 0:00で停止している リセットボタン押下 0:00で停止したままになる 3 カウントアップしている スタート/ストップ ボタン押下 押した瞬間の時間で カウントが止まる 4 カウントアップしている リセットボタン押下 何も変わらず カウントアップし続ける 5 0:05で停止している スタート/ストップ ボタン押下 0:05からカウントアップが 再開する 6 0:05で停止している リセットボタン押下 0:00に変化し、停止している
テストケース例 # 前状態 操作 期待結果 1 0:00で停止している スタート/ストップ ボタン押下 カウントアップが始まる
2 0:00で停止している リセットボタン押下 0:00で停止したままになる 3 カウントアップしている スタート/ストップ ボタン押下 押した瞬間の時間で カウントが止まる 4 カウントアップしている リセットボタン押下 何も変わらず カウントアップし続ける 5 0:05で停止している スタート/ストップ ボタン押下 0:05からカウントアップが 再開する 6 0:05で停止している リセットボタン押下 0:00に変化し、停止している 状態遷移図や状態表では 表現できていない部分
お題
お題 (ワークのため割愛)
ポイント • 状態遷移図を描くことで、認識の違いに気付ける • 状態表を書くことで、 起こり得ない遷移や自己遷移のパターンに気付ける
カバレッジ
カバレッジ JSTQB Advanced Level テストアナリストには 以下のカバレッジが提示されている • 遷移カバレッジ • Nスイッチカバレッジ
◦ 0スイッチカバレッジ = 遷移カバレッジ ◦ 1スイッチカバレッジ ◦ 2スイッチカバレッジ … • ラウンドトリップカバレッジ • (+αとして)無効な遷移を含める
遷移カバレッジ =0スイッチカバレッジ
遷移カバレッジ(0スイッチカバレッジ) すべての状態に滞在し、すべての遷移を通過することを 保証する。 ISTQBテスト技術者資格制度 Advanced Level シラバス 日本語版 テストアナリスト Version
3.1.1.J03
遷移カバレッジ(0スイッチカバレッジ)の例 リセット スタート/ ストップ スタート/ ストップ スタート/ ストップ リセット リセット
待機中 計測中 一時停止中
遷移カバレッジ(0スイッチカバレッジ)の例 リセット スタート/ ストップ スタート/ ストップ スタート/ ストップ リセット リセット
待機中 計測中 一時停止中
遷移カバレッジ(0スイッチカバレッジ)の例 リセット スタート/ ストップ スタート/ ストップ スタート/ ストップ リセット リセット
待機中 計測中 一時停止中 上記2ケースを実行することで、 遷移カバレッジが100%になる
Nスイッチカバレッジ
Nスイッチカバレッジ 「N スイッチカバレッジ」は、長さ N+1 でカバーされた スイッチの数を意味し、その長さのスイッチの総数の パーセンテージで表す。 例えば、100%の1スイッチカバレッジを達成するには、 2つの連続する遷移のすべての有効なシーケンスを、1 回
以上テストする必要がある。 このテストでは、100%の 0 スイッチカバレッジで見落と しがちな故障の種類のいくつかを見つけ出すことができ る。 ISTQBテスト技術者資格制度 Advanced Level シラバス 日本語版 テストアナリスト Version 3.1.1.J03
Nスイッチカバレッジの説明用お題 状態C 状態A 状態B 状態D 状態E
0スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 上の各矢印をテストすることで、すべての遷移を通過する
0スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 上の各矢印をテストすることで、すべての遷移を通過する
0スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 上の各矢印をテストすることで、すべての遷移を通過する
0スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 上の各矢印をテストすることで、すべての遷移を通過する
0スイッチカバレッジを満たすテストケース 状態C 状態A 状態B 状態D 状態E 2ケースを実施することで、 0スイッチカバレッジを満たすことができる
1スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 状態Aを起点、状態Cを切り替えポイントとして、 状態A→状態C→??のパターンすべての遷移を通過する
1スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 状態Aを起点、状態Cを切り替えポイントとして、 状態A→状態C→??のパターンすべての遷移を通過する
1スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 同様に状態Bを起点、状態Cを切り替えポイントとして、 状態B→状態C→??のパターンすべての遷移を通過する
1スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 同様に状態Bを起点、状態Cを切り替えポイントとして、 状態B→状態C→??のパターンすべての遷移を通過する
1スイッチカバレッジを満たすテストケース 状態C 状態A 状態B 状態D 状態E 4ケースを実施することで、 1スイッチカバレッジを満たすことができる
2スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 2スイッチカバレッジの場合、 切り替えポイントが2箇所になる 状態F 状態G
状態I 状態H
2スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 2スイッチカバレッジの場合、 切り替えポイントが2箇所になる 状態F 状態G
状態I 状態H
2スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 2スイッチカバレッジの場合、 切り替えポイントが2箇所になる 状態F 状態G
状態I 状態H
2スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 2スイッチカバレッジの場合、 切り替えポイントが2箇所になる 状態F 状態G
状態I 状態H
2スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 2スイッチカバレッジの場合、 切り替えポイントが2箇所になる 状態F 状態G
状態I 状態H
2スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 2スイッチカバレッジの場合、 切り替えポイントが2箇所になる 状態F 状態G
状態I 状態H
2スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 2スイッチカバレッジの場合、 切り替えポイントが2箇所になる 状態F 状態G
状態I 状態H
2スイッチカバレッジ 状態C 状態A 状態B 状態D 状態E 2スイッチカバレッジの場合、 切り替えポイントが2箇所になる 状態F 状態G
状態I 状態H
ラウンドトリップ カバレッジ
ラウンドトリップカバレッジ 「ラウンドトリップカバレッジ」は、遷移のシーケンスが ループを形成するときに適用する。 100%のラウンドトリップカバレッジを達成するには、 任意の状態から同じ状態に戻るすべてのループを、ループ が開始および終了するすべての状態に対してテストする。 このループには、開始状態と終了状態を除くすべての特定 の状態が複数回含まれていてはならない。 ISTQBテスト技術者資格制度 Advanced
Level シラバス 日本語版 テストアナリスト Version 3.1.1.J03
ラウンドトリップカバレッジの例 リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット
リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/ ストップ
リセット リセット まず「待機中」状態に注目する ラウンドトリップカバレッジを満たすテストケース
ラウンドトリップカバレッジを満たすテストケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット 「待機中」状態に戻ってくる遷移は…
ラウンドトリップカバレッジを満たすテストケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット 「待機中」状態に戻ってくる遷移は…
リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/ ストップ
リセット リセット 次に「計測中」状態に戻ってくる遷移は… ラウンドトリップカバレッジを満たすテストケース
ラウンドトリップカバレッジを満たすテストケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット 次に「計測中」状態に戻ってくる遷移は…
ラウンドトリップカバレッジを満たすテストケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット 次に「計測中」状態に戻ってくる遷移は…
ラウンドトリップカバレッジを満たすテストケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット 次に「計測中」状態に戻ってくる遷移は…
リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/ ストップ
リセット リセット 最後に「一時停止中」状態に戻ってくる遷移は… ラウンドトリップカバレッジを満たすテストケース
ラウンドトリップカバレッジを満たすテストケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット 最後に「一時停止中」状態に戻ってくる遷移は…
ラウンドトリップカバレッジを満たすテストケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット 最後に「一時停止中」状態に戻ってくる遷移は…
ラウンドトリップカバレッジを満たすテストケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット 上記のテストケースが必要となる
ラウンドトリップカバレッジの対象外のケース リセット 待機中 計測中 スタート/ ストップ 一時停止中 スタート/ ストップ スタート/
ストップ リセット リセット ↑は「特定の状態が複数回含まれていてはならない。」 のラウンドトリップカバレッジの定義を満たさないため、 テストケースには入らない
お題
お題 (ワークのため割愛)
より実務に近いお題
お題 (ワークのため割愛)
ポイント • 注目点によって、作成する状態遷移図は全く異なる • 注目点によって、ある程度の抽象化が必要 • 一見すると同じ状態でも、状況によって細分化 • 状態表を書くと、自己遷移がたくさん発生する
まとめ
まとめ • 状態遷移図を描き、状態の変化について認識を揃える • 状態表を書き、気付いていなかった自己遷移や 無効な遷移を発見する • 様々なカバレッジを駆使して、工数や要求を満たす 最適なテストケースを作成する •
様々な情報がある中で適度な抽象化や細分化を行い 状態遷移図を作成する