/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.jackrabbit.core.observation; import org.apache.jackrabbit.core.query.AbstractQueryTest; import javax.jcr.RepositoryException; import javax.jcr.Node; import javax.jcr.NodeIterator; /** * <code>MoveInPlaceTest</code> is a test case for issue JCR-1728 */ public class MoveInPlaceTest extends AbstractQueryTest { public void testMove() throws RepositoryException { Node parent = testRootNode.addNode("parent"); Node child = parent.addNode("child"); testRootNode.save(); Node tmp = testRootNode.addNode("tmp"); superuser.move(child.getPath(), tmp.getPath() + "/" + child.getName()); parent.remove(); superuser.move(tmp.getPath(), testRootNode.getPath() + "/parent"); testRootNode.save(); String stmt = testPath + "/parent/child"; NodeIterator nodes = executeQuery(stmt).getNodes(); assertTrue("Result must not be empty", nodes.hasNext()); assertEquals("Wrong result", testRoot + "/parent/child", nodes.nextNode().getPath()); assertFalse("More results than expected", nodes.hasNext()); } }