【ハウツー】
みなさんの配属された現場では、どんなテストを実施していますか。テストを分類する用語は様々で、それぞれが意味するところも組織やプロジェクトによって様々です。ここでは一般論として概要を説明してみますので、みなさんの現場に照らし合わせて考えてください。
機能やサブシステム、レイヤやライブラリ、モジュール、コンポーネントなどなど、「システムを分割した単位」を表す言葉がたくさんあるとおり、システムの設計の中で重要なアプローチに、大きくてそのままでは扱いづらいものをどのように分割するか、分割したものをどう繋ぎ合わせるか、ということがあります。
みなさんも、プログラミングを担当した箇所で、メソッドや関数を見通しが利く範囲で切り分けたりすることがあると思います。そのように「分割した単位」が、分割した意図に沿って正しく動くかどうか検証するのが単体テスト、分割したそれぞれを繋ぎ合わせて動くかどうか検証するのが結合テスト、というわけです。ですので、「単体テストとはなにか」「結合テストとはなにか」は、そのシステムをどう分割するかにまつわる、各プロジェクトの設計方針によるところが大なものです。
その上で、システム全体としてちゃんと動くか、ここでの「ちゃんと」とは「要件定義したとおりに、業務が回るか」もそうですし、「障害時に復旧できるか」「アクセスが集中してもパフォーマンスが出るか」「長時間連続運転しても大丈夫か」といった観点もあります。これらを検証する全体がシステムテストで、その内部分類として、「ちゃんと」というときの観点によって、業務運用テスト・システム運用テスト・パフォーマンステスト・ストレステストなどがあると考えるとよいでしょう。
多くのプロジェクトでは結合テストとシステムテストを、プロジェクト全体での公式・本格のテストと位置づけています。こうしたテストは、関わる人も多く、作業も複雑となるため、事前の準備が非常に重要となります。
たとえば、結合テストをするためには、結合対象のものがどういう順番で、いつ完成するかといったスケジュールも考慮する必要があります。システムテストなら、本番環境でのテストが望ましいところですが、本番環境はひとつです。場合によっては他のシステムが稼動しているところに相乗りすることもあります。いつどんなテストを実施できるか、トラブルがあったときの対応は万全か、しっかり段取りしなくてはいけません。
もちろん、テストすべき事項を洗い出し、それぞれにテストの手順、必要なデータを明らかにするなど、テストそのもののコンテンツも準備します。多くの人が連携して動く活動だけに、テストが進められなくなるようなバグが出たらどうするかなど、リスクも考慮に入れた段取りが重要です。テストは段取り八分、実施前に勝敗は半分以上決まっています。
| トマトを食べれば痩せられる!? -京大ら、新発見の成分で肥満改善効果を実証 [21:00 2/10] |
| JAXA、液体シリコン中に残存する共有結合を観察 -大口径ウェハの実現に期待 [20:11 2/10] |
| NEDOなど、熱膨張が小さな樹脂複合材料ペレットの量産化に成功 [19:22 2/10] |
| 理研、一般顕微鏡を蛍光顕微鏡に強化できるアダプタを試作して性能を実証 [19:15 2/10] |
| 天の川のブラックホールが小惑星を飲み込んでいる - NASAが発表 [18:08 2/10] |
|
かまいたちら若手6組が激突! 『NHK上方漫才コンテスト』本選出場者が決定 [13:30 2/11] エンタメ |
|
[ミス日本「海の日」]初仕事で「ジャパンインターナショナルボートショー」をPR 編集部に来訪 [13:00 2/11] エンタメ |
|
[北島三郎]「目立たなきゃだめ」と話題の“オオカミバンド”を激励 [12:30 2/11] ホビー |
|
目的は一体!? 肥前夢街道に現るバッジ売りの少猫(佐賀県) [12:08 2/11] キャリア |
|
つらい花粉症は対策グッズで乗り切ろう! [12:07 2/11] キャリア |