blob: 192d209913d1ae2f9c98a95898123a7c20ce43c4 [file] [log] [blame]
package org.apache.maven.plugin.surefire.log.api;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
import org.junit.Test;
import org.mockito.ArgumentCaptor;
import java.io.ByteArrayOutputStream;
import java.io.PrintStream;
import static org.fest.assertions.Assertions.assertThat;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
/**
* Tests for {@link ConsoleLoggerDecorator}, {@link NullConsoleLogger} and {@link PrintStreamLogger}.
*/
public class LoggersTest
{
@Test
public void testPrintStreamLogger()
{
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
PrintStream printStream = new PrintStream( outputStream );
PrintStreamLogger logger = new PrintStreamLogger( printStream );
assertThat( logger.isErrorEnabled() ).isTrue();
assertThat( logger.isWarnEnabled() ).isTrue();
assertThat( logger.isInfoEnabled() ).isTrue();
assertThat( logger.isDebugEnabled() ).isTrue();
logger.error( "error" );
logger.debug( "debug" );
logger.info( "info" );
logger.warning( "warning" );
String line = System.lineSeparator();
assertThat( outputStream.toString() )
.isEqualTo( "error" + line + "debug" + line + "info" + line + "warning" + line );
Exception e = new Exception( "exception" );
outputStream.reset();
logger.error( e );
assertThat( outputStream.toString() )
.contains( "java.lang.Exception: exception" )
.contains( "at " + getClass().getName() + ".testPrintStreamLogger(LoggersTest.java:61)" );
}
@Test( expected = NullPointerException.class )
public void shouldThrowNPE()
{
new ConsoleLoggerDecorator( null );
}
@Test
public void testDecorator()
{
ConsoleLogger logger = mock( ConsoleLogger.class );
ConsoleLoggerDecorator decorator = new ConsoleLoggerDecorator( logger );
assertThat( decorator.isDebugEnabled() ).isFalse();
when( logger.isDebugEnabled() ).thenReturn( true );
assertThat( decorator.isDebugEnabled() ).isTrue();
assertThat( decorator.isInfoEnabled() ).isFalse();
when( logger.isInfoEnabled() ).thenReturn( true );
assertThat( decorator.isInfoEnabled() ).isTrue();
assertThat( decorator.isWarnEnabled() ).isFalse();
when( logger.isWarnEnabled() ).thenReturn( true );
assertThat( decorator.isWarnEnabled() ).isTrue();
assertThat( decorator.isErrorEnabled() ).isFalse();
when( logger.isErrorEnabled() ).thenReturn( true );
assertThat( decorator.isErrorEnabled() ).isTrue();
ArgumentCaptor<String> argumentMsg = ArgumentCaptor.forClass( String.class );
decorator.debug( "debug" );
verify( logger, times( 1 ) ).debug( argumentMsg.capture() );
assertThat( argumentMsg.getAllValues() ).hasSize( 1 );
assertThat( argumentMsg.getAllValues().get( 0 ) ).isEqualTo( "debug" );
argumentMsg = ArgumentCaptor.forClass( String.class );
decorator.info( "info" );
verify( logger, times( 1 ) ).info( argumentMsg.capture() );
assertThat( argumentMsg.getAllValues() ).hasSize( 1 );
assertThat( argumentMsg.getAllValues().get( 0 ) ).isEqualTo( "info" );
argumentMsg = ArgumentCaptor.forClass( String.class );
decorator.warning( "warning" );
verify( logger, times( 1 ) ).warning( argumentMsg.capture() );
assertThat( argumentMsg.getAllValues() ).hasSize( 1 );
assertThat( argumentMsg.getAllValues().get( 0 ) ).isEqualTo( "warning" );
argumentMsg = ArgumentCaptor.forClass( String.class );
decorator.error( "error" );
verify( logger, times( 1 ) ).error( argumentMsg.capture() );
assertThat( argumentMsg.getAllValues() ).hasSize( 1 );
assertThat( argumentMsg.getAllValues().get( 0 ) ).isEqualTo( "error" );
ArgumentCaptor<Throwable> argumentThrowable = ArgumentCaptor.forClass( Throwable.class );
argumentMsg = ArgumentCaptor.forClass( String.class );
Exception e = new Exception();
decorator.error( "error", e );
verify( logger, times( 1 ) ).error( argumentMsg.capture(), argumentThrowable.capture() );
assertThat( argumentMsg.getAllValues() ).hasSize( 1 );
assertThat( argumentMsg.getAllValues().get( 0 ) ).isEqualTo( "error" );
assertThat( argumentThrowable.getAllValues() ).hasSize( 1 );
assertThat( argumentThrowable.getAllValues().get( 0 ) ).isSameAs( e );
argumentThrowable = ArgumentCaptor.forClass( Throwable.class );
decorator.error( e );
verify( logger, times( 1 ) ).error( argumentThrowable.capture() );
assertThat( argumentThrowable.getAllValues() ).hasSize( 1 );
assertThat( argumentThrowable.getAllValues().get( 0 ) ).isSameAs( e );
}
}