changeset 71:f1aef52c0611

Added NetworkAppendChildAtTest
author one
date Fri, 11 Oct 2013 18:24:46 +0900
parents 892bac9ac118
children 2520a5bd3dac
files src/alice/jungle/datasegment/store/transformer/NetworkAppendChildAt.java src/alice/jungle/operations/NetworkAppendChildAtOperation.java src/test/alice/jungle/core/operations/NetworkAppendChildOperationTest.java
diffstat 3 files changed, 115 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/alice/jungle/datasegment/store/transformer/NetworkAppendChildAt.java	Fri Oct 11 18:24:46 2013 +0900
@@ -0,0 +1,35 @@
+package alice.jungle.datasegment.store.transformer;
+
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableNode;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.NodeEditor;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
+
+import org.msgpack.annotation.Message;
+
+
+/*
+ * This code same AppendChildAt. 
+ */
+
+@Message
+public class NetworkAppendChildAt implements NodeEditor {
+
+	private final int pos;
+	
+	public NetworkAppendChildAt(int _pos) {
+		pos = _pos;
+	}
+
+	@Override
+	public <T extends EditableNode<T>> Either<Error, T> edit(T _e) {
+		Either<Error,T> either = _e.getChildren().addNewChildAt(pos);
+		if(either.isA()){
+			// error
+			return either;
+		}
+		return DefaultEither.newB(either.b());
+	}
+
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/alice/jungle/operations/NetworkAppendChildAtOperation.java	Fri Oct 11 18:24:46 2013 +0900
@@ -0,0 +1,55 @@
+package alice.jungle.operations;
+
+import java.nio.ByteBuffer;
+
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.Command;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.NodeOperation;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableNode;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
+
+import org.msgpack.annotation.Message;
+
+import alice.jungle.datasegment.store.transformer.NetworkAppendChildAt;
+
+
+@Message
+public class NetworkAppendChildAtOperation implements NodeOperation {
+	
+	//	private final int pos;
+	/* MessagePack can not handle final.*/
+	private int pos;
+	
+	/* Position -1 represent root position. */
+	public NetworkAppendChildAtOperation() { pos = -2; }
+	
+	public NetworkAppendChildAtOperation(int _pos) {
+		pos = _pos;
+	}
+	
+	@Override
+	public Command getCommand() {
+		return Command.APPEND_CHILD;
+	}
+	
+	@Override
+	public <T extends EditableNode<T>> Either<Error, T> invoke(T _target) {
+		NetworkAppendChildAt appendChildAt = new NetworkAppendChildAt(pos);
+		return appendChildAt.edit(_target);
+	}
+
+	@Override
+	public int getPosition() {
+		return pos;
+	}
+
+	@Override
+	public String getKey() {
+		return null;
+	}
+
+	@Override
+	public ByteBuffer getValue() {
+		return null;
+	}
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/test/alice/jungle/core/operations/NetworkAppendChildOperationTest.java	Fri Oct 11 18:24:46 2013 +0900
@@ -0,0 +1,25 @@
+package test.alice.jungle.core.operations;
+
+import java.io.IOException;
+
+import org.msgpack.MessagePack;
+import org.msgpack.type.Value;
+
+import alice.jungle.operations.NetworkAppendChildAtOperation;
+import junit.framework.TestCase;
+
+public class NetworkAppendChildOperationTest extends TestCase {
+
+	public void testMsgpackConvert() throws IOException {
+		NetworkAppendChildAtOperation op = new NetworkAppendChildAtOperation(1);
+		MessagePack msgpack = new MessagePack();
+		Value v = msgpack.unconvert(op);
+		NetworkAppendChildAtOperation mOp = msgpack.convert(v, NetworkAppendChildAtOperation.class);
+		assertEquals(op.getCommand(), mOp.getCommand());
+		assertEquals(op.getPosition(), 1);
+		assertEquals(op.getPosition(), mOp.getPosition());
+
+	}
+	
+	
+}