/* * Copyright (C) 2009 eXo Platform SAS. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.exoplatform.services.jcr.usecases.nodetypes; import org.exoplatform.services.jcr.impl.core.SessionImpl; import org.exoplatform.services.jcr.usecases.BaseUsecasesTest; import java.util.ArrayList; import java.util.Calendar; import java.util.Iterator; import java.util.List; import javax.jcr.Node; import javax.jcr.NodeIterator; import javax.jcr.query.Query; import javax.jcr.query.QueryManager; import javax.jcr.query.QueryResult; /** * Created by The eXo Platform SASL . * * @author <a href="volodymyr.krasnikov@exoplatform.com.ua">Volodymyr Krasnikov</a> * @version $Id: TestSearchNodetype.java 17:40:24 */ public class TestSearchNodetype extends BaseUsecasesTest { public void testCreateNodetype() throws Exception { List<String> nodePath = new ArrayList<String>(); Node queryNode = root.addNode("aFilePlan", "nt:unstructured"); Node node1 = queryNode.addNode("Test1", "nt:file"); Node content1 = node1.addNode("jcr:content", "nt:resource"); content1.setProperty("jcr:lastModified", Calendar.getInstance()); content1.setProperty("jcr:mimeType", "text/xml"); content1.setProperty("jcr:data", getClass().getResourceAsStream("nodetypes-usecase-test.xml")); node1.addMixin("rma:record"); node1.setProperty("rma:recordIdentifier", "testIdentificator"); node1.setProperty("rma:originatingOrganization", "testProperty2"); nodePath.add(node1.getPath()); Node node2 = queryNode.addNode("Test2", "nt:file"); Node content2 = node2.addNode("jcr:content", "nt:resource"); content2.setProperty("jcr:lastModified", Calendar.getInstance()); content2.setProperty("jcr:mimeType", "text/xml"); content2.setProperty("jcr:data", getClass().getResourceAsStream("nodetypes-usecase-test.xml")); node2.addMixin("rma:record"); node2.setProperty("rma:recordIdentifier", "testIdentificator"); node2.setProperty("rma:originatingOrganization", "testProperty2"); nodePath.add(node2.getPath()); session.save(); String sqlQuery = "SELECT * FROM rma:record WHERE jcr:path LIKE '/aFilePlan/%' "; QueryManager manager = session.getWorkspace().getQueryManager(); Query query = manager.createQuery(sqlQuery, Query.SQL); QueryResult queryResult = query.execute(); NodeIterator iter = queryResult.getNodes(); assertTrue(iter.getSize() == nodePath.size()); // check target nodes for existence Iterator<String> i_path = nodePath.iterator(); while (iter.hasNext() && i_path.hasNext()) { assertEquals(iter.nextNode().getPath(), i_path.next()); } } public void testCreateNodetypeWithLogout() throws Exception { List<String> nodePath = new ArrayList<String>(); Node queryNode = root.addNode("aFilePlan", "nt:unstructured"); Node node1 = queryNode.addNode("Test1", "nt:file"); Node content1 = node1.addNode("jcr:content", "nt:resource"); content1.setProperty("jcr:lastModified", Calendar.getInstance()); content1.setProperty("jcr:mimeType", "text/xml"); content1.setProperty("jcr:data", getClass().getResourceAsStream("nodetypes-usecase-test.xml")); node1.addMixin("rma:record"); node1.setProperty("rma:recordIdentifier", "testIdentificator"); node1.setProperty("rma:originatingOrganization", "testProperty2"); nodePath.add(node1.getPath()); Node node2 = queryNode.addNode("Test2", "nt:file"); Node content2 = node2.addNode("jcr:content", "nt:resource"); content2.setProperty("jcr:lastModified", Calendar.getInstance()); content2.setProperty("jcr:mimeType", "text/xml"); content2.setProperty("jcr:data", getClass().getResourceAsStream("nodetypes-usecase-test.xml")); node2.addMixin("rma:record"); node2.setProperty("rma:recordIdentifier", "testIdentificator"); node2.setProperty("rma:originatingOrganization", "testProperty2"); nodePath.add(node2.getPath()); session.save(); String sqlQuery = "SELECT * FROM rma:record WHERE jcr:path LIKE '/aFilePlan/%' "; QueryManager manager = session.getWorkspace().getQueryManager(); Query query = manager.createQuery(sqlQuery, Query.SQL); QueryResult queryResult = query.execute(); NodeIterator iter = queryResult.getNodes(); assertTrue(iter.getSize() == nodePath.size()); // check target nodes for existence Iterator<String> i_path = nodePath.iterator(); while (iter.hasNext() && i_path.hasNext()) { assertEquals(iter.nextNode().getPath(), i_path.next()); } session.logout(); // new login session = (SessionImpl)repository.login(credentials, "ws"); manager = session.getWorkspace().getQueryManager(); Query query2 = manager.createQuery(sqlQuery, Query.SQL); QueryResult queryResult2 = query2.execute(); NodeIterator iter2 = queryResult2.getNodes(); assertTrue(iter2.getSize() == nodePath.size()); // check target nodes for existence i_path = nodePath.iterator(); while (iter.hasNext() && i_path.hasNext()) { assertEquals(iter.nextNode().getPath(), i_path.next()); } } public void testCreateNodetypeWithPreQueryManader() throws Exception { List<String> nodePath = new ArrayList<String>(); String sqlQuery = "SELECT * FROM rma:record WHERE jcr:path LIKE '/aFilePlan/%' "; QueryManager manager = session.getWorkspace().getQueryManager(); Query query = manager.createQuery(sqlQuery, Query.SQL); Node queryNode = root.addNode("aFilePlan", "nt:unstructured"); Node node1 = queryNode.addNode("Test1", "nt:file"); Node content1 = node1.addNode("jcr:content", "nt:resource"); content1.setProperty("jcr:lastModified", Calendar.getInstance()); content1.setProperty("jcr:mimeType", "text/xml"); content1.setProperty("jcr:data", getClass().getResourceAsStream("nodetypes-usecase-test.xml")); node1.addMixin("rma:record"); node1.setProperty("rma:recordIdentifier", "testIdentificator"); node1.setProperty("rma:originatingOrganization", "testProperty2"); nodePath.add(node1.getPath()); Node node2 = queryNode.addNode("Test2", "nt:file"); Node content2 = node2.addNode("jcr:content", "nt:resource"); content2.setProperty("jcr:lastModified", Calendar.getInstance()); content2.setProperty("jcr:mimeType", "text/xml"); content2.setProperty("jcr:data", getClass().getResourceAsStream("nodetypes-usecase-test.xml")); node2.addMixin("rma:record"); node2.setProperty("rma:recordIdentifier", "testIdentificator"); node2.setProperty("rma:originatingOrganization", "testProperty2"); nodePath.add(node2.getPath()); session.save(); QueryResult queryResult = query.execute(); NodeIterator iter = queryResult.getNodes(); assertTrue(iter.getSize() == nodePath.size()); // check target nodes for existence Iterator<String> i_path = nodePath.iterator(); while (iter.hasNext() && i_path.hasNext()) { assertEquals(iter.nextNode().getPath(), i_path.next()); } session.logout(); // new login session = (SessionImpl)repository.login(credentials, "ws"); manager = session.getWorkspace().getQueryManager(); Query query2 = manager.createQuery(sqlQuery, Query.SQL); QueryResult queryResult2 = query2.execute(); NodeIterator iter2 = queryResult2.getNodes(); assertTrue(iter2.getSize() == nodePath.size()); // check target nodes for existence i_path = nodePath.iterator(); while (iter.hasNext() && i_path.hasNext()) { assertEquals(iter.nextNode().getPath(), i_path.next()); } } }