view src/test/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/core/nodeeditor/ReplaceRootNodeAt.java @ 176:550f51183d8a

Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
author one
date Fri, 06 Mar 2015 10:59:34 +0900
parents
children 75422f82e6b6
line wrap: on
line source

package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.nodeeditor;

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.store.impl.DefaultTreeEditor;
import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
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 junit.framework.Assert;

import org.junit.Test;

public class ReplaceRootNodeAt {

  @Test
  public void ReplaceRootNodeAtTest() {
      System.out.println("start");
    Jungle jungle = new DefaultJungle(null, "hogehoge", new DefaultTreeEditor(new DefaultTraverser()));
    jungle.createNewTree("tree");
    JungleTree tree = jungle.getTreeByName("tree");
    JungleTreeEditor editor = tree.getTreeEditor();
    
    TreeNode oldRoot = tree.getRootNode();
    Either<Error, JungleTreeEditor> either = editor.replaceNewRootNode();
    Assert.assertTrue(either.isB());
    JungleTreeEditor newTreeEditor = either.b();
    Assert.assertTrue(newTreeEditor.success().isB());
    TreeNode newRoot = tree.getRootNode();
    Assert.assertFalse(oldRoot.equals(newRoot));
    
    Either<Error, TreeNode> childrenEither = newRoot.getChildren().at(0);
    Assert.assertTrue(childrenEither.isB());
    TreeNode newRootChildren = childrenEither.b();
    Assert.assertEquals(oldRoot, newRootChildren);
  }
}