annotate src/jungle/test/codesegment/log/practice/TestCodeSegment.java @ 45:bf3dc481cc9b

modified JungleManager to singleton
author one
date Fri, 12 Jul 2013 09:47:22 +0900
parents 190f6a3bdab2
children 87ec5dd0dc27
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
14
6dc6b25021a3 move some files
one
parents: 13
diff changeset
1 package jungle.test.codesegment.log.practice;
2
20498c88a70d add Container
one
parents:
diff changeset
2
9
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
3 import java.io.IOException;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
4 import java.nio.ByteBuffer;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
5
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.DefaultJungle;
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.Jungle;
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTree;
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTreeEditor;
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
9
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.Command;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
10
5376ac62ac08 modified TestCodeSegment
one
parents: 9
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultNodePath;
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultTreeEditor;
13
f3c0a65c3f12 TestCodeSegment use asClass
one
parents: 11
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.DefaultTreeOperationLog;
9
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.TreeOperationLog;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
17 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.NodeOperation;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
18 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.TreeOperation;
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
19 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultTraverser;
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
20 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
21 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
2
20498c88a70d add Container
one
parents:
diff changeset
22 import alice.codesegment.CodeSegment;
20498c88a70d add Container
one
parents:
diff changeset
23 import alice.datasegment.CommandType;
20498c88a70d add Container
one
parents:
diff changeset
24 import alice.datasegment.Receiver;
31
190f6a3bdab2 rename some packages
one
parents: 16
diff changeset
25 import alice.jungle.core.NetworkDefaultJungle;
190f6a3bdab2 rename some packages
one
parents: 16
diff changeset
26 import alice.jungle.datasegment.store.operations.DefaultTreeOperationLogContainer;
190f6a3bdab2 rename some packages
one
parents: 16
diff changeset
27 import alice.jungle.transaction.NetworkDefaultJungleTreeEditor;
13
f3c0a65c3f12 TestCodeSegment use asClass
one
parents: 11
diff changeset
28 import alice.test.topology.aquarium.FishPoint;
9
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
29
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
30 import org.msgpack.MessagePack;
2
20498c88a70d add Container
one
parents:
diff changeset
31 import org.msgpack.type.Value;
20498c88a70d add Container
one
parents:
diff changeset
32
20498c88a70d add Container
one
parents:
diff changeset
33 public class TestCodeSegment extends CodeSegment {
20498c88a70d add Container
one
parents:
diff changeset
34
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 31
diff changeset
35 static Jungle jungle = new NetworkDefaultJungle(null,"hoge",new DefaultTreeEditor(new DefaultTraverser()), "serverName");
16
d2436fd71c61 modifidy TestCodeSegment
one
parents: 15
diff changeset
36
2
20498c88a70d add Container
one
parents:
diff changeset
37 // create input datasegment arg1
20498c88a70d add Container
one
parents:
diff changeset
38 Receiver arg1 = ids.create(CommandType.PEEK);
20498c88a70d add Container
one
parents:
diff changeset
39
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
40 public TestCodeSegment() {
13
f3c0a65c3f12 TestCodeSegment use asClass
one
parents: 11
diff changeset
41 arg1.setKey("log");
16
d2436fd71c61 modifidy TestCodeSegment
one
parents: 15
diff changeset
42 jungle.createNewTree("tree");
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
43 }
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
44
2
20498c88a70d add Container
one
parents:
diff changeset
45 @Override
20498c88a70d add Container
one
parents:
diff changeset
46 public void run() {
20498c88a70d add Container
one
parents:
diff changeset
47 System.out.println("type = " + arg1.type);
20498c88a70d add Container
one
parents:
diff changeset
48 System.out.println("index = " + arg1.index);
20498c88a70d add Container
one
parents:
diff changeset
49 System.out.println("data = " + arg1.getVal());
14
6dc6b25021a3 move some files
one
parents: 13
diff changeset
50 System.out.println(((Value)arg1.getVal()).getType());
2
20498c88a70d add Container
one
parents:
diff changeset
51
13
f3c0a65c3f12 TestCodeSegment use asClass
one
parents: 11
diff changeset
52 DefaultTreeOperationLogContainer convertedLogContainer = arg1.asClass(DefaultTreeOperationLogContainer.class);
9
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
53 TreeOperationLog convertedLog = null;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
54 try {
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
55 convertedLog = convertedLogContainer.convert();
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
56 } catch (IOException e) {
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
57 e.printStackTrace();
2
20498c88a70d add Container
one
parents:
diff changeset
58 }
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
59 printLog(convertedLog);
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
60
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
61 JungleTree tree = jungle.getTreeByName("tree");
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
62 NetworkDefaultJungleTreeEditor editor = (NetworkDefaultJungleTreeEditor) tree.getTreeEditor();
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 31
diff changeset
63 /*
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
64 JungleTreeEditor tEditor = editor.setNewLogAndGetEditor(convertedLog);
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 31
diff changeset
65
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
66 Either<Error,JungleTreeEditor> either = tEditor.success();
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
67 if (either.isA()) {
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
68 throw new IllegalStateException();
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
69 }
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 31
diff changeset
70 */
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
71 System.exit(0);
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
72 }
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
73
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
74 public void printLog(TreeOperationLog log) {
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
75 for (TreeOperation treeOp : log) {
9
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
76 NodePath path = treeOp.getNodePath();
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
77 NodeOperation nodeOp = treeOp.getNodeOperation();
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
78 Command c = nodeOp.getCommand();
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
79 String str = "";
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
80 switch (c) {
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
81 case PUT_ATTRIBUTE:
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
82 String k = nodeOp.getKey();
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
83 ByteBuffer value = nodeOp.getValue();
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
84 if (value.limit() < 100) {
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
85 str = String.format("key:%s,value:%s", k,
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
86 new String(value.array()));
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
87 } else {
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
88 str = String.format("key:%s,value:%d", k, value.limit());
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
89 }
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
90 break;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
91 case DELETE_ATTRIBUTE:
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
92 str = String.format("key:%s", nodeOp.getKey());
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
93 break;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
94 case APPEND_CHILD:
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
95 str = String.format("pos:%d", nodeOp.getPosition());
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
96 break;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
97 case DELETE_CHILD:
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
98 str = String.format("pos:%d", nodeOp.getPosition());
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
99 break;
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
100 }
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
101 System.out.println(String.format("[%s:%s]", c, str));
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
102 System.out.println("path:");
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
103 for (int i: path ) {
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
104 System.out.println(i);
49c0eaa4dce2 add StartCodeSegment.java
one
parents: 2
diff changeset
105 }
11
c9ff68c4d82f modified TestCodeSegment
one
parents: 10
diff changeset
106 }
2
20498c88a70d add Container
one
parents:
diff changeset
107 }
20498c88a70d add Container
one
parents:
diff changeset
108
20498c88a70d add Container
one
parents:
diff changeset
109 }