view 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
line wrap: on
line source

package jungle.test.codesegment.practice;

import java.io.IOException;
import java.nio.ByteBuffer;

import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.DefaultJungle;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.Jungle;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTree;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTreeEditor;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.Command;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultNodePath;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultTreeEditor;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.TreeOperationLog;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.NodeOperation;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.TreeOperation;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultTraverser;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
import jungle.test.core.NetworkDefaultJungle;
import jungle.test.datasegment.store.operations.DefaultTreeOperationLogContainer;
import jungle.test.transaction.NetworkDefaultJungleTreeEditor;
import alice.codesegment.CodeSegment;
import alice.datasegment.CommandType;
import alice.datasegment.Receiver;

import org.msgpack.MessagePack;
import org.msgpack.type.Value;

public class TestCodeSegment extends CodeSegment {
	
	static Jungle jungle = new NetworkDefaultJungle(null,"hoge",new DefaultTreeEditor(new DefaultTraverser()));
	
	// create input datasegment arg1
	Receiver arg1 = ids.create(CommandType.PEEK);
	
	public TestCodeSegment() {
		jungle.createNewTree("tree");
	}
	
	@Override
	public void run() {
		System.out.println("type = " + arg1.type);
		System.out.println("index = " + arg1.index);
		System.out.println("data = " + arg1.getVal());
		System.out.println(((Value)arg1.getVal()).getType());
		
		MessagePack msgpack = new MessagePack();
		Value logContainerValue = (Value) arg1.getVal();
		TreeOperationLog convertedLog = null;
		try {
			DefaultTreeOperationLogContainer convertedLogContainer = msgpack.convert(logContainerValue, DefaultTreeOperationLogContainer.class);
			convertedLog = convertedLogContainer.convert();
		} catch (IOException e) {
			e.printStackTrace();
		}
		printLog(convertedLog);

		JungleTree tree = jungle.getTreeByName("tree");
		NetworkDefaultJungleTreeEditor editor = (NetworkDefaultJungleTreeEditor) tree.getTreeEditor();
		JungleTreeEditor tEditor = editor.setNewLogAndGetEditor(convertedLog);
		Either<Error,JungleTreeEditor> either = tEditor.success();
		if (either.isA()) {
			throw new IllegalStateException();
		}
		System.exit(0);
	}
	
	public void printLog(TreeOperationLog log) {
		for (TreeOperation treeOp : log) {
			NodePath path = treeOp.getNodePath();
			NodeOperation nodeOp = treeOp.getNodeOperation();
			Command c = nodeOp.getCommand();
			String str = "";
			switch (c) {
			case PUT_ATTRIBUTE:
				String k = nodeOp.getKey();
				ByteBuffer value = nodeOp.getValue();
				if (value.limit() < 100) {
					str = String.format("key:%s,value:%s", k,
							new String(value.array()));
				} else {
					str = String.format("key:%s,value:%d", k, value.limit());
				}
				break;
			case DELETE_ATTRIBUTE:
				str = String.format("key:%s", nodeOp.getKey());
				break;
			case APPEND_CHILD:
				str = String.format("pos:%d", nodeOp.getPosition());
				break;
			case DELETE_CHILD:
				str = String.format("pos:%d", nodeOp.getPosition());
				break;
			}
			System.out.println(String.format("[%s:%s]", c,  str));
			System.out.println("path:");
			for (int i: path ) {
				System.out.println(i);
			}
		}
	}

}