Skip to content

Commit

Permalink
DumpExecutionDataTest should not forcibly terminate Java processes (e…
Browse files Browse the repository at this point in the history
…clipse-eclemma#38)

Forced termination sometimes causes the appearance of the dialog
"No Coverage Data"

> No coverage data has been collected during this coverage session.
> Please do not terminate the Java process manually from Eclipse.

leading to the failure of subsequent tests

```
org.eclipse.swtbot.swt.finder.exceptions.WidgetNotFoundException: Could not find menu bar for shell: Shell with text {No Coverage Data}
	at org.eclipse.eclemma.ui.ExportImportTest.testImport(ExportImportTest.java:34)
Caused by: org.eclipse.swtbot.swt.finder.widgets.TimeoutException: Timeout after: 5000 ms.: Could not find menu bar for shell: Shell with text {No Coverage Data}
	at org.eclipse.eclemma.ui.ExportImportTest.testImport(ExportImportTest.java:34)
```
  • Loading branch information
Godin authored Nov 2, 2023
1 parent 15a1c07 commit 1919d4b
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@

import static org.junit.Assert.assertEquals;

import java.io.File;

import org.eclipse.core.runtime.ILogListener;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Platform;
Expand All @@ -38,7 +40,9 @@ public class DumpExecutionDataTest {
private static final SWTWorkbenchBot bot = new SWTWorkbenchBot();

private static ILaunch launch1;
private static String terminate1;
private static ILaunch launch2;
private static String terminate2;

@AfterClass
public static void resetWorkbench() {
Expand All @@ -53,16 +57,27 @@ public static void setup() throws Exception {
project.enableJava5();
final IPackageFragmentRoot root = project.createSourceFolder();
final IPackageFragment fragment = project.createPackage(root, "example");
project.createCompilationUnit(fragment, "Example.java",
"package example; class Example { public static void main(String[] args) throws Exception { Thread.sleep(30000); } }");

project.createCompilationUnit(fragment, "Example.java", "package example;" //
+ "import java.io.File;" //
+ "class Example {" //
+ " public static void main(String[] args) throws Exception {" //
+ " File termFile = new File(args[0]);" //
+ " while (!termFile.exists()) {" //
+ " Thread.sleep(100);" //
+ " }" //
+ " }" //
+ "}");
JavaProjectKit.waitForBuild();

ILaunchConfiguration launchConfiguration = project
.createLaunchConfiguration("example.Example");
terminate1 = project.project.getLocation().toString() + "/terminate1";
ILaunchConfiguration launchConfiguration1 = project
.createLaunchConfiguration("example.Example", terminate1);
launch1 = launchConfiguration1.launch(CoverageTools.LAUNCH_MODE, null);

launch1 = launchConfiguration.launch(CoverageTools.LAUNCH_MODE, null);
launch2 = launchConfiguration.launch(CoverageTools.LAUNCH_MODE, null);
terminate2 = project.project.getLocation().toString() + "/terminate2";
ILaunchConfiguration launchConfiguration2 = project
.createLaunchConfiguration("example.Example", terminate2);
launch2 = launchConfiguration2.launch(CoverageTools.LAUNCH_MODE, null);
}

@Test
Expand Down Expand Up @@ -91,8 +106,11 @@ public void dumpDialog_should_abort_without_errors_when_nothing_was_selected()

@AfterClass
public static void terminate() throws Exception {
launch1.terminate();
launch2.terminate();
new File(terminate1).createNewFile();
new File(terminate2).createNewFile();
while (!launch1.isTerminated() || !launch2.isTerminated()) {
Thread.sleep(100);
}

final ISessionManager sessionManager = CoverageTools.getSessionManager();
sessionManager.removeSessionsFor(launch1);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -110,8 +110,8 @@ public static void waitForBuild()
/**
* Creates launch configuration for the type with given name.
*/
public ILaunchConfiguration createLaunchConfiguration(String mainTypeName)
throws Exception {
public ILaunchConfiguration createLaunchConfiguration(String mainTypeName,
String args) throws Exception {
ILaunchConfigurationType type = DebugPlugin.getDefault().getLaunchManager()
.getLaunchConfigurationType(
IJavaLaunchConfigurationConstants.ID_JAVA_APPLICATION);
Expand All @@ -121,6 +121,8 @@ public ILaunchConfiguration createLaunchConfiguration(String mainTypeName)
javaProject.getElementName());
config.setAttribute(IJavaLaunchConfigurationConstants.ATTR_MAIN_TYPE_NAME,
mainTypeName);
config.setAttribute(
IJavaLaunchConfigurationConstants.ATTR_PROGRAM_ARGUMENTS, args);
Set<String> modes = new HashSet<String>();
modes.add(CoverageTools.LAUNCH_MODE);
config.setPreferredLaunchDelegate(modes,
Expand Down

0 comments on commit 1919d4b

Please sign in to comment.