1 package org.apache.maven.plugin.surefire;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import org.apache.maven.plugin.surefire.log.api.ConsoleLogger;
23 import org.apache.maven.plugin.surefire.log.api.ConsoleLoggerDecorator;
24 import org.apache.maven.plugin.surefire.log.api.PrintStreamLogger;
25 import org.apache.maven.surefire.booter.IsolatedClassLoader;
26 import org.apache.maven.surefire.booter.SurefireReflector;
27 import org.junit.Before;
28 import org.junit.Test;
29
30 import static org.apache.maven.surefire.util.ReflectionUtils.getMethod;
31 import static org.apache.maven.surefire.util.ReflectionUtils.invokeMethodWithArray;
32 import static org.hamcrest.CoreMatchers.instanceOf;
33 import static org.hamcrest.MatcherAssert.assertThat;
34 import static org.hamcrest.CoreMatchers.is;
35 import static org.hamcrest.CoreMatchers.not;
36 import static org.hamcrest.CoreMatchers.notNullValue;
37 import static org.hamcrest.CoreMatchers.sameInstance;
38 import static org.mockito.Mockito.spy;
39 import static org.mockito.Mockito.times;
40 import static org.mockito.Mockito.verify;
41
42
43
44
45
46
47
48 public class SurefireReflectorTest
49 {
50 private ConsoleLogger logger;
51 private SurefireReflector reflector;
52
53 @Before
54 public void prepareData()
55 {
56 logger = spy( new PrintStreamLogger( System.out ) );
57 ClassLoader cl = new IsolatedClassLoader( Thread.currentThread().getContextClassLoader(), false, "role" );
58 reflector = new SurefireReflector( cl );
59 }
60
61 @Test
62 public void shouldProxyConsoleLogger()
63 {
64 Object mirror = reflector.createConsoleLogger( logger );
65 assertThat( mirror, is( notNullValue() ) );
66 assertThat( mirror.getClass().getInterfaces()[0].getName(), is( ConsoleLogger.class.getName() ) );
67 assertThat( mirror, is( not( sameInstance( (Object) logger ) ) ) );
68 assertThat( mirror, is( instanceOf( ConsoleLoggerDecorator.class ) ) );
69 invokeMethodWithArray( mirror, getMethod( mirror, "info", String.class ), "Hi There!" );
70 verify( logger, times( 1 ) ).info( "Hi There!" );
71 }
72 }