annotate src/test/java/jp/ac/u_ryukyu/ie/cr/tatsuki/jungle/index/ParentIndexTest.java @ 157:f98f2704b154 untilIndex

minnerChange
author one
date Sun, 07 Dec 2014 18:43:32 +0900
parents d9fbddf77bf6
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.index;
72f454eb04ec add parentIndex
one
parents:
diff changeset
2
146
371b6ddb78f2 repair putAttributeIndex and deleteAttributeIndex
one
parents: 145
diff changeset
3 import java.nio.ByteBuffer;
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
4 import java.util.Iterator;
72f454eb04ec add parentIndex
one
parents:
diff changeset
5
72f454eb04ec add parentIndex
one
parents:
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.DefaultJungle;
72f454eb04ec add parentIndex
one
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.Jungle;
72f454eb04ec add parentIndex
one
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTree;
72f454eb04ec add parentIndex
one
parents:
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTreeEditor;
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditor;
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultNodePath;
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultTreeEditor;
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
72f454eb04ec add parentIndex
one
parents:
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultTraverser;
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.ParentIndex;
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
16 import junit.framework.Assert;
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
17
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
18 import org.junit.Test;
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
19
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
20 import fj.data.Option;
72f454eb04ec add parentIndex
one
parents:
diff changeset
21
72f454eb04ec add parentIndex
one
parents:
diff changeset
22 public class ParentIndexTest {
72f454eb04ec add parentIndex
one
parents:
diff changeset
23
72f454eb04ec add parentIndex
one
parents:
diff changeset
24 @Test
72f454eb04ec add parentIndex
one
parents:
diff changeset
25 public void testParentIndex() {
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
26 Jungle jungle = new DefaultJungle(null, "hogehoge", new DefaultTreeEditor (new DefaultTraverser()));
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
27 jungle.createNewTree("tree");
72f454eb04ec add parentIndex
one
parents:
diff changeset
28 JungleTree tree = jungle.getTreeByName("tree");
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
29 JungleTreeEditor editor = tree.getTreeEditor();
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
30 DefaultNodePath path = new DefaultNodePath();
72f454eb04ec add parentIndex
one
parents:
diff changeset
31 editor = editor.addNewChildAt(path, 0).b();
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
32
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
33 for (int num = 0; num < 5; num++) {
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
34 editor = editor.addNewChildAt(path.add(0), num).b();
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
35 editor = editor.putAttribute(path.add(0).add(num), "test", ByteBuffer.wrap("test".getBytes())).b();
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
36 editor = editor.success().b();
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
37 }
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
38
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
39 ParentIndex parentIndex = tree.getParentIndex();
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
40 TreeNode node = tree.getRootNode();
72f454eb04ec add parentIndex
one
parents:
diff changeset
41 for (int num = 0; node.getChildren().size() != 0; num++) {
72f454eb04ec add parentIndex
one
parents:
diff changeset
42 Iterator<TreeNode> children = node.getChildren().iterator();
72f454eb04ec add parentIndex
one
parents:
diff changeset
43 for (; children.hasNext();) {
72f454eb04ec add parentIndex
one
parents:
diff changeset
44 TreeNode child = children.next();
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
45 TreeNode parent = parentIndex.get(child);
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
46 Assert.assertEquals(parent, node);
72f454eb04ec add parentIndex
one
parents:
diff changeset
47 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
48 node = node.getChildren().at(num).b();
72f454eb04ec add parentIndex
one
parents:
diff changeset
49 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
50
72f454eb04ec add parentIndex
one
parents:
diff changeset
51 JungleTree oldTree = tree.getOldTree(tree.revision() - 1).b();
72f454eb04ec add parentIndex
one
parents:
diff changeset
52 TreeNode oldRoot = oldTree.getRootNode();
72f454eb04ec add parentIndex
one
parents:
diff changeset
53 TreeNode oldNode = oldRoot.getChildren().at(0).b();
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
54 TreeNode oldParent = parentIndex.get(oldNode);
f98f2704b154 minnerChange
one
parents: 151
diff changeset
55 Assert.assertTrue(oldParent == null);
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
56 ParentIndex oldTreeParentIndex = oldTree.getParentIndex();
157
f98f2704b154 minnerChange
one
parents: 151
diff changeset
57 oldParent = oldTreeParentIndex.get(oldNode);
f98f2704b154 minnerChange
one
parents: 151
diff changeset
58 Assert.assertTrue(oldParent != null);
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
59
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
60 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
61 }