/*******************************************************************************
*
* Copyright (c) 2010-2011 Sonatype, Inc.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
*
*
*
*
*******************************************************************************/
package org.hudsonci.maven.eventspy_30.handler;
import org.apache.maven.execution.MavenExecutionResult;
import org.hudsonci.maven.eventspy_30.EventSpyHandler;
import org.hudsonci.maven.eventspy_30.MavenProjectConverter;
import javax.inject.Named;
/**
* Handles {@link MavenExecutionResult} events.
*
* @author <a href="mailto:jason@planet57.com">Jason Dillon</a>
* @since 2.1.0
*/
@Named
public class MavenExecutionResultHandler
extends EventSpyHandler<MavenExecutionResult>
{
public void handle( final MavenExecutionResult event )
throws Exception
{
log.debug( "Execution result: {}", event );
if ( event.hasExceptions() )
{
log.info( "Build failed with exception(s)" );
int i = 0;
for ( Throwable cause : event.getExceptions() )
{
log.info( "[{}] {}", ++i, cause );
}
}
log.debug( "Recording MavenProjects" );
getBuildRecorder().recordSessionFinished( MavenProjectConverter.extractFrom( event ) );
}
}