package org.eclipse.emf.diffmerge.tests.wt.elements.cases;
import org.eclipse.emf.diffmerge.tests.wt.elements.DiffMergeTestCase;
import org.eclipse.swt.custom.SashForm;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Group;
import org.eclipse.swt.widgets.ToolBar;
import org.eclipse.swt.widgets.ToolItem;
import org.eclipse.swt.widgets.Tree;
import com.windowtester.runtime.IUIContext;
import com.windowtester.runtime.swt.condition.shell.ShellDisposedCondition;
import com.windowtester.runtime.swt.condition.shell.ShellShowingCondition;
import com.windowtester.runtime.swt.locator.ButtonLocator;
import com.windowtester.runtime.swt.locator.SWTWidgetLocator;
import com.windowtester.runtime.swt.locator.TableItemLocator;
import com.windowtester.runtime.swt.locator.TreeItemLocator;
/**
* Element moved in an added element.
* Persistence check.
*/
public class MovedInAdded extends DiffMergeTestCase {
/**
* Main test method.
*/
public void testMovedInAdded() throws Exception {
IUIContext ui = getUI();
compareInFolder(true);
ui.click(new TreeItemLocator("Root (3)/Element A (2)/Element B (2)",
new SWTWidgetLocator(Tree.class, new SWTWidgetLocator(Composite.class,
0, new SWTWidgetLocator(SashForm.class)))));
ui.click(new TreeItemLocator("Root (3)/Element A (2)",
new SWTWidgetLocator(Tree.class, new SWTWidgetLocator(Composite.class,
0, new SWTWidgetLocator(SashForm.class)))));
ui.click(new SWTWidgetLocator(ToolItem.class, "", 0, new SWTWidgetLocator(
ToolBar.class, new SWTWidgetLocator(Composite.class,
new SWTWidgetLocator(Composite.class, 1, new SWTWidgetLocator(
SashForm.class))))));
ui.wait(new ShellShowingCondition("Merge Operation"));
ui.click(new ButtonLocator("Include differences in children"));
ui.click(new ButtonLocator("OK"));
ui.wait(new ShellDisposedCondition("Merge Operation"));
ui.wait(new ShellDisposedCondition("Progress Information"));
ui.wait(new ShellDisposedCondition("Progress Information"));
ui.wait(new ShellShowingCondition("Merge Operation"));
ui.click(new TreeItemLocator(
"Element A/Addition into Root (via 'content')", new SWTWidgetLocator(
Tree.class, new SWTWidgetLocator(Group.class, "Required changes"))));
ui.click(new TreeItemLocator(
"Element B/Move into Element A (via 'manyContent')",
new SWTWidgetLocator(Tree.class, new SWTWidgetLocator(Group.class,
"Required changes"))));
ui.click(new TreeItemLocator("Element B/Move out of Root (from 'content')",
new SWTWidgetLocator(Tree.class, new SWTWidgetLocator(Group.class,
"Implied changes"))));
ui.click(new ButtonLocator("OK"));
ui.wait(new ShellDisposedCondition("Merge Operation"));
ui.wait(new ShellDisposedCondition("Progress Information"));
ui.click(new TreeItemLocator("Root (1)/Element A (1)/Element B (1)",
new SWTWidgetLocator(Tree.class, new SWTWidgetLocator(Composite.class,
0, new SWTWidgetLocator(SashForm.class)))));
ui.click(new TableItemLocator("value"));
ui.click(new TableItemLocator("1"));
ui.click(new SWTWidgetLocator(ToolItem.class, "", 0, new SWTWidgetLocator(
ToolBar.class, new SWTWidgetLocator(Composite.class,
new SWTWidgetLocator(Composite.class, 1, new SWTWidgetLocator(
SashForm.class))))));
ui.wait(new ShellDisposedCondition("Progress Information"));
ui.wait(new ShellShowingCondition("Merge Operation"));
ui.click(new ButtonLocator("OK"));
ui.wait(new ShellDisposedCondition("Merge Operation"));
ui.wait(new ShellDisposedCondition("Progress Information"));
closeCompareEditor(true);
checkModelIsValid(true);
checkModelIsValid(false);
checkIdentical();
closeEditors();
}
}