blob: 840f7e3ca41cc231a6742023c677380c4099b487 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2006 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
* Julien Ruaux: jruaux@octo.com
* Vincent Massol: vmassol@octo.com
* David Saff (saff@mit.edu) - bug 102632: [JUnit] Support for JUnit 4.
*******************************************************************************/
package org.eclipse.jdt.internal.junit.ui;
import java.net.URL;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.FileLocator;
import org.eclipse.core.runtime.IConfigurationElement;
import org.eclipse.core.runtime.IExtensionPoint;
import org.eclipse.core.runtime.IPath;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.MultiStatus;
import org.eclipse.core.runtime.Path;
import org.eclipse.core.runtime.Platform;
import org.eclipse.core.runtime.Status;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.jface.action.IAction;
import org.eclipse.jface.dialogs.IDialogSettings;
import org.eclipse.jface.resource.ImageDescriptor;
import org.eclipse.ui.IWorkbench;
import org.eclipse.ui.IWorkbenchPage;
import org.eclipse.ui.IWorkbenchWindow;
import org.eclipse.ui.plugin.AbstractUIPlugin;
import org.eclipse.jdt.junit.ITestRunListener;
import org.eclipse.jdt.internal.junit.model.JUnitModel;
import org.osgi.framework.Bundle;
import org.osgi.framework.BundleContext;
import org.osgi.framework.ServiceReference;
import org.osgi.service.packageadmin.PackageAdmin;
/**
* The plug-in runtime class for the JUnit plug-in.
*/
public class JUnitPlugin extends AbstractUIPlugin {
//TODO: move to org.eclipse.jdt.internal.junit
/**
* The single instance of this plug-in runtime class.
*/
private static JUnitPlugin fgPlugin= null;
public static final String PLUGIN_ID= "org.eclipse.jdt.junit"; //$NON-NLS-1$
public static final String ID_EXTENSION_POINT_TESTRUN_LISTENERS= PLUGIN_ID + "." + "testRunListeners"; //$NON-NLS-1$ //$NON-NLS-2$
public static final String ID_EXTENSION_POINT_JUNIT_LAUNCHCONFIGS= PLUGIN_ID + "." + "junitLaunchConfigs"; //$NON-NLS-1$ //$NON-NLS-2$
public static final String ID_EXTENSION_POINT_TEST_KINDS= PLUGIN_ID + "." + "internal_testKinds"; //$NON-NLS-1$ //$NON-NLS-2$
public final static String TEST_SUPERCLASS_NAME= "junit.framework.TestCase"; //$NON-NLS-1$
public final static String TEST_INTERFACE_NAME= "junit.framework.Test"; //$NON-NLS-1$
public final static String JUNIT4_ANNOTATION_NAME= "org.junit.Test"; //$NON-NLS-1$
public static final String SIMPLE_TEST_INTERFACE_NAME= "Test"; //$NON-NLS-1$
/**
* The class path variable referring to the junit home location
*/
public final static String JUNIT_HOME= "JUNIT_HOME"; //$NON-NLS-1$
/**
* The class path variable referring to the junit source location
* @since 3.2
*/
public final static String JUNIT_SRC_HOME= "JUNIT_SRC_HOME"; //$NON-NLS-1$
private static final IPath ICONS_PATH= new Path("$nl$/icons/full"); //$NON-NLS-1$
private final JUnitModel fJUnitModel= new JUnitModel();
/**
* List storing the registered test run listeners
*/
private List/*<ITestRunListener>*/ fTestRunListeners;
/**
* List storing the registered JUnit launch configuration types
*/
private List fJUnitLaunchConfigTypeIDs;
private BundleContext fBundleContext;
private static boolean fIsStopped= false;
public JUnitPlugin() {
fgPlugin= this;
}
public static JUnitPlugin getDefault() {
return fgPlugin;
}
public static Shell getActiveWorkbenchShell() {
IWorkbenchWindow workBenchWindow= getActiveWorkbenchWindow();
if (workBenchWindow == null)
return null;
return workBenchWindow.getShell();
}
/**
* Returns the active workbench window
*
* @return the active workbench window
*/
public static IWorkbenchWindow getActiveWorkbenchWindow() {
if (fgPlugin == null)
return null;
IWorkbench workBench= fgPlugin.getWorkbench();
if (workBench == null)
return null;
return workBench.getActiveWorkbenchWindow();
}
public static IWorkbenchPage getActivePage() {
IWorkbenchWindow activeWorkbenchWindow= getActiveWorkbenchWindow();
if (activeWorkbenchWindow == null)
return null;
return activeWorkbenchWindow.getActivePage();
}
public static String getPluginId() {
return PLUGIN_ID;
}
public static void log(Throwable e) {
log(new Status(IStatus.ERROR, getPluginId(), IStatus.ERROR, "Error", e)); //$NON-NLS-1$
}
public static void log(IStatus status) {
getDefault().getLog().log(status);
}
public static ImageDescriptor getImageDescriptor(String relativePath) {
IPath path= ICONS_PATH.append(relativePath);
return createImageDescriptor(getDefault().getBundle(), path, true);
}
/**
* Sets the three image descriptors for enabled, disabled, and hovered to an action. The actions
* are retrieved from the *lcl16 folders.
*
* @param action the action
* @param iconName the icon name
*/
public static void setLocalImageDescriptors(IAction action, String iconName) {
setImageDescriptors(action, "lcl16", iconName); //$NON-NLS-1$
}
private static void setImageDescriptors(IAction action, String type, String relPath) {
ImageDescriptor id= createImageDescriptor("d" + type, relPath, false); //$NON-NLS-1$
if (id != null)
action.setDisabledImageDescriptor(id);
ImageDescriptor descriptor= createImageDescriptor("e" + type, relPath, true); //$NON-NLS-1$
action.setHoverImageDescriptor(descriptor);
action.setImageDescriptor(descriptor);
}
/*
* Creates an image descriptor for the given prefix and name in the JDT UI bundle. The path can
* contain variables like $NL$.
* If no image could be found, <code>useMissingImageDescriptor</code> decides if either
* the 'missing image descriptor' is returned or <code>null</code>.
* or <code>null</code>.
*/
private static ImageDescriptor createImageDescriptor(String pathPrefix, String imageName, boolean useMissingImageDescriptor) {
IPath path= ICONS_PATH.append(pathPrefix).append(imageName);
return createImageDescriptor(JUnitPlugin.getDefault().getBundle(), path, useMissingImageDescriptor);
}
/**
* Creates an image descriptor for the given path in a bundle. The path can
* contain variables like $NL$. If no image could be found,
* <code>useMissingImageDescriptor</code> decides if either the 'missing
* image descriptor' is returned or <code>null</code>.
*
* @param bundle
* @param path
* @param useMissingImageDescriptor
* @return an {@link ImageDescriptor}, or <code>null</code> iff there's
* no image at the given location and
* <code>useMissingImageDescriptor</code> is <code>true</code>
*/
private static ImageDescriptor createImageDescriptor(Bundle bundle, IPath path, boolean useMissingImageDescriptor) {
URL url= FileLocator.find(bundle, path, null);
if (url != null) {
return ImageDescriptor.createFromURL(url);
}
if (useMissingImageDescriptor) {
return ImageDescriptor.getMissingImageDescriptor();
}
return null;
}
/**
* @see AbstractUIPlugin#start(BundleContext)
*/
public void start(BundleContext context) throws Exception {
super.start(context);
fBundleContext= context;
fJUnitModel.start();
}
/**
* @see AbstractUIPlugin#stop(BundleContext)
*/
public void stop(BundleContext context) throws Exception {
fIsStopped= true;
try {
fJUnitModel.stop();
} finally {
super.stop(context);
}
fBundleContext= null;
}
public static JUnitModel getModel() {
return getDefault().fJUnitModel;
}
/**
* Initializes TestRun Listener extensions
*/
private void loadTestRunListeners() {
fTestRunListeners= new ArrayList();
IExtensionPoint extensionPoint= Platform.getExtensionRegistry().getExtensionPoint(ID_EXTENSION_POINT_TESTRUN_LISTENERS);
if (extensionPoint == null) {
return;
}
IConfigurationElement[] configs= extensionPoint.getConfigurationElements();
MultiStatus status= new MultiStatus(PLUGIN_ID, IStatus.OK, "Could not load some testRunner extension points", null); //$NON-NLS-1$
for (int i= 0; i < configs.length; i++) {
try {
ITestRunListener testRunListener= (ITestRunListener) configs[i].createExecutableExtension("class"); //$NON-NLS-1$
fTestRunListeners.add(testRunListener);
} catch (CoreException e) {
status.add(e.getStatus());
}
}
if (!status.isOK()) {
JUnitPlugin.log(status);
}
}
/**
* Loads the registered JUnit launch configurations
*/
private void loadLaunchConfigTypeIDs() {
fJUnitLaunchConfigTypeIDs= new ArrayList();
IExtensionPoint extensionPoint= Platform.getExtensionRegistry().getExtensionPoint(ID_EXTENSION_POINT_JUNIT_LAUNCHCONFIGS);
if (extensionPoint == null) {
return;
}
IConfigurationElement[] configs= extensionPoint.getConfigurationElements();
for (int i= 0; i < configs.length; i++) {
String configTypeID= configs[i].getAttribute("configTypeID"); //$NON-NLS-1$
fJUnitLaunchConfigTypeIDs.add(configTypeID);
}
}
/**
* @return an array of all TestRun listeners
*/
public ITestRunListener[] getTestRunListeners() {
if (fTestRunListeners == null) {
loadTestRunListeners();
}
return (ITestRunListener[]) fTestRunListeners.toArray(new ITestRunListener[fTestRunListeners.size()]);
}
/**
* @return a list of all JUnit launch configuration types
*/
public List/*<String>*/ getJUnitLaunchConfigTypeIDs() {
if (fJUnitLaunchConfigTypeIDs == null) {
loadLaunchConfigTypeIDs();
}
return fJUnitLaunchConfigTypeIDs;
}
/**
* Returns the bundle for a given bundle name,
* regardless whether the bundle is resolved or not.
*
* @param bundleName the bundle name
* @return the bundle
* @since 3.2
*/
public Bundle getBundle(String bundleName) {
Bundle bundle= Platform.getBundle(bundleName);
if (bundle != null)
return bundle;
// Accessing unresolved bundle
ServiceReference serviceRef= fBundleContext.getServiceReference(PackageAdmin.class.getName());
PackageAdmin admin= (PackageAdmin)fBundleContext.getService(serviceRef);
Bundle[] bundles= admin.getBundles(bundleName, null);
if (bundles != null && bundles.length > 0)
return bundles[0];
return null;
}
/**
* Adds a TestRun listener to the collection of listeners
* @param newListener the listener to add
*/
public void addTestRunListener(ITestRunListener newListener) {
if (fTestRunListeners == null)
loadTestRunListeners();
for (Iterator iter= fTestRunListeners.iterator(); iter.hasNext();) {
Object o= iter.next();
if (o == newListener)
return;
}
fTestRunListeners.add(newListener);
}
/**
* Removes a TestRun listener to the collection of listeners
* @param newListener the listener to remove
*/
public void removeTestRunListener(ITestRunListener newListener) {
if (fTestRunListeners != null)
fTestRunListeners.remove(newListener);
}
public static boolean isStopped() {
return fIsStopped;
}
public IDialogSettings getDialogSettingsSection(String name) {
IDialogSettings dialogSettings= getDialogSettings();
IDialogSettings section= dialogSettings.getSection(name);
if (section == null) {
section= dialogSettings.addNewSection(name);
}
return section;
}
}