gihyo.jp » DEVELOPER STAGE » 特集 » Hudsonを使ったアジャイルな開発入門 » 第5回 高度なプロジェクトタイプ

Hudsonを使ったアジャイルな開発入門

第5回 高度なプロジェクトタイプ

この連載では,オープンソースの継続的インテグレーション(CI)サーバであるHudsonを利用した,ソフトウェア開発の生産性向上について解説しています。前回の記事では,プラグインを幾つか紹介し,また使って楽しいエクストリーム・フィードバック・デバイスについても触れました。さて,最終回となる今回は,Mavenと連携したりテストを効率よく実行したりするための高度なプロジェクトタイプを紹介します。

Mavenプロジェクトタイプ

さて,本稿では,今まで「フリースタイルプロジェクト」と呼ばれているHudsonの標準的なプロジェクトタイプを紹介してきました。この型のプロジェクトでは,任意のソースコード管理システムと,任意のビルドツールと,更に任意のビルド後処理を組み合わせることができます。この方式では,Hudsonは本質的には何がビルドされているのかまったく理解せず,単に手順を設定されたとおりに実行するだけです。この結果として,どのような種類のプロジェクトにも適用できて,高い汎用性を得ることができますが,他方,その分本質的に必要なもの以上に多くの設定を行う必要があります。何とか,この設定をより簡略化する方法はないものでしょうか。

HudsonのMavenプロジェクトタイプはこの問題を解決する一つの方法です。プロジェクトがMavenでビルドされている場合,ビルドに関する多くの情報(例えば生成されるjarファイル,テストレポート,javadocなど)はpom.xmlに既に書かれています。ビルドツールをMavenに固定する代わりに,この情報を最大限活用して自動化をよりいっそう推し進めるのが,Mavenプロジェクトタイプの基本的な発想です。このモードでは,Hudsonは実行されているMavenの中に監視ツールを配置して,Mavenが何をしているのかを追跡します。 surefireプラグインが実行されてユニットテストが走ったり,あるいはjavadocプラグインが実行されてjavadocが生成されれば,これらを記録する処理を自動的に行います。また,Mavenモジュールの一覧を表示したり,利用されたプラグインの一覧とそのバージョンを記録したりといった,Mavenに固有のユーザーインターフェースもHudson上に表示されるようになります。この結果,フリースタイルプロジェクトでは必要であった多くの設定項目が削減できます。

実際に簡単な例を見ましょう。Hudson自身はMavenでビルドされているので,HudsonをHudsonでビルドしてみます。次の画面は設定画面の主要な部分です。ご覧のように,SubversionのURL と,「clean install」というMavenのビルドフェーズが指定されている他は何の設定もありません。

画像

ところが,ビルドを実際に実行してみると,適切に設定されたフリースタイルプロジェクトと同程度かそれ以上の情報がHudsonによって収集されていることが分かります。以下は,このプロジェクトに含まれるMavenモジュールの一覧です。

画像

テスト結果も自動的に収集されて傾向が表示されます。

画像

生成されたアーティファクトも自動的に記録されています。

画像

実行されたプラグイン・mojo・及びそのバージョンとファイル指紋です。こっちのマシンではビルドできるのにあっちではビルドできないといった,プラグインのバージョンに起因するビルド関係のトラブルシューティングをする時に役立ちます。

画像

この他に,目には見えない部分でも幾つかの処理が自動的にキックインします。例えばPOMの内容から依存関係を計算され,依存しているプロジェクトが Hudson上でビルドされていれば,それらのプロジェクトの間に上流・下流関係が設定されます。POMのを利用していればそれらのメールアドレスに通知も送られます。また,追加のHudsonプラグインを導入する事でHudsonが反応できるMaven mojoの種類が増えます。例えば,FindbugsプラグインをHudsonにインストールしていると,findbugs-maven-plugin が実行されるだけで自動的にfindbugsのレポートが収集されます。

Maven サポートでのもう一つのウリは,事後のデプロイメントです。Mavenの標準の動作では,モジュールが複数あった場合には個々のモジュール毎にビルドとデプロイが繰り返されます。この結果,後ろのモジュールがビルドに失敗した時には,それより以前のモジュールは既にデプロイされてしまっていて,結果としてリポジトリが一貫性の無い状態になってしまうことがあります。HudsonにはMavenのビルドが完全に終了してからデプロイをする機能があり,この問題を防ぐことができます。

また,これと前回紹介したビルド・プロモーションを組み合わせると,より複雑なテスト工程を実行してさらに緻密に動作を検証して,プロモートされたビルドだけをリポジトリへコピーしたりすることもできます。これによって,不安定なビルドが他のユーザーのところへ流出してしまうのを防ぐことができます。

この機能はHudsonの中では比較的新しく,まだまだ改善の余地は沢山ありますが,既に十分に有用な機能になっていると思います。試してみてください。

著者プロフィール

川口耕介(かわぐちこうすけ)

Sun Microsystems, Inc.のシニアスタッフエンジニア。主としてXMLとのそのスキーマ言語関係の仕事をし,JAXB, JAXP, JAX-WSなどの仕様策定・実装に携わった。仕事の他にも,主にjava.netに多数の趣味のプロジェクトをホストしている。Hudsonは趣味のプロジェクトとして開始したが,今では本業の一部。米国カリフォルニア州在住。

URLhttp://www.kohsuke.org/

コメント

コメントの記入

パスサポ

多数の情報処理技術者試験対策書籍の発行実績を誇る技術評論社がお届けする,資格試験合格サイト「めざせ! 情報処理試験 パスサポ」が開設されました。

ピックアップ

サクセスストーリーに続く,快適サーバー運用管理のヒント!

データの増大,煩雑な管理,システムダウン,セキュリティなど,迫りくる課題からシステム管理者の負担を軽くするポイントを解説します。

gihyo.jp インフラエンジニア情報局

ネットワークやITにかかわるあらゆる業種で必要とされるインフラエンジニアに向けた技術情報や心構え,その魅力について多角的に紹介。

テストエンジニア ステーション

いま,ITに関わるあらゆる開発業務で注目されつつあるテスト系エンジニアをターゲットにしたコンテンツサイトを展開します。

一行クイックアンケート

gihyo.jpで取り上げてほしいネタは?

※検索はページ右上の検索ボックスをご利用ください。

その他の連載

はじめMath! Javaでコンピュータ数学

プログラミング言語入門者向けに,知っていると役立つ数学的トピックスを紹介します。簡単な演習問題と解説で,即活用できる知識を目指します。

小型Linuxサーバの最高峰 OpenBlockS 600活用指南

搭載メモリの増加,CPUクロックの向上など,あらゆる面が強化された期待の新モデルOpenBlockS 600。この記事ではOpenBlockS 600の紹介から,活用するためのさまざまなノウハウを紹介していきます。

教科書には載っていない ネットワークエンジニアの実践技術

ネットワークエンジニア,インフラエンジニアのトラブル対応には,時には「教科書通りにいかない」テクニックが必要となります。資格試験では得られないこうした実践的な技術について,実例を元に紹介します。

Googleケータイ,世に現る

2008年9月,Googleが中心となって開発されている「Android」を採用した携帯電話「T-Mobile G1」が発表されました。本連載ではT-Mobile G1を中心にGoogleケータイに迫ります。

モバゲーオープンプラットフォームに挑戦!――面白法人カヤック流モバゲーオープンプラットフォーム企画と開発のイロハ

2010年1月にリリースとなったモバゲーオープンプラットフォーム。その制作企業であるカヤックが,アイデアを企画に落とし込み,開発までのノウハウを紹介します。

プロトタイピングツールSketchFlowを用いた,Silverlightアプリ開発

SketchFlowプロトタイプ作成からアプリケーション開発までをExpression Blend 3を使って実践的に解説します。

Ubuntu Weekly Recipe

Ubuntuの強力なデスクトップ機能を活用するための,いろいろなレシピをお届けします。

玩式草子─ソフトウェアとたわむれる日々

Plamo Linuxのメンテナンスの傍ら,Linuxやオープンソースソフトと日々を過ごす著者が,その魅力とつきあい方を,エッセイ風味でお届けします。

連載一覧

gihyo.jp

  • DEVELOPER STAGE
  • ADMINISTRATOR STAGE
  • WEB+DESIGN STAGE
  • LIFESTYLE STAGE
  • SCIENCE STAGE
  • NEWS & REPORT

書籍案内

  • 新刊書籍
  • 書籍ジャンル一覧
  • 書籍シリーズ一覧
  • 新刊ピックアップ
  • ロングセラー
  • 電脳会議

定期刊行物一覧

  • Software Design
  • WEB+DB PRESS
  • Web Site Expert
  • 組込みプレス

最近のコメント