source: trunk/autoquest-core-tasktrees-test/src/test/java/de/ugoe/cs/autoquest/tasktrees/taskequality/IterationComparisonRuleTest.java @ 1146

Last change on this file since 1146 was 1146, checked in by pharms, 11 years ago
  • complete refactoring of task tree model with a separation of task models and task instances
  • appropriate adaptation of task tree generation process
  • appropriate adaptation of commands and task tree visualization
File size: 5.1 KB
Line 
1//   Copyright 2012 Georg-August-Universität Göttingen, Germany
2//
3//   Licensed under the Apache License, Version 2.0 (the "License");
4//   you may not use this file except in compliance with the License.
5//   You may obtain a copy of the License at
6//
7//       http://www.apache.org/licenses/LICENSE-2.0
8//
9//   Unless required by applicable law or agreed to in writing, software
10//   distributed under the License is distributed on an "AS IS" BASIS,
11//   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12//   See the License for the specific language governing permissions and
13//   limitations under the License.
14
15package de.ugoe.cs.autoquest.tasktrees.taskequality;
16
17import static org.junit.Assert.*;
18
19import org.junit.Test;
20
21import de.ugoe.cs.autoquest.eventcore.IEventTarget;
22import de.ugoe.cs.autoquest.eventcore.IEventType;
23import de.ugoe.cs.autoquest.eventcore.StringEventType;
24import de.ugoe.cs.autoquest.tasktrees.taskequality.IterationComparisonRule;
25import de.ugoe.cs.autoquest.tasktrees.taskequality.TaskEquality;
26import de.ugoe.cs.autoquest.tasktrees.taskequality.TaskEqualityRuleManager;
27import de.ugoe.cs.autoquest.tasktrees.treeifc.IIteration;
28import de.ugoe.cs.autoquest.tasktrees.treeifc.ISelection;
29import de.ugoe.cs.autoquest.tasktrees.treeifc.ITaskBuilder;
30import de.ugoe.cs.autoquest.tasktrees.treeifc.ITask;
31import de.ugoe.cs.autoquest.tasktrees.treeifc.ITaskFactory;
32import de.ugoe.cs.autoquest.tasktrees.treeimpl.TaskBuilder;
33import de.ugoe.cs.autoquest.tasktrees.treeimpl.TaskFactory;
34import de.ugoe.cs.autoquest.test.DummyGUIElement;
35
36/**
37 * @author Patrick Harms
38 */
39public class IterationComparisonRuleTest {
40
41    /**
42     *
43     */
44    @Test
45    public void test() {
46        TaskEqualityRuleManager manager = new TaskEqualityRuleManager();
47        manager.init();
48       
49        ITaskFactory taskFactory = new TaskFactory();
50        ITaskBuilder treeBuilder = new TaskBuilder();
51       
52        IterationComparisonRule rule = new IterationComparisonRule(manager);
53       
54        IEventType eventType1 = new StringEventType("eventType1");
55        IEventTarget eventTarget1 = new DummyGUIElement("elem1");
56
57        IEventType eventType2 = new StringEventType("eventType2");
58        IEventTarget eventTarget2 = new DummyGUIElement("elem2");
59
60        ITask task1 = taskFactory.createNewEventTask(eventType1, eventTarget1);
61        ITask task2 = taskFactory.createNewEventTask(eventType2, eventTarget2);
62       
63        assertFalse(rule.isApplicable(task1, task2));
64       
65        IIteration iteration1 = taskFactory.createNewIteration();
66        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration1, iteration1));
67
68        IIteration iteration2 = taskFactory.createNewIteration();
69       
70        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration1, iteration2));
71        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration2, iteration1));
72       
73        treeBuilder.setMarkedTask(iteration1, task1);
74       
75        assertEquals(TaskEquality.UNEQUAL, rule.compare(iteration1, iteration2));
76        assertEquals(TaskEquality.UNEQUAL, rule.compare(iteration2, iteration1));
77       
78        treeBuilder.setMarkedTask(iteration2, task1);
79       
80        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration1, iteration2));
81        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration2, iteration1));
82       
83        treeBuilder.setMarkedTask(iteration1, task2);
84       
85        assertEquals(TaskEquality.UNEQUAL, rule.compare(iteration1, iteration2));
86        assertEquals(TaskEquality.UNEQUAL, rule.compare(iteration2, iteration1));
87       
88        treeBuilder.setMarkedTask(iteration2, task2);
89       
90        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration1, iteration2));
91        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration2, iteration1));
92       
93        ISelection selection1 = taskFactory.createNewSelection();
94        treeBuilder.addChild(selection1, task2);
95        treeBuilder.setMarkedTask(iteration1, selection1);
96       
97        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration1, iteration2));
98        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration2, iteration1));
99       
100        ISelection selection2 = taskFactory.createNewSelection();
101        treeBuilder.addChild(selection2, task2);
102        treeBuilder.setMarkedTask(iteration2, selection2);
103       
104        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration1, iteration2));
105        assertEquals(TaskEquality.LEXICALLY_EQUAL, rule.compare(iteration2, iteration1));
106       
107        assertFalse(rule.isApplicable(iteration1, selection1));
108        assertFalse(rule.isApplicable(selection1, iteration1));
109        assertFalse(rule.isApplicable(iteration2, selection1));
110        assertFalse(rule.isApplicable(selection1, iteration2));
111
112        assertFalse(rule.isApplicable(iteration1, selection2));
113        assertFalse(rule.isApplicable(selection2, iteration1));
114        assertFalse(rule.isApplicable(iteration2, selection2));
115        assertFalse(rule.isApplicable(selection2, iteration2));
116    }
117
118}
Note: See TracBrowser for help on using the repository browser.