]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.modeling.tests/src/org/simantics/modeling/tests/commands/WaitActiveExperiment.java
Added missing org.simantics.modeling.tests plug-ins.
[simantics/platform.git] / bundles / org.simantics.modeling.tests / src / org / simantics / modeling / tests / commands / WaitActiveExperiment.java
diff --git a/bundles/org.simantics.modeling.tests/src/org/simantics/modeling/tests/commands/WaitActiveExperiment.java b/bundles/org.simantics.modeling.tests/src/org/simantics/modeling/tests/commands/WaitActiveExperiment.java
new file mode 100644 (file)
index 0000000..efb2faf
--- /dev/null
@@ -0,0 +1,50 @@
+package org.simantics.modeling.tests.commands;
+
+import org.simantics.Simantics;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.testing.base.CommandSequenceTest;
+import org.simantics.db.testing.common.WriteCommand;
+import org.simantics.project.IProject;
+import org.simantics.simulation.experiment.IExperiment;
+import org.simantics.simulation.project.IExperimentManager;
+import org.simantics.simulation.project.IExperimentManagerListener;
+
+public class WaitActiveExperiment extends WriteCommand<CommandSequenceTest> implements IExperimentManagerListener {
+
+       boolean done = false;
+       
+       @Override
+       public void run(CommandSequenceTest environment) throws DatabaseException {
+               try {
+                       IProject project = Simantics.getProject(); 
+            final IExperimentManager experimentManager = project.getHint(IExperimentManager.KEY_EXPERIMENT_MANAGER);
+            if (experimentManager != null) {
+               IExperiment experiment = experimentManager.getActiveExperiment();
+               if(experiment == null) {
+                       experimentManager.addListener(this);
+                       while(!done) {
+                               Thread.sleep(50);
+                       }
+                       // Cannot because of bean comparison
+                       //experimentManager.removeListener(this);
+               }
+            }
+               } catch (Exception e) {
+                       throw new DatabaseException(e);
+               }
+       }
+
+       @Override
+       public void activeExperimentLoaded(IExperiment experiment) {
+               done = true;
+       }
+
+       @Override
+       public void activeExperimentUnloaded() {
+       }
+
+       @Override
+       public void managerDisposed() {
+       }
+
+}
\ No newline at end of file