/*
* 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());
}
}
}