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
34   * a severe error.
35   *
36   * @author <a href="mailto:dfabulich@apache.org">Dan Fabulich</a>
37   * @author <a href="mailto:krosenvold@apache.org">Kristian Rosenvold</a>
38   */
39  public class CheckTestNgExecuteErrorIT
40      extends SurefireJUnit4IntegrationTestCase
41  {
42      @Test
43      public void executionError()
44          throws Exception
45      {
46          OutputValidator outputValidator = unpack( "/testng-execute-error" )
47                                                    .maven()
48                                                    .sysProp( "testNgVersion", "5.7" )
49                                                    .sysProp( "testNgClassifier", "jdk15" )
50                                                    .showErrorStackTraces()
51                                                    .withFailure()
52                                                    .executeTest();
53  
54          File reportDir = outputValidator.getSurefireReportsDirectory();
55          String[] dumpFiles = reportDir.list( new FilenameFilter()
56                                               {
57                                                   @Override
58                                                   public boolean accept( File dir, String name )
59                                                   {
60                                                       return name.endsWith( "-jvmRun1.dump" );
61                                                   }
62                                               } );
63          assertThat( dumpFiles )
64                  .isNotNull()
65                  .isNotEmpty();
66          for ( String dump : dumpFiles )
67          {
68              outputValidator.getSurefireReportsFile( dump )
69                      .assertContainsText( "at org.apache.maven.surefire.testng.TestNGExecutor.run" );
70          }
71      }
72  }