
<meta http-equiv="Context-Type" content="text/html; charset=UTF-8">
<html>
<head>
<title>Hudson</title>
</head>

<style>
dt {
display: list-item;
list-style-position:outside;
list-style-image:url(/eclipse.org-common/themes/Phoenix/images/arrow.gif);
margin-left:16px;
}
dd {
margin-left:25px;
margin-bottom:5px;
}
</style>

<body>

<p>
  The Hudson project is a proposed open source project under the <a href="http://www.eclipse.org/projects/project_summary.php?projectid=technology">Technology Top-Level Project</a>.
</p>

<p>
  This proposal is in the Project Proposal Phase (as defined in the Eclipse Development Process) and is written to declare its intent and 
  scope. We solicit additional participation and input from the Eclipse community. Please send all feedback to the  
  <a href="http://www.eclipse.org/forums/eclipse.proposals">Eclipse Proposals</a> Forum.
</p>

<h2>Description</h2>

Hudson is a <a target="_blank" href="http://martinfowler.com/articles/continuousIntegration.html">Continuous Integration (CI)</a> server. The canonical definition of CI was put forth by Martin Fowler and is as follows:

<i>
  Continuous Integration is a software development practice where members of a team integrate their work frequently, usually each person integrates at least daily - leading to multiple integrations per day. Each integration is verified by an automated build (including test) to detect integration errors as quickly as possible. Many teams find that this approach leads to significantly reduced integration problems and allows a team to develop cohesive software more rapidly. This article is a quick overview of Continuous Integration summarizing the technique and its current usage.
</i>

Hudson is a CI server written in the Java language but is itself language agnostic. Hudson can be used to automate builds for Java, .NET, C/++, Python, Ruby, or PHP projects, is often used as the basis of a <a href="http://martinfowler.com/books.html#continuousDelivery">Continuous Delivery</a> systems, but is not limited to any particular task as Hudson can really be seen as a sophisticated job scheduler capable of doing anything a human can do, except in an automated and determinsitic fashion.
         
<h2>Scope</h2>

The primary goals of this project are to make a high-quality continuous integration server and help the ecosystem of Hudson plugins, extensions and integrations flourish.

<h3>High-quality continuous integration system</h3>

This project will continue to improve the Hudson core by bolstering the test harnesses, creating a new performance harnesses, and fully automated test and release infrastructure. A process is in place to systematically move through the issues that are of most concern to users: improve stability, improve performance, improve Maven 3.x integration, improve the UI, and better integration for the most commonly used plugins. There is also a desire for the use of standard technologies, where present, in the Hudson core. A standard OSGi runtime model based on Eclipse Equinox, a standard component model using JSR330, and standard web services using JAXRS are high on the priority list. Compatibility is also of utmost importance while all these improvements are being made. Even though there are plans to use JSR330 as part of a new plugin model for Hudson, until the community decides otherwise, the existing Huson plugins will be supported without requiring changes.

<h3>Helping the ecosystem of Hudson extensions flourish</h3>

The health of the ecosystem surrounding Hudson is just as important as the Hudson core itself. There are plans to create Maven and Eclipse integrations for Hudson plugin developers. It has to be easy to create a Hudson plugin and have the ability to develop and debug it from the command line using Maven from within Eclipse (and other IDEs). There also needs to be a simple release process by which Hudson plugins can be deployed to Maven Central and be made available to users from the standard Hudson Update Center.
 
<h2>Why Eclipse?</h2> 

Traditionally the Hudson project did not have formal structure or processes.  It was grown from a pet project where the processes and structure implicitly evolved.  It is now the desire of the Hudson project to formalize the process and structure of the project to help create a healthy, open environment with well-defined rules, development process and release processes for building a high-quality and reliable continuous integration server.  Many options were considered before making the decision to create an Eclipse project.
<p>
The Eclipse foundation has a proven track record at building healthy environments for open source projects.  It is supported and respected by thousands of users and enterprise companies.  Hudson is used heavily at Eclipse and has become an integral part of the development infrastructure at Eclipse. The requirements the Eclipse Foundation has on the Hudson project mirror the requirements  of all organizations that have sophisticated enterprise CI needs where many libraries, frameworks, and projects are delivered as one consistent platform on a predetermined schedule.  The people involved in the Hudson project believe Eclipse would be a great home for Hudson and would mutually benefit the project as well as the Eclipse foundation.

<h2>Initial Contribution</h2>

The initial contribution of the Hudson core would consist of the codebase that can be viewed at Github <a href="https://github.com/hudson/hudson">here</a>. The vast majority of the code is owned by Oracle, Inc., and currently the two major organizations that are contributing to Hudson are Oracle and Sonatype. A full enumeration of the 3rd party dependencies and their licenses can be found in the accompanying documentation which can be found <a href="Hudson3rdPartyLicenses.txt">here</a>.
 
<h2>Legal Issues</h2>

There are several issues that will need to be dealt with regarding the Hudson code base. There are six 3rd party dependencies that are distributed under the LGPL.  For the following dependencies an alternative will need to be found, the license of the 3rd party dependency will need to change, or the functionality required of a particular LGPL library will need to be re-implemented.

<ul>
  <li>Java Native Access </li>
  <li>jCIFS (http://jcifs.samba.org)</li>
  <li>XOM (http://www.xom.nu)</li>
  <li>JCaptcha (http://www.jcaptcha.net/)</li>
  <li>JCommon (http://www.jfree.org/jcommon/)</li>
  <li>JFreeChart (http://www.jfree.org/jfreechart/)</li>
</ul>
 
<h2>Committers</h2>

<!-- 
	List any initial committers that should be provisioned along with the
	new project. Include affiliation, but do not include email addresses at
	this point.
 -->

<p>The following individuals are proposed as initial committers to the project:</p>

<ul>
	<li>Winston Prakash, Oracle (Project Lead)</li>
	<li>Denis Tyrell, Oracle    (Project Lead)</li>
	<li>Geoff Waymark, Oracle</li>
	<li>Susan Duncan, Oracle</li>
	<li>Duncan Mills, Oracle</li>
	<li>Jason van Zyl, Sonatype</li>
	<li>Stuart McCulloch, Sonatype</li>
	<li>Jason Dillon, Sonatype</li>
	<li>Lucas Panjer, Tasktop</li>
      <li>Doug MacEachern, VMware</li>
</ul>

<p>We welcome additional committers and contributions.</p>

<h2>Mentors</h2>

<p>The following Architecture Council members will mentor this
project:</p>

<ul>
	<li>Mik Kersten</li>
	<li>Gunnar Wagenknecht</li>
</ul>

<h2>Interested Parties</h2>

<p>The following individuals, organizations, companies and projects have 
expressed interest in this project:</p>

<ul>
      <li>Oracle Corporation</li>
      <li>Sonatype, Inc.</li>
      <li>IBM Corporation</li>
	<li>Mik Kersten, Tasktop</li>
	<li>Gil Clark, Intuit</li>
      <li>Rod Johnson, VMware</li>
	<li>Werner Keil, UOMo Project</li>
</ul>

<h2>Changes to this Document</h2>

<!-- 
	List any changes that have occurred in the document here.
	You only need to document changes that have occurred after the document
	has been posted live for the community to view and comment.
 -->

<table>
	<tr>
		<th>Date</th>
		<th>Change</th>
	</tr>
	<tr>
		<td>04-May-2011</td>
		<td>Document submitted</td>
	</tr>
	<tr>
		<td>16-May-2011</td>
		<td>Mentor added.  Contributors added.  License ownership updated in 3rd party licenses</td>
	</tr>
</table>
</body>
</html>   <html><body></body></html>