annotate src/test/java/jp/ac/u_ryukyu/ie/cr/tatsuki/jungle/index/IndexCommitTest.java @ 153:20af7f25ef32

miner change
author one
date Tue, 25 Nov 2014 17:52:41 +0900
parents a2c374a2686b
children f98f2704b154 809f813d1083
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
134
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.index;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
2
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
3 import java.util.Iterator;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
4
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
5 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.DefaultJungle;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.Jungle;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTree;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTreeEditor;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultNodePath;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultTreeEditor;
145
72f454eb04ec add parentIndex
one
parents: 134
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.IndexTreeEditor;
134
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultTreeNode;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultTraverser;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.InterfaceTraverser;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
17 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
18 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Pair;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
19 import junit.framework.Assert;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
20 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
153
20af7f25ef32 miner change
one
parents: 148
diff changeset
21 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.Index;
134
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
22
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
23 import java.nio.ByteBuffer;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
24
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
25 import org.junit.Test;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
26
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
27 import fj.data.List;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
28 import fj.data.Option;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
29 import fj.data.TreeMap;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
30
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
31 public class IndexCommitTest {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
32
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
33 @Test
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
34 public void IndexCommitTest() throws InterruptedException {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
35
153
20af7f25ef32 miner change
one
parents: 148
diff changeset
36 Jungle jungle = new DefaultJungle(null, "hogehoge",new DefaultTreeEditor(new DefaultTraverser()));
134
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
37 jungle.createNewTree("tree");
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
38 JungleTree tree = jungle.getTreeByName("tree");
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
39 createTree(tree);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
40 tree.getRootNode();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
41 InterfaceTraverser ifTraverser = tree.getTraverser();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
42
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
43 ifTraverser.find((TreeNode node) -> {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
44 ByteBuffer attribute = node.getAttributes().get(key);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
45 if (attribute != null) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
46 byte[] byteAttribute = attribute.array();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
47 String str = new String(byteAttribute);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
48 System.out.println("attribute = " + str);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
49 return str.equals("<-1,0,1>");
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
50 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
51 return false;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
52 }, key, "<-1,0,1>");
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
53
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
54 //check index
153
20af7f25ef32 miner change
one
parents: 148
diff changeset
55 Index index = ifTraverser.getIndex();
20af7f25ef32 miner change
one
parents: 148
diff changeset
56 index.get(key,"<-1,0,1>");
20af7f25ef32 miner change
one
parents: 148
diff changeset
57 ifTraverser.commit();
144
0854f9a9e81d change attrs form TreeMap<String , ByteBuffer> → TreeMap<String,List<ByteBuffer>>
one
parents: 143
diff changeset
58
153
20af7f25ef32 miner change
one
parents: 148
diff changeset
59 JungleTree newTree = jungle.getTreeByName("tree");
20af7f25ef32 miner change
one
parents: 148
diff changeset
60 InterfaceTraverser newIfTraverser = newTree.getTraverser();
20af7f25ef32 miner change
one
parents: 148
diff changeset
61 Index newIndex = newIfTraverser.getIndex();
20af7f25ef32 miner change
one
parents: 148
diff changeset
62 newIndex.get(key,"<-1,0,1>");
134
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
63 JungleTreeEditor editor = tree.getTreeEditor();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
64 Either<Error, JungleTreeEditor> either = editor.addNewChildAt(new DefaultNodePath(), 0);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
65 editor = either.b();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
66 editor.success();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
67
153
20af7f25ef32 miner change
one
parents: 148
diff changeset
68 ifTraverser.commit();
20af7f25ef32 miner change
one
parents: 148
diff changeset
69 // Assert.assertTrue(newIndex.isEmpty());
20af7f25ef32 miner change
one
parents: 148
diff changeset
70 //
20af7f25ef32 miner change
one
parents: 148
diff changeset
71 // InterfaceTraverser ifTraverser1= tree.getTraverser();
20af7f25ef32 miner change
one
parents: 148
diff changeset
72 //
20af7f25ef32 miner change
one
parents: 148
diff changeset
73 // ifTraverser1.find((TreeNode node) -> {
20af7f25ef32 miner change
one
parents: 148
diff changeset
74 // ByteBuffer attribute = node.getAttributes().get(key);
20af7f25ef32 miner change
one
parents: 148
diff changeset
75 // if (attribute != null) {
20af7f25ef32 miner change
one
parents: 148
diff changeset
76 // byte[] byteAttribute = attribute.array();
20af7f25ef32 miner change
one
parents: 148
diff changeset
77 // String str = new String(byteAttribute);
20af7f25ef32 miner change
one
parents: 148
diff changeset
78 // System.out.println("attribute = " + str);
20af7f25ef32 miner change
one
parents: 148
diff changeset
79 // return str.equals("<-1,0,1>");
20af7f25ef32 miner change
one
parents: 148
diff changeset
80 // }
20af7f25ef32 miner change
one
parents: 148
diff changeset
81 // return false;
20af7f25ef32 miner change
one
parents: 148
diff changeset
82 // }, key, "<-1,0,1>");
20af7f25ef32 miner change
one
parents: 148
diff changeset
83 //
20af7f25ef32 miner change
one
parents: 148
diff changeset
84 // ifTraverser1.commit();
20af7f25ef32 miner change
one
parents: 148
diff changeset
85 // JungleTree newTree2 = jungle.getTreeByName("tree");
20af7f25ef32 miner change
one
parents: 148
diff changeset
86 // InterfaceTraverser newIfTraverser2 = newTree2.getTraverser();
20af7f25ef32 miner change
one
parents: 148
diff changeset
87 // TreeMap<String, TreeMap<String, List<Pair<TreeNode, NodePath>>>> newIndex1 = newIfTraverser2.getIndex();
20af7f25ef32 miner change
one
parents: 148
diff changeset
88 // Assert.assertFalse(newIndex1.isEmpty());
134
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
89
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
90 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
91
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
92 public boolean compare(TreeNode compareNode, String compareAttribute) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
93 String labName = compareNode.getAttributes().getString(key);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
94 if (labName.equals(compareAttribute))
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
95 return true;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
96 return false;
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
97 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
98
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
99 public static String key = "KEY";
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
100 public static DefaultTreeNode factory = new DefaultTreeNode();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
101
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
102 public void createTree(JungleTree tree) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
103 NodePath root = new DefaultNodePath();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
104 createChildren(tree, root, 0);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
105
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
106 for (int x = 0; x < 2; x++) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
107 createChildren(tree, root.add(0), x);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
108 for (int y = 0; y < 2; y++) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
109 createChildren(tree, root.add(0).add(x), y);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
110 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
111 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
112
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
113 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
114
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
115 public void createChildren(JungleTree tree, NodePath root, int num) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
116 JungleTreeEditor editor = tree.getTreeEditor();// Treeのeditorを作成
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
117 Either<Error, JungleTreeEditor> either = editor
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
118 .addNewChildAt(root, num); // 新しく入れるところへのパス
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
119 if (either.isA()) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
120 Assert.fail();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
121 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
122 editor = either.b();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
123 either = editor.success();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
124 if (either.isA()) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
125 Assert.fail();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
126 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
127 NodePath childPath = root.add(num);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
128 editor = tree.getTreeEditor();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
129 NodePath attribute = root.add(num);
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
130 System.out.println(attribute.toString());
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
131 either = editor.putAttribute(childPath, key,
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
132 ByteBuffer.wrap(attribute.toString().getBytes()));
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
133 if (either.isA()) {
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
134 Assert.fail();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
135 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
136 editor = either.b();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
137 either = editor.success();
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
138 }
f46a6e0e4594 add deleteIndexEditor
one
parents:
diff changeset
139 }