Upgrade to Pro — share decks privately, control downloads, hide ads and more …

ソフトウェアテスト2020 / Software_Test_2020

Cybozu
August 19, 2020

ソフトウェアテスト2020 / Software_Test_2020

Cybozu

August 19, 2020
Tweet

More Decks by Cybozu

Other Decks in Technology

Transcript

  1. ⽬次 ▌テストの必要性 ▌テストに対するよくある誤解 l (1) テスト = 仕様の検証︖ l (2)

    テスト = テスト実⾏︖ ▌スクラムチームの中でのテスト 2
  2. テストの必要性(JSTQB FL 1.1) ▌BtoB から BtoC まで、社会を構成する要素として必須 ▌ソフトウェアが期待通りに動かないと︖ l 経済的な損失

    l 時間の浪費 l 信⽤の失墜 l 傷害や死亡事故 ▌ソフトウェアテストは、ソフトウェアの品質を評価し、運⽤環境でのソフト ウェアの故障が発⽣するリスクを低減する1つの⼿段 ISTQB 著、JSTQB 訳 「テスト技術者資格制度 Foundation Level シラバス (2018年度版)」、2019年 http://jstqb.jp/dl/JSTQB-SyllabusFoundation_Version2018.J03.pdf [JSTQB FL] 4
  3. テストと品質 ▌Gerald M. Weinberg l 「品質は誰かにとっての価値である」 l ソフトウェアを1⽇8時間使うユーザーにとっては使い勝⼿の良さが⾼品質 l 故障のたびに批判されるシステム管理者にとってはゼロ故障が⾼品質

    l 厳しい予算の制約下にあるプロジェクト管理者にとっては、開発費⽤が少ない ことが⾼品質 G. M. ワインバーグ著、⼤野徇郎訳『ワインバーグのシステム思考法』共⽴、1994年、p.7 9
  4. (参考)Testing と Checking ▌Checking l 「プロダクトのある側⾯に対して、アルゴリズムに基づく決定ルールを適 ⽤することで、評価を⾏うプロセスのこと。」 ▌Testing l 「プロダクトの探索と実験を通じてプロダクトを学習することによってプロ

    ダクトを評価するプロセスのこと。問いを⽴てたり、研究したり、モデル化 したり、観察したり、推論したりすることが含まれる。」 James Bach “Testing and Checking Refined”, 2013 https://www.satisfice.com/blog/archives/856 10
  5. (参考)マイヤーズの三⾓形問題 ▌以下のプログラムをテストするのに⼗分なテストケースを考えてく ださい。 lこのプログラムは、⼊⼒ダイアログから3つの整数を読む。 lこれらの3つの値は、三⾓形の3つの辺を表す。 lこのプログラムは、⼊⼒された三⾓形が正三⾓形か、⼆等辺 三⾓形か、不等辺三⾓形かを⽰すメッセージを表⽰する。 Glenford J. Myers、Tom

    Dadgett、Todd M. Thomas、Corey Sandler 著、⻑尾真、松尾正信訳 『ソフトウェア・テストの技法 第2版』近代科学社、2006、p.2 ソフトウェアテスト技術振興協会(ASTER)著、「テスト設計チュートリアル U-30クラス向け 2020年度版」、 2020 http://aster.or.jp/business/contest/doc/2020_U-30_V1.0.0.pdf 18
  6. (参考)マイヤーズの三⾓形問題(元ネタ本の回答) 1. 有効な不等辺三⾓形 2. 有効な正三⾓形 3. 有効な⼆等辺三⾓形 4. 有効な⼆等辺三⾓形の辺の組み合わせ (e.g.

    (5, 5, 6), (5, 6, 5), (6, 5, 5) ) 5. ⼀辺がゼロ 6. ⼀辺が負の数 7. ⼆辺の合計が、もう⼀辺と同じ (e.g. (1, 2 ,3) 8. ケース7の組み合わせ (e.g. (1, 2, 3), (1, 3, 2), (3, 1, 2) ) 9. ⼆辺の合計が、もう⼀辺より⼩さい (e.g. (1, 2, 4) ) 10. ケース9の組み合わせ (e.g. (1, 2, 4), (1, 4, 2), (4, 1, 2) ) 11. 全ての辺がゼロ 12. 整数以外の値 20 前掲 Glenford J. Myers ほか『ソフトウェア・テストの技法 第2版』、p.3
  7. (参考)マイヤーズの三⾓形問題(その他の回答例) ▌OS・ブラウザの組み合わせ ▌レスポンス秒数 ▌ダイアログのアクセシビリティ ▌ログの形式 ▌不正な⼊⼒値 ▌エラーハンドリング ▌エラーの表⽰⽅法 ▌API 経由での⼊⼒

    ▌XSS ▌認証・アクセス権 ▌ローカライズ ▌など…… 21 前掲 ソフトウェアテスト技術振興協会(ASTER)著、 「テスト設計チュートリアル U-30クラス向け 2020年度版」 p.8 と、サイボウズでのテストの実例を参考にした。