package hudson.plugins.dry;
import hudson.model.AbstractBuild;
import hudson.plugins.analysis.core.AbstractResultAction;
import hudson.plugins.analysis.core.HealthDescriptor;
import hudson.plugins.analysis.core.PluginDescriptor;
/**
* Controls the live cycle of the DRY results. This action persists the
* results of the DRY analysis of a build and displays the results on the
* build page. The actual visualization of the results is defined in the
* matching <code>summary.jelly</code> file.
* <p>
* Moreover, this class renders the DRY result trend.
* </p>
*
* @author Ulli Hafner
*/
public class DryResultAction extends AbstractResultAction<DryResult> {
/**
* Creates a new instance of <code>PmdResultAction</code>.
*
* @param owner
* the associated build of this action
* @param healthDescriptor
* health descriptor to use
* @param result
* the result in this build
*/
public DryResultAction(final AbstractBuild<?, ?> owner, final HealthDescriptor healthDescriptor, final DryResult result) {
super(owner, new DryHealthDescriptor(healthDescriptor), result);
}
/**
* Creates a new instance of <code>PmdResultAction</code>.
*
* @param owner
* the associated build of this action
* @param healthDescriptor
* health descriptor to use
*/
public DryResultAction(final AbstractBuild<?, ?> owner, final HealthDescriptor healthDescriptor) {
super(owner, new DryHealthDescriptor(healthDescriptor));
}
/** {@inheritDoc} */
public String getDisplayName() {
return Messages.DRY_ProjectAction_Name();
}
/** {@inheritDoc} */
@Override
protected PluginDescriptor getDescriptor() {
return new DryDescriptor();
}
/** {@inheritDoc} */
@Override
public String getMultipleItemsTooltip(final int numberOfItems) {
return Messages.DRY_ResultAction_MultipleWarnings(numberOfItems);
}
/** {@inheritDoc} */
@Override
public String getSingleItemTooltip() {
return Messages.DRY_ResultAction_OneWarning();
}
}