/******************************************************************************* * Copyright (c) 2010-present 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: * Stuart McCulloch (Sonatype, Inc.) - initial API and implementation *******************************************************************************/ package org.eclipse.sisu.plexus; import javax.inject.Inject; import org.codehaus.plexus.component.annotations.Component; import org.codehaus.plexus.component.annotations.Requirement; import org.eclipse.sisu.bean.BeanManager; import org.eclipse.sisu.bean.BeanProperty; import org.eclipse.sisu.bean.PropertyBinding; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.google.inject.AbstractModule; import com.google.inject.Guice; import junit.framework.TestCase; public class PlexusLoggingTest extends TestCase { static class LoggerManager implements BeanManager { public boolean manage( final Class<?> clazz ) { return false; } @SuppressWarnings( "rawtypes" ) public PropertyBinding manage( final BeanProperty property ) { if ( Logger.class.equals( property.getType().getRawType() ) ) { return new PropertyBinding() { @SuppressWarnings( "unchecked" ) public <B> void injectProperty( final B bean ) { property.set( bean, LoggerFactory.getLogger( bean.getClass() ) ); } }; } return null; } public boolean manage( final Object bean ) { return false; } public boolean unmanage( final Object bean ) { return false; } public boolean unmanage() { return false; } } @Override protected void setUp() { Guice.createInjector( new AbstractModule() { @Override protected void configure() { install( new PlexusDateTypeConverter() ); bind( PlexusBeanLocator.class ).to( DefaultPlexusBeanLocator.class ); bind( PlexusBeanConverter.class ).to( PlexusXmlBeanConverter.class ); install( new PlexusBindingModule( new LoggerManager(), new PlexusAnnotatedBeanModule( null, null ) ) ); requestInjection( PlexusLoggingTest.this ); } } ); } @Component( role = Object.class ) static class SomeComponent { @Requirement Logger logger; } @Inject SomeComponent component; public void testLogging() { assertNotNull( component.logger ); assertEquals( SomeComponent.class.getName(), component.logger.getName() ); } }