View Javadoc
1   package org.apache.maven.surefire.its;
2   
3   /*
4    * Licensed to the Apache Software Foundation (ASF) under one
5    * or more contributor license agreements.  See the NOTICE file
6    * distributed with this work for additional information
7    * regarding copyright ownership.  The ASF licenses this file
8    * to you under the Apache License, Version 2.0 (the
9    * "License"); you may not use this file except in compliance
10   * with the License.  You may obtain a copy of the License at
11   *
12   *     http://www.apache.org/licenses/LICENSE-2.0
13   *
14   * Unless required by applicable law or agreed to in writing,
15   * software distributed under the License is distributed on an
16   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17   * KIND, either express or implied.  See the License for the
18   * specific language governing permissions and limitations
19   * under the License.
20   */
21  
22  import org.apache.maven.surefire.its.fixture.OutputValidator;
23  import org.apache.maven.surefire.its.fixture.SurefireJUnit4IntegrationTestCase;
24  import org.junit.Test;
25  
26  import java.io.File;
27  import java.io.FilenameFilter;
28  
29  import static org.fest.assertions.Assertions.assertThat;
30  
31  
32  /**
33   * Test for checking that the output from a forked suite is properly captured even if the suite encounters a severe error.
34   *
35   * @author <a href="mailto:dfabulich@apache.org">Dan Fabulich</a>
36   * @author <a href="mailto:krosenvold@apache.org">Kristian Rosenvold</a>
37   */
38  public class CheckTestNgExecuteErrorIT
39      extends SurefireJUnit4IntegrationTestCase
40  {
41      @Test
42      public void executionError()
43          throws Exception
44      {
45          OutputValidator outputValidator = unpack( "/testng-execute-error" )
46                                                    .maven()
47                                                    .sysProp( "testNgVersion", "5.7" )
48                                                    .sysProp( "testNgClassifier", "jdk15" )
49                                                    .showErrorStackTraces()
50                                                    .withFailure()
51                                                    .executeTest();
52  
53          File reportDir = outputValidator.getSurefireReportsDirectory();
54          String[] dumpFiles = reportDir.list( new FilenameFilter()
55                                               {
56                                                   @Override
57                                                   public boolean accept( File dir, String name )
58                                                   {
59                                                       return name.endsWith( ".dump" );
60                                                   }
61                                               });
62          assertThat( dumpFiles ).isNotEmpty();
63          for ( String dump : dumpFiles )
64          {
65              outputValidator.getSurefireReportsFile( dump )
66                      .assertContainsText( "at org.apache.maven.surefire.testng.TestNGExecutor.run" );
67          }
68      }
69  }