STLC-クイックガイド

STLCは、Software Testing LifeCycleの略です。STLCは、ソフトウェアまたは製品の品​​質を保証するためにテストチームによって実行される一連のさまざまなアクティビティです。

  • STLCは、ソフトウェア開発ライフサイクル(SDLC)の不可欠な部分です。ただし、STLCはテストフェーズのみを扱います。

  • STLCは、要件が定義されるか、SRD(ソフトウェア要件ド​​キュメント)が利害関係者によって共有されるとすぐに開始されます。

  • STLCは、高品質のソフトウェアを保証するための段階的なプロセスを提供します。

  • STLCの初期段階では、ソフトウェアまたは製品の開発中に、テスターはテストの範囲、開始基準と終了基準、およびテストケースを分析および定義できます。品質の向上とともに、テス​​トサイクルタイムの短縮に役立ちます。

  • 開発フェーズが終了するとすぐに、テスターはテストケースの準備が整い、実行を開始します。これは、初期段階でバグを見つけるのに役立ちます。

STLCフェーズ

STLCには次の異なるフェーズがありますが、すべてのフェーズに従う必要はありません。フェーズは、ソフトウェアまたは製品の性質、テストに割り当てられた時間とリソース、および従うべきSDLCのモデルによって異なります。

STLCには6つの主要なフェーズがあります-

  • Requirement Analysis − SRDの準備が整い、利害関係者と共有されると、テストチームはAUT(テスト対象アプリケーション)に関する高レベルの分析を開始します。

  • Test Planning −テストチームは戦略とアプローチを計画します。

  • Test Case Designing −範囲と基準に基づいてテストケースを開発します。

  • Test Environment Setup −統合環境で製品を検証する準備ができたとき。

  • Test Execution −製品のリアルタイム検証とバグの発見。

  • Test Closure −テストが完了すると、マトリックス、レポート、結果が文書化されます。

この章では、STLCとSDLCの比較の要因を理解します。以下の点を考慮し、STLCとSDLCを比較してみましょう。

  • STLCはSDLCの一部です。STLCはSDLCセットのサブセットであると言えます。

  • STLCは、ソフトウェアまたは製品の品​​質が保証されるテスト段階に限定されます。SDLCは、ソフトウェアまたは製品の完全な開発において非常に重要な役割を果たします。

  • ただし、STLCはSDLCの非常に重要なフェーズであり、最終製品またはソフトウェアはSTLCプロセスを経ずにリリースすることはできません。

  • STLCは、リリース後/更新サイクルの一部でもあります。SDLCのメンテナンス段階では、既知の欠陥が修正されるか、新しい機能がソフトウェアに追加されます。

次の表に、SDLCとSTLCのフェーズに基づいた比較の要因を示します。

段階 SDLC STLC
要件の収集
  • ビジネスアナリストが要件を収集します。
  • 開発チームは要件を分析します。
  • 高レベルの後、開発チームはアーキテクチャと設計の観点から分析を開始します。
  • テストチームはSRDドキュメントをレビューおよび分析します。
  • テスト要件を特定します-範囲、検証、および妥当性確認のキーポイント。
  • さまざまなモジュール間の論理的および機能的な関係の要件を確認します。これは、初期段階でギャップを特定するのに役立ちます。
設計
  • SDLCのアーキテクチャは、要件に基づいてソフトウェアの高レベルおよび低レベルの設計を開発するのに役立ちます。
  • ビジネスアナリストは、UIデザインのモッカーに取り組んでいます。
  • 設計が完了すると、利害関係者によって承認されます。
  • STLCでは、通常、テストアーキテクトまたはテストリーダーのいずれかがテスト戦略を計画します。
  • テストポイントを特定します。
  • リソースの割り当てとタイムラインはここで確定します。
開発
  • 開発チームがソフトウェアの開発を開始します。
  • さまざまなシステムと統合します。
  • すべての統合が完了すると、すぐにテストできるソフトウェアまたは製品が提供されます。
  • テストチームは、製品の品質を検証するためのテストシナリオを作成します。
  • 詳細なテストケースは、予想される動作とともにすべてのモジュールについて記述されています。
  • ここでは、テストモジュールの前提条件と開始および終了基準を示します。
環境設定
  • 開発チームは、検証するために開発された製品を使用してテスト環境をセットアップします。
  • テストチームは、前提条件に基づいて設定された環境を確認します。
  • スモークテストを実行して、テスト対象の製品の環境が安定していることを確認します。
テスト
  • 実際のテストはこのフェーズで実行されます。これには、単体テスト、統合テスト、システムテスト、欠陥の再テスト、回帰テストなどが含まれます。
  • 開発チームは、報告されたバグがある場合はそれを修正し、再テストのためにテスターに​​送り返します。
  • UATテストは、SITテストからサインオフした後にここで実行されます。
  • システム統合テストは、テストケースに基づいて開始されます。
  • 報告された欠陥がある場合は、再テストして修正します。
  • ここで回帰テストが実行され、終了基準を満たした製品は承認されます。
展開/製品リリース
  • さまざまなテストチームからサインオフを受け取ると、アプリケーションは実際のエンドユーザー向けに本番環境にデプロイされます。
  • 製品が展開されるとすぐに、実稼働環境での煙と健全性のテストがここで完了します。
  • テストレポートとマトリックスの準備は、製品を分析するためにテストチームによって行われます。
メンテナンス
  • 展開後のサポート、拡張機能、および更新(ある場合)について説明します。
  • このフェーズでは、拡張と更新に基づいて、テストケース、回帰スーツ、および自動化スクリプトの保守が行われます。

テストの一般的な目的は、できるだけ早くバグを見つけることです。また、バグが修正されたら、期待どおりに機能し、他の機能を壊さないことを確認してください。

これらの目標を達成するために、ソフトウェアテストの7つの基本原則が示されています。

テストは何を示していますか?

テストでは欠陥が存在することを示すことができますが、製品に欠陥がないことを証明する方法はありません。テストフェーズでは、テスト対象のアプリケーションが特定の要件に基づいて機能していることを確認し、アプリケーションの未発見の欠陥の可能性を減らすのに役立ちます。ただし、欠陥がない場合でも、絶対に正しいとは限りません。AUTは終了基準と一致しており、SRDに従って要件を維持していると想定できます。

徹底的なテストは可能ですか?

些細な場合を除いて、入力のすべての組み合わせおよび可能な組み合わせの100%のカバレッジまたはテストは不可能です。徹底的なテストの代わりに、リスク分析と優先順位を使用してテストの範囲を定義します。ここで、ほとんどのリアルタイムシナリオは、最も可能性の高いネガティブシナリオも含めることを検討できます。これは、障害の追跡に役立ちます。

初期テスト

テスト活動はできるだけ早く開始し、テスト戦略で定義された目的と期待される結果に焦点を当てる必要があります。テストの初期段階は、要件の欠陥または設計レベルの不一致を特定するのに役立ちます。これらのタイプのバグが初期段階で捕捉されれば、時間を節約でき、費用対効果も高くなります。テストを早い段階で開始する必要がある理由の答えは非常に簡単です。SRDを受信するとすぐに、テスターはテストの観点から要件を分析し、要件の不一致に気付くことができます。

欠陥クラスタリング

以前の製品の欠陥分析に基づくと、欠陥のほとんどは、アプリケーションにとって重要なモジュールの小さなセットから識別されていると言えます。これらのモジュールは、複雑さ、さまざまなシステムの相互作用、またはさまざまな他のモジュールへの依存性に基づいて識別できます。テスターがこれらの重要なモジュールを特定できれば、これらのモジュールにさらに焦点を当てて、考えられるすべてのバグを特定できます。ある調査では、AUTの20%の機能から10個の欠陥のうち8個が特定されていることがわかりました。

農薬のパラドックス

農薬のパラドックスとは何ですか–農薬が作物に頻繁に使用される場合、昆虫が特定の種類の耐性を発達させ、このように噴霧された農薬が徐々に昆虫に効果がないように見えるときに起こります。

同じ概念がテストにも当てはまります。ここで、昆虫は虫であり、農薬は何度も何度も実行するために使用されるテストケースです。同じテストケースのセットが何度も実行されると、これらのテストケースは特定の時間枠の後に無効になり、テスターは新しい欠陥を特定できなくなります。

これらの条件を克服するには、テストケースを随時改訂およびレビューする必要があり、新しいさまざまなテストケースを追加できます。これは、新しい欠陥を特定するのに役立ちます。

テストはコンテキストに依存します

この原則は、両方のアプリケーションが同じ性質になるまで、2つの異なるタイプのアプリケーションを同じアプローチを使用してテストすることはできないと述べています。たとえば、テスターがWebベースのアプリケーションとモバイルアプリケーションに同じアプローチを使用する場合、それは完全に間違っており、製品リリースの品質が低下するリスクが高くなります。テスターは、アプリケーションのさまざまなタイプと性質に対して、さまざまなアプローチ、方法論、手法、およびカバレッジを使用する必要があります。

エラーの欠如–誤謬

この原則は、アプリケーションまたはシステムが安定し、時間がかかり、リソースを使い果たすまで、欠陥を見つけて修正することを示しています。欠陥の99%を修正した後でも、不安定なアプリケーションのリスクが高くなります。最初に重要なことは、アプリケーションの安定性と環境の前提条件を確認することです。これらの2つの条件が満たされている場合にのみ、詳細なテストを開始できます。

要件分析はSTLCの最初のフェーズであり、SRD / SRSがテストチームと共有されるとすぐに開始されます。STLCの要求分析を理解するために、以下の点を考慮してみましょう。

  • このフェーズの開始基準は、SRS(ソフトウェア要件仕様)の提供です。また、アプリケーションアーキテクチャが便利であることをお勧めします。

  • このフェーズでは、QAチームは、何をテストし、どのようにテストするかをより高いレベルで分析します。

  • QAチームは、要件を理解するためにクエリや説明が必要な場合に備えて、ビジネスアナリスト、システムアーキテクチャ、クライアント、テストマネージャー/リードなどのさまざまな利害関係者をフォローアップします。

  • 要件は、パフォーマンス、セキュリティ、ユーザビリティなどの機能的または非機能的、あるいは機能的および非機能的の両方である可能性があります。

  • このフェーズの終了基準は、RTMドキュメント、自動化実現可能性レポート、および該当する場合は要件をより具体的にするための質問のリストを完成させることです。

要件分析のために実行されるアクティビティ

このフェーズでQAチームによって実行される3つの主要なアクティビティがあります。活動内容は以下のとおりです。

スコープの定義

QAチームは、高レベルでのテストの範囲を特定し、さまざまな機能モジュールに分割します。チームはまた、実行に必要なテストのタイプ(スモークテスト、サニティテスト、機能テスト、回帰テストなど)を特定します。QAチームは、テストが実行されることになっている前提条件と環境の詳細を分析します。チームは、テストの優先順位に関する詳細を収集し、検証するモジュールのシーケンスに焦点を当てます。また、モジュールが矛盾していて、機能が他のモジュールと一緒に引き継がれていない場合の要件の欠陥も特定します。

RTMを準備する

要件トレースは、要件と、それらの要件を実装および検証するために開発された作業成果物との間のリンクを文書化するプロセスです。RTMは、要件分析ですべての要件を、それらのトレーサビリティとともに1つのドキュメントにキャプチャします。これらはすべて、ライフサイクルの終わりに提供されます。

マトリックスは、プロジェクトの範囲と作成される成果物の基礎を形成するため、プロジェクトの最初に作成されます。

マトリックスは双方向であり、成果物の出力を調べることで要件を前方に追跡し、製品の特定の機能に指定されたビジネス要件を調べることで後方に追跡します。

自動化分析

要件フェーズでは、QAチームが回帰テストの自動化の範囲を分析します。自動化がスコープに追加された場合、チームは、使用できるツール、自動化としてカバーされる機能、自動化開発に関連する時間枠とリソース割り当てを決定します。この分析が完了すると、QAチームはさまざまな利害関係者に自動化実現可能性レポートを提供してサインオフを提供します。

この章では、STLCのさまざまなレベルでの開始基準と終了基準について説明します。基準を理解するには、以下の点を考慮する必要があります。

理想的には、QAチームは、現在のフェーズの終了基準が満たされるまで、次のフェーズに進みません。開始基準には、前のフェーズの終了基準の完了を含める必要があります。

リアルタイムで、終了基準が満たされるまで次のフェーズを待つことはできません。これで、前のフェーズの重要な成果物が完了した場合に、次のフェーズを開始できます。

STLCの各フェーズでは、開始基準と終了基準を定義する必要があります。

エントリー基準

STLCフェーズの開始基準は、特定の条件として定義できます。または、STLCの特定のフェーズを開始するために必要なすべてのドキュメントは、STLCフェーズに入る前に存在している必要があります。

エントリ基準は、タスクの実行を許可する一連の条件です。これらの条件がない場合、タスクは実行できません。

エントリー基準を設定する際には、エントリー基準項目がプロセスを開始するために利用できる時間枠を定義することも重要です。

たとえば、テストケースの開発フェーズを開始するには、次の条件を満たす必要があります。

  • 要件文書が利用可能である必要があります。
  • アプリケーションフローを完全に理解する必要があります。
  • テスト計画文書の準備ができているはずです。

終了基準

STLCフェーズの終了基準は、現在のフェーズを終了して次のフェーズに進む前に完了する必要があるアイテム/ドキュメント/アクション/タスクとして定義できます。

終了基準は一連の期待です。これは、STLCフェーズを終了する前に満たす必要があります。

たとえば、テストケースの開発フェーズを完了するには、次の期待に応える必要があります。

  • テストケースを作成して確認する必要があります。
  • テストデータを特定して準備する必要があります。
  • 該当する場合は、テスト自動化スクリプトの準備ができている必要があります。

受け入れ基準とは、要件ドキュメントに記載されている機能、モジュール、およびアプリケーションの予想される動作を意味します。ソフトウェアシステムが要件仕様を満たしているかどうかを判断するのは、検証段階/チェックポイントです。このテストの主な目的は、システムがビジネス要件に準拠しているかどうかを評価し、必要な基準を満たしているかどうかを確認することです。

受け入れ基準は、予想される合格/不合格の結果について明確に言及する一連のステートメントです。受け入れ基準は、機能要件と非機能要件の両方を指定します。これらの要件は、「満足の条件または期待される行動」を表しています。部分的な受け入れはありません。基準が満たされているか、満たされていないかのいずれかです。

これらの基準は、機能/モジュールの境界とパラメーターを定義し、機能/モジュールが完了して期待どおりに機能しているかどうかを判別します。

高レベルの受け入れ基準は、テスト計画レベルで言及されています。受け入れ基準は、テストケースレベルで検証または期待される結果のポイントのリストに変換されます。

受け入れ基準は、次の属性に基づいて定義されます-

  • 機能の正確性と完全性
  • データの整合性
  • データ変換
  • Usability
  • Performance
  • Timeliness
  • 機密性と可用性
  • インストールおよびアップグレード機能
  • Scalability
  • Documentation

テスト計画は、アプリケーションのテストに使用される戦略、使用されるリソース、テストが実行されるテスト環境、およびテストの制限とテストアクティビティのスケジュールの概要を示します。通常、品質保証チームリーダーは、テスト計画の作成を担当します。

テスト計画には何が含まれていますか?

テスト計画には、次のものが含まれます。

  • テスト計画ドキュメントの概要。
  • アプリケーションのテスト中の仮定。
  • アプリケーションのテストに含まれるテストケースのリスト。
  • テストする機能のリスト。
  • ソフトウェアのテスト中に使用される一種のアプローチ。
  • テストが必要な成果物のリスト。
  • アプリケーションのテストに割り当てられたリソース。
  • テストプロセス中に関連するリスク。
  • 達成すべきタスクとマイルストーンのスケジュール。

テスト計画の重要なポイント

STLCのテスト計画では、次の点を考慮する必要があります。

  • 理想的には、テストアナリスト(リード)/マネージャーがテスト戦略/テスト計画文書を作成します。

  • 分析は、アプリケーション関連のデータ/情報に重点を置いています。

  • これは、実際のテストタスクの最初のフェーズです。

  • このフェーズでは、「何をテストするか」と「どのリソースをテストする必要があるか」に回答します。

  • このフェーズの基本的な入力基準は、要件トレーサビリティマトリックスとともに要件ドキュメント(不明確/欠落/明確化された要件の更新バージョン)の提供です。

  • 自動化の範囲内にある場合は、このフェーズに入る前に自動化実現可能性レポートを作成する必要があります。

  • このフェーズの終了基準は、テスト戦略/テスト計画ドキュメントとテスト作業見積もりドキュメントの完了です。

テスト計画フェーズの側面

このフェーズの主な目的は、テスト計画/テスト戦略ドキュメントを準備することです。これには、成果物の範囲、労力の見積もり、およびリソース計画の3つの主要な側面が含まれます。

成果物の範囲

成果物の範囲を結論付けるには、次のアクティビティを実行する必要があります-

  • 適切なエンゲージメントと配信モデルを特定します。
  • テストの目的、テストの範囲、テストのフェーズおよびアクティビティを定義します。
  • ビジネス要件とシステム要件を確認して、テストの実現可能性を特定します。
  • テストプロセス、テストの種類、および手順を定義します。
  • 欠陥管理と変更管理の手順を定義します。
  • テストツール、手法、およびベストプラクティスを特定します。
  • リスク分析を定義します。
  • 自動化ソリューションを定義し、該当する場合は自動化に適した候補を特定します。

労力の見積もり

推定とは、入力データが不完全、不確実、または不安定な場合でも、何らかの目的で使用できる値である推定または近似を見つけるプロセスです。

見積もりによって、特定のシステムまたは製品を構築するのにかかる費用、労力、リソース、および時間が決まります。見積もりは以下に基づいています-

  • 過去のデータ/過去の経験
  • 利用可能なドキュメント/知識
  • Assumptions
  • 特定されたリスク

テスト見積もりの​​4つの基本的なステップは次のとおりです。

  • AUT(テスト対象アプリケーション)のサイズの見積もり。
  • 人月または人時間での労力の見積もり。
  • 暦月のスケジュールの見積もり。
  • 合意された通貨でのプロジェクトコストの見積もり。

リソースプラン

リソース計画は、テストフェーズの重要な要素です。これらの計画は、テストチームが特定のタスクを完了するのにかかる時間に反比例します。リソースの数を増やすと、一定の制限の完了日数が減少し、その後は飽和状態になります。リソースの増加はあまり影響を与えず、完了日数の減少につながらない可能性があります。

リソースリクエスター(通常はプロジェクトマネージャー)は、リソースを要求し、労力とコストを追跡するためのリソース計画を作成します。リソースマネージャは、プランが使用される前にリソースプランを変更および承認できます。

リソースプランの通常のワークフローは次のとおりです。

  • プロジェクトマネージャーによる計画
  • プロジェクトマネージャーからのリクエスト
  • リソースマネージャーによる承認/変更/拒否
  • 完了-リソースマネージャーによるサインオフ後にリクエストを閉じる

テスト計画の準備ができたら、QAチームはテストケースの開発を開始します。このフェーズの主な目的は、個々のユニットのテストケースを準備することです。これらの機能的および構造的テストケースは、テスト計画に記載されている機能、検証および妥当性確認のポイントをカバーしています。

STLCでのテストケース開発では、以下の点を考慮する必要があります。

  • このフェーズでは、QAチームが段階的なアプローチでテストケースを作成します。テストケースは、変更が必要な場合にテストケースを確認またはやり直した後、ビジネスアナリストによって承認されます。

  • テストケースの準備ができたら、QAチームは前提条件に基づいてテストデータを準備します。

  • このフェーズの開始基準は、テスト計画のアクティビティが終了し、テスト計画の準備ができている必要があることです。

  • このフェーズの終了基準は、テストケースを承認し、テストデータを準備し、自動化の範囲内にある場合はテストスクリプトを準備することです。

  • テストケースは、要件トレーサビリティマトリックスを使用してマッピングし、不足している要件の範囲をフォローアップする必要があります。

テストケース開発フェーズのアクティビティ

以下は、テストケース開発フェーズで実行される3つのアクティビティです。

テストシナリオの識別

シナリオにより、複雑なシステムのテストと評価が容易になります。次の戦略は、適切なシナリオの作成に役立ちます-

  • 考えられるユーザー、そのアクション、および目的を列挙します。

  • ハッカーの考え方でユーザーを評価し、システムの悪用の考えられるシナリオをリストします。

  • システムイベントと、システムがそのような要求をどのように処理するかをリストします。

  • メリットを一覧表示し、エンドツーエンドのタスクを作成してそれらを確認します。

  • 同様のシステムとその動作について読んでください。

  • 競合他社の製品とその前身に関する苦情を調査し​​ます。

テストケースの作成

テストケースは、特定の要件に対するコンプライアンスを検証するために、特定のテストシナリオ用に作成された、テストデータ、前提条件、期待される結果、および事後条件を含むドキュメントです。

テストケースは、テスト実行の開始点として機能します。入力値のセットが適用された後。アプリケーションには決定的な結果があり、実行後の状態としても知られるエンドポイントでシステムを離れます。

テストデータの準備

テストデータは、テストウェアでテストを実行するために使用されます。テストデータは、欠陥を明らかにするために正確かつ網羅的である必要があります。これらの3つの目的を達成するために、以下に示す段階的なアプローチが続きます。

  • テストリソースまたは要件を特定する
  • テストする条件/機能を特定する
  • 優先テスト条件を設定する
  • テストの条件を選択します
  • テストケースの処理の期待される結果を決定する
  • テストケースを作成する
  • テスト条件を文書化する
  • テストを実施する
  • 変更に基づいてテストケースを検証および修正する

アクティビティブロック図

次の図は、テストケース開発の一部を形成するさまざまなアクティビティを示しています。

テスト環境は、ソフトウェア、ハードウェア、およびネットワークが構成された状態でのテスト実行をサポートする要素で構成されています。テスト環境の構成は、環境/構成に関連する問題を明らかにするために、実稼働環境を模倣する必要があります。

テスト環境のセットアップでは、次の点を考慮する必要があります。

  • これは、テストが実行されるハードウェア環境とソフトウェア環境の組み合わせです。

  • これには、ハードウェア構成、オペレーティングシステム設定、ソフトウェア構成、テスト端末、およびテストを実行するためのその他のサポートが含まれます。

  • これは、テストプロセスの最も重要な側面です。使用不可または環境設定の誤りは、すべてのテスト作業を台無しにする可能性があります。

  • 実際には、QAチームは、テストするための適切な環境がなければ、実際の作業を開始することはできません。

  • これは独立した活動であり、テストケースの開発とともに開始できます。

  • 最も一般的には、このアクティビティは技術面で開発者が実行しますが、要件条件は顧客/ビジネスアナリストが実行できます。

  • テスト環境の準備は、スモークテストによって検証され、QAチームによって実行されます。

  • 理想的には、このフェーズの入力基準は、テスト計画の提供、煙テストケースの準備、およびテストデータの準備であると言えます。

  • このフェーズの終了基準は、テスト環境の準備ができており、スモークテストが正常に実行されて期待される結果が得られることです。

テスト環境のセットアップのために実行されるアクティビティ

このフェーズでは、次のアクティビティが実行されます。

設計テスト環境

テスト環境の設計には、次の要素が重要な役割を果たします。

  • バックアップを取るためにテスト環境をアーカイブする必要があるかどうかを判断します。

  • ネットワーク構成を確認します。

  • 必要なサーバーオペレーティングシステム、データベース、およびその他のコンポーネントを特定します。

  • テストチームが必要とするライセンスの数を特定します。

環境の設定

環境セットアップ要件を分析し、セットアップのソフトウェアおよびハードウェア要件のリストを準備します。テスト環境のセットアップに関する公式の確認を取得し、テスト環境にアクセスするように構成します。

スモークテスト

環境がセットアップされ、QAチームがそれにアクセスできるようになったら、テスト環境の構築の安定性を検証するために、スモークテストをすばやく実行する必要があります。結果が期待どおりである場合、QAチームは次のフェーズに進むことができます。そうでない場合は、不一致を指摘し、修正後に展開を待つことができます。

テストの実行は、コードを実行し、期待される結果と実際の結果を比較するプロセスです。テスト実行プロセスでは、次の要素を考慮する必要があります-

  • リスクに基づいて、このサイクルで実行するテストスイートのサブセットを選択します。
  • 各テストスイートのテストケースをテスターに​​割り当てて実行します。
  • テストを実行し、バグを報告し、テストステータスを継続的にキャプチャします。
  • 発生したブロッキングの問題を解決します。
  • ステータスを報告し、割り当てを調整し、計画と優先順位を毎日再検討します。
  • テストサイクルの結果とステータスを報告します。

テスト実行では、以下の点を考慮する必要があります。

  • このフェーズでは、QAチームは、準備されたテストケースに基づいてAUTの実際の検証を実行し、段階的な結果を期待される結果と比較します。

  • このフェーズの開始基準は、テスト計画とテストケース開発フェーズの完了です。テストデータも準備できている必要があります。

  • テスト環境のセットアップの検証は、テストの実行に正式に入る前に、スモークテストを通じて常に推奨されます。

  • 終了基準には、すべてのテストケースの検証が成功する必要があります。欠陥はクローズまたは延期する必要があります。テストケースの実行と欠陥の要約レポートを準備する必要があります。

テスト実行のためのアクティビティ

このフェーズの目的は、本番/リリースに移る前にAUTをリアルタイムで検証することです。このフェーズからサインオフするために、QAチームはさまざまなタイプのテストを実行して製品の品質を確認します。この欠陥の報告と再テストに加えて、このフェーズでは重要なアクティビティもあります。このフェーズの重要な活動は次のとおりです-

システム統合テスト

製品/ AUTの実際の検証はここから始まります。システム統合テスト(SIT)は、準備された特定の要件/テストケースに対するシステムのコンプライアンスを評価するブラックボックステスト手法です。

システム統合テストは通常​​、システムのサブセットで実行されます。SITは、テストツールを最小限に使用して実行でき、交換された相互作用について検証され、個々のレイヤー内の各データフィールドの動作も調査されます。統合後、データフローには3つの主要な状態があります-

  • 統合レイヤー内のデータ状態
  • データベースレイヤー内のデータ状態
  • アプリケーション層内のデータ状態

Note− SITテストでは、QAチームは品質を確保するためにできるだけ多くの欠陥を見つけようとします。ここでの主な目的は、できるだけ多くのバグを見つけることです。

欠陥報告

期待される結果が実際の結果と一致しない場合、ソフトウェアのバグが発生します。これは、コンピュータープログラムのエラー、欠陥、障害、または障害である可能性があります。ほとんどのバグは、開発者やアーキテクトによるミスやエラーから発生します。

SITテストの実行中に、QAチームはこれらのタイプの欠陥を発見し、関係するチームメンバーに報告する必要があります。メンバーはさらに行動を起こし、欠陥を修正します。レポートのもう1つの利点は、欠陥のステータスの追跡が容易になることです。欠陥の報告と追跡をサポートするALM、QC、JIRA、バージョン1、Bugzillaなどの人気のあるツールが多数あります。

欠陥レポートは、顧客からのフィードバックをテストまたは記録し、クライアントのフィードバックに基づいて欠陥を修正する製品の新しいバージョンを作成することにより、テスト対象のアプリケーションまたは製品の欠陥を見つけるプロセスです。

複雑でビジネスクリティカルなシステムには何百もの欠陥があるため、欠陥追跡もソフトウェアエンジニアリングの重要なプロセスです。最も困難な要因の1つは、これらの欠陥の管理、評価、および優先順位付けです。欠陥の数は一定期間にわたって増加し、それらを効果的に管理するために、欠陥追跡システムを使用して作業を容易にします。

欠陥マッピング

欠陥が報告されてログに記録されたら、関連する失敗/ブロックされたテストケースと、要件トレーサビリティマトリックスの対応する要件にマッピングする必要があります。このマッピングは、DefectReporterによって行われます。適切な欠陥レポートを作成し、製品の欠陥を分析するのに役立ちます。テストケースと要件が欠陥にマッピングされると、利害関係者は、優先度と重大度に基づいて欠陥を修正/延期するかどうかを分析して決定できます。

再テスト

再テストとは、以前に失敗したAUTに対するテストを実行して、問題が解決したかどうかを確認することです。欠陥が修正された後、同じ環境条件下でシナリオをチェックするために再テストが実行されます。

再テスト中、テスターは機能の変更された領域で詳細を探しますが、回帰テストはすべての主要な機能をカバーして、この変更によって機能が壊れていないことを確認します。

回帰試験

すべての欠陥がクローズ、延期、または拒否のステータスになり、テストケースのいずれも進行中/失敗/実行なしのステータスになると、システム統合テストは完全にテストケースと要件に基づいていると言えます。ただし、コードの変更や欠陥の修正によって機能が破損していないことを確認するには、1回のクイックテストが必要です。

回帰テストは、コードの変更によって影響を受けたテストを再実行することで構成されるブラックボックステスト手法です。これらのテストは、ソフトウェア開発ライフサイクル全体を通じて可能な限り頻繁に実行する必要があります。

回帰テストの種類

  • Final Regression Tests−「最終回帰テスト」は、一定期間変更されていないビルドを検証するために実行されます。このビルドは、展開または顧客に出荷されます。

  • Regression Tests −通常の回帰テストを実行して、欠陥修正または拡張のための最近のコード変更によって、ビルドがアプリケーションの他の部分を破壊していないかどうかを確認します。

アクティビティブロック図

次のブロック図は、このフェーズで実行される重要なアクティビティを示しています。また、前のフェーズからの依存関係も示しています-

欠陥ライフサイクルは、バグライフサイクルとも呼ばれ、欠陥の旅であり、欠陥がその存続期間中に通過するサイクルです。これは、ソフトウェアのテストプロセスによって管理され、使用するツールにも依存するため、組織ごとに、またプロジェクトごとに異なります。

欠陥のライフサイクル–ワークフロー

次の図は、欠陥ライフサイクルのワークフローを示しています。

欠陥のライフサイクルの状態

以下は、欠陥ライフサイクルのさまざまな状態です。

  • New −発生しているが、まだ検証されていない潜在的な欠陥。

  • Assigned −対処する開発チームに対して割り当てられます。

  • Active−欠陥は開発者によって対処されており、調査が進行中です。この段階では、2つの可能な結果があります-延期または拒否。

  • Test / Fixed / Ready for Retest −欠陥は修正され、テストの準備ができています。

  • Verified −再テストされ、テストがQAによって検証された欠陥。

  • Closed − QA再テスト後に閉じることができる、または欠陥が重複しているか、欠陥ではないと見なされた場合に閉じることができる欠陥の最終状態。

  • Reopened −欠陥が修正されていない場合、QAは欠陥を再開/再アクティブ化します。

  • Deferred −その特定のサイクルで欠陥に対処できない場合、それは将来のリリースまで延期されます。

  • Rejected −欠陥は、重複欠陥、欠陥ではない、再現不可能という3つの理由のいずれかで拒否される可能性があります。

欠陥は、QAチームの観点から次のように分類されます。 Priority そして開発の観点から Severity(それを修正するためのコードの複雑さ)。これらは、時間枠と欠陥を修正するために行われる作業の量で重要な役割を果たす2つの主要な分類です。

優先度とは何ですか?

優先度は、欠陥を解決する必要がある順序として定義されます。優先度ステータスは通常、QAチームによって設定され、開発チームに対して欠陥を提起し、欠陥を修正するための時間枠について言及します。優先度ステータスは、エンドユーザーの要件に基づいて設定されます。

たとえば、会社のロゴが会社のWebページに誤って配置されている場合、優先度は高くなりますが、重大度は低くなります。

優先リスト

優先度は次の方法で分類できます-

  • Low −この欠陥は、重大な欠陥が修正された後に修正できます。

  • Medium −欠陥は、後続のビルドで解決する必要があります。

  • High −欠陥はアプリケーションにかなりの影響を及ぼし、関連するモジュールは修正されるまで使用できないため、欠陥は直ちに解決する必要があります。

  • Urgent −欠陥はアプリケーションまたは製品に深刻な影響を及ぼし、修正されるまで製品を使用できないため、欠陥は直ちに解決する必要があります。

重大度とは何ですか?

重大度は、アプリケーションの欠陥の影響と、開発の観点から修正するためのコードの複雑さとして定義されます。 It製品の開発面に関連しています。重大度は、システムの欠陥がどれほど悪い/重大であるかに基づいて決定できます。重大度ステータスは、欠陥による機能の逸脱についてのアイデアを与えることができます。

Example −フライト運営ウェブサイトの場合、予約に対するチケット番号の生成の欠陥は重大度が高く、優先度も高くなります。

重大度リスト

重大度は次のように分類できます-

  • Critical /Severity 1−欠陥はアプリケーションの最も重要な機能に影響を与え、QAチームはそれを修正せずにテスト中のアプリケーションの検証を続行することはできません。たとえば、アプリ/製品が頻繁にクラッシュします。

  • Major / Severity 2−欠陥は機能モジュールに影響を与えます。QAチームはその特定のモジュールをテストできませんが、他のモジュールの検証を続行します。たとえば、フライトの予約が機能していません。

  • Medium / Severity 3−欠陥は単一の画面に問題があるか、単一の機能に関連していますが、システムはまだ機能しています。ここでの欠陥は、機能をブロックしません。たとえば、Ticket#は、最初の5文字や最後の5文字のような適切な英数字に従わない表現です。

  • Low / Severity 4−機能には影響しません。これは、外観上の欠陥、フィールドのUIの不整合、またはUI側からのエンドユーザーエクスペリエンスを改善するための提案である可能性があります。たとえば、[送信]ボタンの背景色が[保存]ボタンの背景色と一致していません。

テストが完了したことを主張するには、テスト終了基準に対するチェックが非常に重要です。テストプロセスを終了する前に、製品の品質がテスト完了基準に照らして測定されます。

このフェーズの開始基準は、テストケースの実行が完了し、テスト結果が利用可能であり、欠陥レポートの準備ができていることです。

テスト完了の基準には、次のものが含まれます。

  • 指定されたカバレッジが達成されました。
  • 番号 showstoppers または重大な欠陥
  • 既知の中優先度または低優先度の欠陥はほとんどありません。これらは製品の使用には影響しません。

このフェーズの終了基準は、テスト終了レポートの提供と、後でクライアントによって承認されるマトリックスの準備です。

それでは、 activities involved in the closure of Test Cycle

テスト完了レポート

テスト完了レポートは、利害関係者を更新するためにテストメトリックが要約形式でレポートされるプロセスです。これにより、情報に基づいた決定を下すことができます。

テスト完了レポートには、次の情報が含まれています。

  • テストサマリーレポート識別子
  • Summary
  • Variances
  • まとめ結果
  • Evaluation
  • 計画された取り組みと実際の取り組み
  • サインオフ

優れたテスト完了レポートは、品質を示し、未解決のリスクを測定し、テストされたソフトウェアのレベルを識別します。

テスト完了マトリックス

テストが完了すると、さまざまなマトリックスが収集され、テストレポートが作成されます。報告書作成の基準は以下のとおりです。

  • 実行されたテストの数
  • 合格したテストの数
  • 失敗したテストの数
  • 各モジュールに基づく失敗したテストの数
  • 実行サイクル中に発生したテスト欠陥の数
  • 受け入れられたテスト欠陥の数
  • 拒否されたテスト欠陥の数
  • 延期されたテスト欠陥の数
  • アクティブな欠陥のステータス
  • ビルドの品質インデックスの計算

試験結果

テストケースの実行、欠陥の再テスト、および回帰テストケースの実行中に、 Test results articulate 保存する必要があり、テスト実行の完了をサポートするために、テストサイクルクロージャドキュメントと一緒に作成できます。

アーティキュレートには、スクリーンショット、データベースクエリの結果、記録、ログファイルなどがあります。