ui bot tests
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/.classpath b/core/tests/org.eclipse.dltk.ui.bot.tests/.classpath
new file mode 100644
index 0000000..2fbb7a2
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/.classpath
@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<classpath>
+	<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/J2SE-1.4"/>
+	<classpathentry kind="con" path="org.eclipse.pde.core.requiredPlugins"/>
+	<classpathentry kind="src" path="src"/>
+	<classpathentry kind="output" path="bin"/>
+</classpath>
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/.project b/core/tests/org.eclipse.dltk.ui.bot.tests/.project
new file mode 100644
index 0000000..2a0704f
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/.project
@@ -0,0 +1,28 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<projectDescription>
+	<name>org.eclipse.dltk.ui.bot.tests</name>
+	<comment></comment>
+	<projects>
+	</projects>
+	<buildSpec>
+		<buildCommand>
+			<name>org.eclipse.jdt.core.javabuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+		<buildCommand>
+			<name>org.eclipse.pde.ManifestBuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+		<buildCommand>
+			<name>org.eclipse.pde.SchemaBuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+	</buildSpec>
+	<natures>
+		<nature>org.eclipse.pde.PluginNature</nature>
+		<nature>org.eclipse.jdt.core.javanature</nature>
+	</natures>
+</projectDescription>
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/.settings/org.eclipse.jdt.core.prefs b/core/tests/org.eclipse.dltk.ui.bot.tests/.settings/org.eclipse.jdt.core.prefs
new file mode 100644
index 0000000..d9dcb5e
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/.settings/org.eclipse.jdt.core.prefs
@@ -0,0 +1,7 @@
+#Thu Jul 24 14:54:45 NOVST 2008
+eclipse.preferences.version=1
+org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.2
+org.eclipse.jdt.core.compiler.compliance=1.4
+org.eclipse.jdt.core.compiler.problem.assertIdentifier=warning
+org.eclipse.jdt.core.compiler.problem.enumIdentifier=warning
+org.eclipse.jdt.core.compiler.source=1.3
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/META-INF/MANIFEST.MF b/core/tests/org.eclipse.dltk.ui.bot.tests/META-INF/MANIFEST.MF
new file mode 100644
index 0000000..b73991c
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/META-INF/MANIFEST.MF
@@ -0,0 +1,31 @@
+Manifest-Version: 1.0
+Bundle-ManifestVersion: 2
+Bundle-Name: %pluginName
+Bundle-SymbolicName: org.eclipse.dltk.ui.bot.tests
+Bundle-Version: 1.0.0
+Bundle-Activator: org.eclipse.dltk.uibot.tests.Activator
+Export-Package: org.eclipse.dltk.uibot.tests
+Bundle-Localization: plugin
+Require-Bundle: net.sf.swtbot.eclipse.finder,
+ net.sf.swtbot.eclipse.spy,
+ net.sf.swtbot.eclipse.ui,
+ net.sf.swtbot.finder,
+ org.junit,
+ org.eclipse.core.resources,
+ org.eclipse.core.runtime,
+ org.eclipse.dltk.core.tests,
+ org.eclipse.ui,
+ org.eclipse.core.runtime
+Bundle-RequiredExecutionEnvironment: J2SE-1.4
+Import-Package: org.eclipse.core.resources,
+ org.eclipse.core.runtime,
+ org.eclipse.core.runtime.jobs,
+ org.eclipse.dltk.compiler.problem,
+ org.eclipse.dltk.core,
+ org.eclipse.dltk.core.search,
+ org.eclipse.dltk.internal.core,
+ org.eclipse.dltk.internal.core.util,
+ org.eclipse.dltk.internal.ui.editor,
+ org.eclipse.ui
+Eclipse-LazyStart: true
+Bundle-Vendor: %provider
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/build.properties b/core/tests/org.eclipse.dltk.ui.bot.tests/build.properties
new file mode 100644
index 0000000..aa1a008
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/build.properties
@@ -0,0 +1,5 @@
+source.. = src/
+output.. = bin/
+bin.includes = META-INF/,\
+               .,\
+               plugin.properties
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/plugin.properties b/core/tests/org.eclipse.dltk.ui.bot.tests/plugin.properties
new file mode 100644
index 0000000..f7c49e3
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/plugin.properties
@@ -0,0 +1,2 @@
+pluginProvider=Eclipse.org
+pluginName=Dynamic Languages Toolkit Core UI-Bot Tests (Incubation)
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/AbstractSWTBotTests.java b/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/AbstractSWTBotTests.java
new file mode 100644
index 0000000..18fe8f4
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/AbstractSWTBotTests.java
@@ -0,0 +1,52 @@
+package org.eclipse.dltk.uibot.tests;
+
+import net.sf.swtbot.eclipse.finder.SWTEclipseBot;
+import net.sf.swtbot.widgets.SWTBotShell;
+
+import org.eclipse.core.resources.IncrementalProjectBuilder;
+import org.eclipse.core.resources.ResourcesPlugin;
+import org.eclipse.core.runtime.CoreException;
+import org.eclipse.core.runtime.NullProgressMonitor;
+import org.eclipse.dltk.core.ISourceModule;
+import org.eclipse.dltk.core.tests.model.AbstractModelTests;
+import org.eclipse.dltk.internal.ui.editor.EditorUtility;
+import org.eclipse.ui.IEditorPart;
+import org.eclipse.ui.IWorkbenchWindow;
+import org.eclipse.ui.PlatformUI;
+
+public abstract class AbstractSWTBotTests extends AbstractModelTests {
+
+	protected final SWTEclipseBot bot = new SWTEclipseBot();
+
+	protected AbstractSWTBotTests(String testProjectName, String name) {
+		super(testProjectName, name);
+	}
+
+	protected void waitForProjectToBuild() throws CoreException {
+		waitUntilIndexesReady();
+		ResourcesPlugin.getWorkspace()
+				.build(IncrementalProjectBuilder.FULL_BUILD,
+						new NullProgressMonitor());
+		waitForAutoBuild();
+	}
+
+	protected void closeEditorPart(IEditorPart part) {
+		part.getSite().getWorkbenchWindow().getActivePage().closeEditor(part,
+				false);
+	}
+
+	protected IEditorPart openSourceFileInEditor(String project,
+			String sourceFolder, String fileName, String perspectiveId)
+			throws Exception {
+		ISourceModule cu = getSourceModule(project, sourceFolder, fileName);
+
+		IWorkbenchWindow[] ww = PlatformUI.getWorkbench().getWorkbenchWindows();
+		PlatformUI.getWorkbench().showPerspective(perspectiveId, ww[0]);
+
+		SWTBotShell[] sh = bot.shells();
+		sh[0].activate();
+
+		return EditorUtility.openInEditor(cu);
+	}
+
+}
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/Activator.java b/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/Activator.java
new file mode 100644
index 0000000..379d037
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/Activator.java
@@ -0,0 +1,50 @@
+package org.eclipse.dltk.uibot.tests;
+
+import org.eclipse.ui.plugin.AbstractUIPlugin;
+import org.osgi.framework.BundleContext;
+
+/**
+ * The activator class controls the plug-in life cycle
+ */
+public class Activator extends AbstractUIPlugin {
+
+	// The plug-in ID
+	public static final String PLUGIN_ID = "org.eclipse.dltk.ui.tests.swtbot"; //$NON-NLS-1$
+
+	// The shared instance
+	private static Activator plugin;
+	
+	/**
+	 * The constructor
+	 */
+	public Activator() {
+	}
+
+	/*
+	 * (non-Javadoc)
+	 * @see org.eclipse.ui.plugin.AbstractUIPlugin#start(org.osgi.framework.BundleContext)
+	 */
+	public void start(BundleContext context) throws Exception {
+		super.start(context);
+		plugin = this;
+	}
+
+	/*
+	 * (non-Javadoc)
+	 * @see org.eclipse.ui.plugin.AbstractUIPlugin#stop(org.osgi.framework.BundleContext)
+	 */
+	public void stop(BundleContext context) throws Exception {
+		plugin = null;
+		super.stop(context);
+	}
+
+	/**
+	 * Returns the shared instance
+	 *
+	 * @return the shared instance
+	 */
+	public static Activator getDefault() {
+		return plugin;
+	}
+
+}
diff --git a/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/SWTBotAsyncAction.java b/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/SWTBotAsyncAction.java
new file mode 100644
index 0000000..52173ee
--- /dev/null
+++ b/core/tests/org.eclipse.dltk.ui.bot.tests/src/org/eclipse/dltk/uibot/tests/SWTBotAsyncAction.java
@@ -0,0 +1,73 @@
+package org.eclipse.dltk.uibot.tests;
+
+import net.sf.swtbot.SWTBot;
+import net.sf.swtbot.widgets.TimeoutException;
+
+public abstract class SWTBotAsyncAction {
+	private final long fTimeout;
+	protected final SWTBot bot;
+
+	public SWTBotAsyncAction(SWTBot bot, long timeout) {
+		this.bot = bot;
+		fTimeout = timeout;
+	}
+
+	public SWTBotAsyncAction(SWTBot bot) {
+		this(bot, 10000);
+	}
+
+	protected abstract void onComplete() throws Exception;
+
+	protected abstract void action() throws Exception;
+
+	protected abstract boolean startCondition() throws Exception;
+
+	protected abstract void blockingAction() throws Exception;
+
+	protected void failTimeoutElapsed() throws Exception {
+		throw new TimeoutException(
+				"Condition not achieved within reasonable timeout"); //$NON-NLS-1$
+	}
+
+	private Throwable exception;
+
+	public void execute() throws Exception {
+		Thread tester = new Thread() {
+			public void run() {
+				try {
+					long timeStamp = System.currentTimeMillis();
+					// first, we wait for start condition to become true
+					while (!startCondition()) {
+						if (System.currentTimeMillis() - timeStamp > fTimeout) {
+							failTimeoutElapsed();
+							return;
+						}
+						Thread.sleep(100);
+					}
+					try {
+						action();
+					} finally {
+						try {
+							onComplete();
+						} catch (Exception e) {
+							e.printStackTrace();
+						}
+					}
+				} catch (Throwable e) {
+					exception = e;
+				}
+			}
+		};
+		tester.start();
+		blockingAction();
+
+		if (exception != null) {
+			if (exception instanceof Error) {
+				throw (Error) exception;
+			} else {
+				throw (Exception) exception;
+			}
+		}
+
+	}
+}