/*******************************************************************************
* Copyright (c) 2007, 2010 Wind River Systems 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:
* Wind River Systems - initial API and implementation
*******************************************************************************/
package org.eclipse.cdt.tests.dsf.gdb.launching;
import java.util.MissingResourceException;
import java.util.ResourceBundle;
import org.eclipse.cdt.dsf.gdb.internal.GdbPlugin;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Platform;
import org.eclipse.core.runtime.Status;
import org.osgi.framework.BundleContext;
/**
* This is no longer an activator class since this is no longer a plug-in. It's
* a fragment.
*/
public class TestsPlugin {
private ResourceBundle resourceBundle;
/**
* We're no longer a plug-in, but a fragment. Make this field an alias
* to our host plugin's ID.
*/
public static final String PLUGIN_ID = GdbPlugin.PLUGIN_ID;
/** Base tracing option for this plugin */
public static final boolean DEBUG = "true".equals(Platform.getDebugOption("org.eclipse.cdt.tests.dsf.gdb/debug")); //$NON-NLS-1$//$NON-NLS-2$
/**
* The constructor.
*/
public TestsPlugin() {
super();
try {
resourceBundle = ResourceBundle.getBundle("org.eclipse.cdt.tests.dsf.gdb.TestsPluginResources"); //$NON-NLS-1$
}
catch (MissingResourceException x) {
resourceBundle = null;
}
}
/**
* Returns this fragment's resource bundle,
*/
public ResourceBundle getResourceBundle() {
return resourceBundle;
}
/**
* Returns the host plug-in's bundle context,
*/
public static BundleContext getBundleContext() {
return GdbPlugin.getBundleContext();
}
/**
* Logs the specified status with this host plug-in's log.
*
* @param status
* status to log
*/
public static void log(IStatus status) {
GdbPlugin.getDefault().getLog().log(status);
}
/**
* Logs an internal error with the specified throwable
*
* @param e
* the exception to be logged
*/
public static void log( Throwable e ) {
log(new Status(IStatus.ERROR, GdbPlugin.PLUGIN_ID, "Internal Error", e)); //$NON-NLS-1$
}
/**
* Tests should use this utility when specifying a timeout value for a wait
* operation. This method checks for the existence of the property
* "dsf.gdb.tests.timeout.multiplier" and applies it to the specified value.
* The property should be specified as a float, e.g., "1.5". Such a value
* would up the timeout value by 50%. This gives the executor of the tests
* the ability to widen the timeouts across the board for all operations to
* accommodate a slow machine.
*
* @param timeoutMs
* the timeout, in milliseconds
* @return the adjusted value
*/
public static int massageTimeout(int timeoutMs) {
String prop = System.getProperty("dsf.gdb.tests.timeout.multiplier");
if (prop == null || prop.length() == 0) {
return timeoutMs;
}
try {
float multiplier = Float.valueOf(prop);
return (int)(timeoutMs * multiplier);
}
catch (NumberFormatException exc) {
log(new Status(IStatus.ERROR, GdbPlugin.PLUGIN_ID, "\"dsf.gdb.tests.timeout.multiplier\" property incorrectly specified. Should be a float value (e.g., \"1.5\") or not specified at all.")); //$NON-NLS-1$
return timeoutMs;
}
}
}