さまざまな作業に対応するオープンソースのテストツール群

 ソフトウェア開発プロジェクトの大小を問わず、テストは開発プロセスにおいて重要な役割を果たす。しかし、すべての組織や開発者が専用のテストツールを利用しているわけではない。そうしたツールは何百ドル、場合によっては何千ドルもするからだ。幸いにして、豊富なオープンソースのソフトウェアテストツールが無料で入手できるおかげで、そうした高価なツールの必要性は薄れつつある。

 簡単にいうと、ソフトウェアのテストは大きく2つのアプローチに分かれる。手作業によるテスト(夏期インターン生がチェックリストを使って行うのはこちら)と自動プログラムによるものだ。プログラムによる自動テストの場合、ツールの調達に多額の費用がかかったり、自動テストを行うソフトウェアのカスタマイズに追われて当座の作業がおろそかになったりする可能性がある。

 一方、 Open Source Testing (OST)、 QAForums Open Testware など、さまざまなテストツールを取り揃えたサイトに目を向け、自分の役に立つものを探し出すこともできる。

 OSTを管理しているMark Aberdour氏は次のように語る。「オープンソースのテストツールのなかで最も数が多いのは、機能テストツールだ。このカテゴリには、キャプチャ/リプレイテストやデータ駆動型テストの実行、WebアプリケーションやJavaアプリケーションを対象としたテストなど、多くのものが含まれる」。現在はソフトウェア開発に携わっているものの、これまで10年にわたってソフトウェアテストおよびテスト管理という別の側面に取り組んできたAberdour氏によれば、オープンソースのテストツールのなかにはパフォーマンステストやテスト管理/バグトラッキングのための多くのツールのほか、セキュリティテストのツールもかなり含まれているという。

 「よく使われる言語、特にテスト駆動型開発(TDD:Test-Driven Development)が多用されている言語向けには、単体テスト用のツールも含めて、多数のツールが用意されている。(WebおよびJavaアプリ用のテストツールは多数あるが)オープンソースはいつもそうであるように、何か気に入らない点があれば誰かが手を加えるので、いかなるニーズに対しても何らかのツールが存在する」。OSTには、PHP, Perl、Ruby、Flash/ActionScript、JavaScript、Python、Tcl、XMLといった言語向けのテストツールが用意されている。「おそらく私がOSTにまとめたもの以外にもテストツールはあるはずだ。TDDを実践している人は testdriven.com を参照するとよいだろう。そちらのほうがTDDに注力したサイトになっている」

 ところで、こうしたオープンソースのテストツールの出来は高価なプロプライエタリなツールに比べてどうなのだろうか。「なかには非常に優れたものもある」とAberdour氏は話す。パフォーマンステストの領域で健闘しているオープンソースツールの例として、彼は WebLOAD OpenSTA を挙げた。それもそのはず、どちらも以前は商用ツールだったものだ。ほかにも、次のようなツールに言及している。「セキュリティの領域では大人気の Wireshark 、バグトラッキングでは Bugzilla Mantis といったツールがよく知られている。機能テストの領域にも、各種機能の揃ったすばらしいツールが数多くある(たとえば SeleniumAbbotJameleonjWebUnitMarathon Sahi soapui Watin/Watir )」

 Aberdour氏によると、商用ツールの場合は、ツール本体の出来もさることながら、たいていは自動ソフトウェア品質管理(ASQ:Automated Software Quality)ツールと統合されており、また当然、名のある企業からサポートを受けられるというメリットもある。ツールを選ぶ際の基準として、こうした点を重視する人は多いだろう。しかしこのような面でも、オープンソースのテストツールの状況はよくなってきている。その例として、テストケースツールのRTH がWatir、HttpUnit、JUnit、MaxQ、そして商用のWinRunnerに統合されている点をAberdour氏は指摘する。また、MantisやBugzillaのようなバグトラッキングツールにさえ、機能テストやテストケース管理用のツールが付属している。

 信頼性と精度の高さについては、従来のオープンソース論争で述べられているとおりだとAberdour氏は言う。人気のあるツールは多くの人によってテストされ、使われている。そうしたツールには、大規模で持続的なコミュニティが形成され、品質の問題について大勢の人からフィードバックを受けているものが少なくない。「こうしたツールの多くは、非常に進化が早く、リリースが頻繁に行われる。とはいえ、何でも自由に行えるわけではない。コードベースが公開されていも、リポジトリは厳重に管理されており、書き込みの操作はコミット権を取得した開発者しか行えない」

 Aberdour氏によると、オープンソースのテストツールを利用しようとする人々にとって重要な問題は、ニーズに合うツールがあるかどうかではなく(ほとんどの場合は適切なツールが見つかるため)、見つかったツールが投資に値するほど成熟したものかどうかだという。「テストの自動化はテストチームのスキル向上、テストスクリプトの作成という点でかなりコストがかかる大がかりな取り組みであり、投資対象として適切なツールか、ライセンス料がかかるかどうかを知る必要がある。また、そのツールは5年後も使われているか、どの程度のサポートが受けられるか、機能の改良やバグの修正、今後のリリース予定などに問題がないかといった疑問も出るだろう。Aberdour氏は、選定および評価のサポートと有料の技術サポートサービスの間には大きな差があることを認めており、OSTでは次にこの部分に注力したいと考えている。

 確かに、サポート面で優れた定評のあるツールは、大きな影響力を持つ持続的なコミュニティに支えられている。しかし、まだオープンソースの市場は多数の有償サポートが利用できるという状況になっていない、とAberdour氏は話す。オープンソース製品を扱うサポート企業の例はいくつかあるものの、そうした製品のサポートチームの多くは(社員ではなく)社外から雇われた人々である。「ビジネスの面ではまだまだこの市場は未熟だが、いずれは成熟し、製品の統合、コミュニティの発展、有償サポートが適切なレベルまで来れば、きわめて破壊的なものになる可能性を秘めている。Gartner社によるとASQ市場は年間20億ドルの規模があるという。また、Hewlett-PackardとMercuryが絶対的に優勢だが、オープンソースツールの普及が進めば、より規模の小さな何百というプロプライエタリ・ベンダは相当な危機にさらされるだろう。状況は確実に正しい方向へと動きつつある」

 オープンソースのテストツールはパフォーマンス的にも優秀で、プロプライエタリなツールに比べるとかなりのお値打ち品といえる。ただ、正式の一貫したサポート体制の欠如から、ミッションクリティカルなアプリケーションのテストには使い辛いツールもある。オープンソース開発者、あるいはテスト予算に対して思うところのあるソフトウェア開発会社は、ここで紹介したテストツールのWebサイトや掲示板をのぞいてみるとよいだろう。ひょっとすると、かなりの節約ができるかもしれない。

Linux.com 原文