annotate src/jungle/test/codesegment/practice/TestCodeSegment.java @ 11:c9ff68c4d82f

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